不过随着时代的变迁,MySQL(原始) 扩展在 PHP7 中已经被彻底废弃了。现在如果想要使用过程式的代码来操作数据库,只能使用 mysqli 扩展了。...当然,小众并不意味着不好,就像日常开发中,我们很少会在 PHP 环境中使用别的数据库,那么在自己的小项目中完全使用一套 MySQLi 来操作数据库反而更加地方便快捷。...而 PHP7.2.4 之前的版本中的 MySQLi 会使用 mysql_native_password 来对连接密码进行加密,这样就会导致无法连接上数据库。...混合起来使用的话很容易让看代码的人晕头转向。所以,最好还是在一个项目中就坚持使用一种方式。...在接下来的文章中,我们将默认只使用 面向对象 式的写法来继续学习 MySQLi 扩展相关的知识。
本节课我们了解下mysqli扩展及几个sql。...扩展 class mysqli{ } //数据库连接 $mysqli = new mysqli("localhost", "my_user", "my_password", "world"); /.../数据库连接错误号码 $mysqli->connect_errno //数据库连接错误内容 $mysqli->connect_error //设置编码 $mysqli->set_charset("utf8mb4...")) //执行sql语句 $result=$mysqli->query($sql); //设置结果类型 返回一行的数据 //MYSQLI_ASSOC, MYSQLI_NUM, or MYSQLI_BOTH...$list[]=$rs; } //执行sql错误内容 $mysqli->error //关闭连接 $mysqli->close(); //结果记录数 $result->num_rows //关闭结果
不过随着时代的变迁,MySQL(原始) 扩展在 PHP7 中已经被彻底废弃了。现在如果想要使用过程式的代码来操作数据库,只能使用 mysqli 扩展了。...当然,小众并不意味着不好,就像日常开发中,我们很少会在 PHP 环境中使用别的数据库,那么在自己的小项目中完全使用一套 MySQLi 来操作数据库反而更加地方便快捷。...在连接 MySQL8 的时候需要注意,因为 MySQL8 服务器会默认使用 caching_sha2_password 作为密码的加密。...混合起来使用的话很容易让看代码的人晕头转向。所以,最好还是在一个项目中就坚持使用一种方式。...在接下来的文章中,我们将默认只使用 面向对象 式的写法来继续学习 MySQLi 扩展相关的知识。
在实例化过程中,我们并没有给 mysqli 的构造函数传递任何的参数,而是使用 real_connect() 方法来传递数据库服务器信息并建立连接。...相信不少朋友从代码中就可以看出,我们使用 real_connect() 可以在一个 mysqli 实例下来切换不同的数据库连接。...$mysqli->select_db('mysql'); 就是这样一个简单的 select_db() 方法,就可以帮助我们在代码执行过程中动态地修改所连接的数据库。...但是在 MySQLi 中,我们统一只使用 query() 方法就可以了。...在日常的开发过程中,最好还是一条一条的语句来执行,避免出现各种无法查明的问题而影响我们正常的业务执行。至于到底要不要使用这个能力,还是大家仁者见仁智者见智了。
PHP中的MySQLi扩展学习(六)MySQLI_result对象操作 在之前的文章中,我们就已经接触过 MYSQLI_result 相关的内容。它的作用其实就是一个查询的结果集。...不过在 PDO 中,一般直接通过 query() 或者 PDOStatement 对象进行查询之后就会返回结果。...但在 MySQLi 中,会把查询到的结果也放入一个对象中,这就是 MySQLI_result 对象。...查询结果集获取 MySQLI_result 对象的可见属性中,我们只能看到上面的那些信息。...在实际的业务开发中 PDO 还是会使用得更多,但 MySQLi 也绝不是能够完全忽略的,多多动手尝试学习吧。
所以在这里,我们就不再多讲理论方面的东西了,直接上代码来看看 MySQLi 中这两大特性与 PDO 在使用上的区别。 事务处理 首先,我们还是要让 MySQLi 对于错误的语句也报出异常来。...在 PDO 中,我们直接指定连接的报错属性就可以了。...; 这样就指定了在使用 MySQLi 扩展时,所有的错误信息都会作为异常抛出。...预处理语句 总体来说,事务的处理和 PDO 的区别不大,但是预处理语句和 PDO 中的使用的区别就有一些了。首先是我们的 MySQLi 中的占位符只有 ? 问号占位。...对于我们来说,还是多以学习了解为主,在自己封装或者使用某些以 MySQLi 为底层数据库操作的框架时不至于晕头转向。
参数绑定及操作属性 之前的文章中想必大家已经见过我们使用的 bind_param() 方法,它与 PDO 中的 bindParam() 方法有很大的不同。...中绑定参数只能使用 ?...问号占位符,然后在使用 bind_param() 时,使用的是 's' 这种来按顺序绑定参数,这个 's' 代表的就是字符串。...string(53) "No data supplied for parameters in prepared statement" // } // } $stmt->close(); 在代码中...在这个表中,我们有四个字段,所以通过引用传递的方式绑定了 4 个列变量。当使用 fetch() 进行查询结果对象的遍历时,就像使用引用的方式为这 4 个列变量赋值。
PHP中的MySQLi扩展学习(五)MySQLI_STMT对象操作 就像 PDO 中的 PDO_Statment 对象一样,MySQLI_STMT 对象也是一个预处理语句所形成的对象,专门用来操作 MySQLi...参数绑定及操作属性 之前的文章中想必大家已经见过我们使用的 bind_param() 方法,它与 PDO 中的 bindParam() 方法有很大的不同。...中绑定参数只能使用 ?...问号占位符,然后在使用 bind_param() 时,使用的是 's' 这种来按顺序绑定参数,这个 's' 代表的就是字符串。...string(53) "No data supplied for parameters in prepared statement" // } // } $stmt->close(); 在代码中
我们之前也已经学习过了 PDO 中关于事务和预处理语句相关的内容。所以在这里,我们就不再多讲理论方面的东西了,直接上代码来看看 MySQLi 中这两大特性与 PDO 在使用上的区别。...事务处理 首先,我们还是要让 MySQLi 对于错误的语句也报出异常来。关于这个功能就和 PDO 很不一样了。在 PDO 中,我们直接指定连接的报错属性就可以了。...; 这样就指定了在使用 MySQLi 扩展时,所有的错误信息都会作为异常抛出。...预处理语句 总体来说,事务的处理和 PDO 的区别不大,但是预处理语句和 PDO 中的使用的区别就有一些了。首先是我们的 MySQLi 中的占位符只有 ? 问号占位。...对于我们来说,还是多以学习了解为主,在自己封装或者使用某些以 MySQLi 为底层数据库操作的框架时不至于晕头转向。
使用 MySQLi 和 PDO 向 MySQL 插入数据 在创建完数据库和表后,我们可以向表中添加数据。...以下为一些语法规则: PHP 中 SQL 查询语句必须使用引号 在 SQL 查询语句中的字符串值必须加引号 数值的值不需要引号 NULL 值不需要引号 INSERT INTO 语句通常用于向 MySQL...在前面的几个章节中我们已经创建了表 "MyGuests",表字段有: "id", "firstname", "lastname", "email" 和 "reg_date"。..."" . mysqli_error($conn); } mysqli_close($conn); ?> 实例 (PDO) <?...INTO MyGuests (firstname, lastname, email) VALUES ('John', 'Doe', 'john@example.com')"; // 使用
PHP中的MySQLi扩展学习(二)mysqli类的一些少见的属性方法 虽说是少见的一些属性方法,但是可能还是有不少同学在日常的开发中使用过,这里只是学习了可能相对来说我们用得比较少的一些 mysqli...nor servname provided, or not known" 在这段代码中,我们使用了错误的 host 信息。...字符集 最近这些年,我们使用 PHP + MySQL 开发基本上都已经是统一地在使用 UTF-8 来作为默认的字符集编码了。...,在我们的测试中返回的是 NULL 而不是正常的布尔值,这一块将来我们学习到了再说。...大家可以仔细地研究一下这个对象中的这些属性,或许某些内容就是你在实际项目中所需要的。 总结 今天的文章学习的就是一些简单的 mysqli 类所持有的属性和方法。
// 创建数据库连接 $connect = mysqli_connect('127.0.0.1', 'root', 'root', 'test', 8889); // 判读是否连接成功了 if (!...$connect) { echo '数据库连接失败'; // 打印连接失败的原因 var_dump(mysqli_connect_error($connect)); exit()...; } // 设置字符集 mysqli_set_charset($connect, 'utf8'); // 组装sql语句 $sql = "SHOW TABLES"; // 执行sql语句 $res =...mysqli_query($connect, $sql); // 获取结果 $res_array = mysqli_fetch_all($res); var_dump($res_array); mysqli_close...1 => array (size=1) 0 => string 'person' (length=6) 面向对象方式 // 创建数据库连接对象 $connect = new mysqli
虽说是少见的一些属性方法,但是可能还是有不少同学在日常的开发中使用过,这里只是学习了可能相对来说我们用得比较少的一些 mysqli 的属性或方法。就当是扩展一下自己的知识体系。...nor servname provided, or not known" 在这段代码中,我们使用了错误的 host 信息。...字符集 最近这些年,我们使用 PHP + MySQL 开发基本上都已经是统一地在使用 UTF-8 来作为默认的字符集编码了。...,在我们的测试中返回的是 NULL 而不是正常的布尔值,这一块将来我们学习到了再说。...大家可以仔细地研究一下这个对象中的这些属性,或许某些内容就是你在实际项目中所需要的。 总结 今天的文章学习的就是一些简单的 mysqli 类所持有的属性和方法。
php //1、建立到mysql的连接 //mysqli('主机名','数据库用户名','数据库密码','连接的数据库的名字') $mysqli=new mysqli('localhost',...'root','root','test'); if($mysqli->connect_errno){ die('Connect Error:'....$mysqli->connect_error); } //2.设置默认的字符集:utf8 $mysqli->set_charset('utf8'); //3.执行SQL语句 $sql='...php //过程化风格 //1、建立数据库连接 $link=mysqli_connect('localhost','root','root','test') ; if(mysqli_connect_errno...()){ die('Connection Error:'.mysqli_connect_errno()); } //2、设置字符集 mysqli_set_charset($link,'utf8
在MySQL中,允许在数据库函数之前加上@符号,屏蔽系统的错误提示,同时用die()函数给出更易理解的错误提示,然后die()函数将自动退出程序。 上例可以改为: 在(2)的mysql_pconnect(),每次连接前,都会检查是否有使用同样的hostname,use,password的连接,如果有,则直接使用这个连接号。 ...> 注:此函数相当于在MySQL中的USE语句:如 USE forum .SQL查询函数(2个): 1、mysql_query() 格式:int mysql_query...你可以使用多个 方法来获取各行中的字段 ,具体选择哪一个方法主要取决于个人喜好 , 因为只是引用字段的 方法有所不同。...将结果集放到对象中 由于你可能会使用 mysqli的面向对象的语法 , 所以完全可以采用面向对象的方式管理结 果集。可以使用fetch_object() 方法来完成。
mysql sql注入 进阶 今天偶然看了一篇博文,说是一道php面试笔试题,原文如下: 请找出下面代码中的问题,修复并优化 100个。...基础:在字符串中拼装数组时候应该用 { 与 } 括起来。 基础:!$re_1 || $re_2应该是!$re_1 && !$re_2或者!($re_1 || $re_2)。...使用mysqli批处理技术,bind_param() mysqli->affected_rows); /* close connection */ $mysqli->close(); ?...使用了占位符(“?”)
解决php7中 ”Uncaught Error: Class ‘mysqli’ not found“的问题 我好想哭,为什么我查了这么久,一个个说的那么有道理,但是到了我这里偏偏就是错的呢。。。
C++中处理文件类似于处理标准输入和标准输出。类ifstream、ofstream和fstream分别从类 istream、ostream和iostream派生而来。...作为派生的类,它们继承了插入和提取运算符(以及其他成员函数),还有与文件一起使用的成员和构造函数。可将文件 包括进来以使用任何fstream。...如果只执行输入,使用ifstream类;如果只执行输出,使用 ofstream类;如果要对流执行输入和输出,使用fstream类。可以将文件名称用作构造函数参数。...被打开的文件在程序中由一个流对象(stream object)来表示 (这些类的一个实例) ,而对这个流对象所做的任何输入输出操作实际就是对该文件所做的操作。...http://www.cplusplus.com/reference/fstream/fstream/中列出了fstream中可以使用的成员函数。
早在 RxJava1.x 版本就有了Observable.Transformer、Single.Transformer和Completable.Transformer,在2.x版本中变成了ObservableTransformer...其实,在大名鼎鼎的图片加载框架 Glide 以及 Picasso 中也有类似的transform概念,能够将图形进行变换。...RxLifecycle中的LifecycleTransformer trello出品的RxLifecycle能够配合Android的生命周期,防止App内存泄漏,其中就使用了LifecycleTransformer...在我的项目中也使用了知乎的RxLifecycle,根据个人的习惯和爱好,我对LifecycleTransformer稍微做了一些修改,将五个Transformer合并成了一个。....... } 如果你想在RxJava的链式调用中也使用缓存,还可以考虑使用transformer的方式,下面我写了一个简单的方法 /** * Created by Tony Shen on
领取专属 10元无门槛券
手把手带您无忧上云