首页
学习
活动
专区
圈层
工具
发布

PHP中的MySQLi扩展学习(四)mysqli的事务与预处理语句

对于 MySQLi 来说,事务和预处理语句当然是它之所以能够淘汰 MySQL(原始) 扩展的资本。我们之前也已经学习过了 PDO 中关于事务和预处理语句相关的内容。...所以在这里,我们就不再多讲理论方面的东西了,直接上代码来看看 MySQLi 中这两大特性与 PDO 在使用上的区别。 事务处理 首先,我们还是要让 MySQLi 对于错误的语句也报出异常来。...在这段测试代码中,第二条 SQL 语句是会报错的,于是进入了 catch 中,使用 rollback() 来回滚事务。...预处理语句 总体来说,事务的处理和 PDO 的区别不大,但是预处理语句和 PDO 中的使用的区别就有一些了。首先是我们的 MySQLi 中的占位符只有 ? 问号占位。...; $username = 'aaa'; $stmt->bind_param("s", $username); // 绑定参数 $stmt->execute(); // 执行语句 $aUser = $

3.3K00
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    PHP中的MySQLi扩展学习(四)mysqli的事务与预处理语句

    PHP中的MySQLi扩展学习(四)mysqli的事务与预处理语句 对于 MySQLi 来说,事务和预处理语句当然是它之所以能够淘汰 MySQL(原始) 扩展的资本。...我们之前也已经学习过了 PDO 中关于事务和预处理语句相关的内容。所以在这里,我们就不再多讲理论方面的东西了,直接上代码来看看 MySQLi 中这两大特性与 PDO 在使用上的区别。...事务处理 首先,我们还是要让 MySQLi 对于错误的语句也报出异常来。关于这个功能就和 PDO 很不一样了。在 PDO 中,我们直接指定连接的报错属性就可以了。...预处理语句 总体来说,事务的处理和 PDO 的区别不大,但是预处理语句和 PDO 中的使用的区别就有一些了。首先是我们的 MySQLi 中的占位符只有 ? 问号占位。...的事务与预处理语句.php 参考文档: https://www.php.net/manual/zh/book.mysqli.php

    2.8K10

    PHP中的MySQLi扩展学习(一)MySQLi介绍

    只面向过程 不支持 存储过程 、 多语句执行 、 预处理语句 PHP7 中已经删除了并且完全不支持 然后是 PDO 。...仅支持面向对象方式使用 可以连接多种数据库,切换数据库带来的变更少,甚至可能不用修改代码 支持 存储过程 、 多语句执行 、 预处理语句 最后就是 MySQLi 。...支持面向对象和面向过程两种写法 仅支持 MySQL 数据库 支持 存储过程 、 多语句执行 、 预处理语句 跟随 PHP 及 MySQL 的版本更新,可以更快速地支持更多的 MySQL 高级特性 从它们三个的这些特点来看...$mysqli = mysqli_connect("localhost", "root", "", "blog_test");$res = mysqli_query($mysqli, "SELECT *...() 函数来执行语句,接着又使用面向对象的方式来获取结果集。

    3.9K00

    PHP中的MySQLi扩展学习(一)MySQLi介绍

    只面向过程 不支持 存储过程 、 多语句执行 、 预处理语句 PHP7 中已经删除了并且完全不支持 然后是 PDO 。...仅支持面向对象方式使用 可以连接多种数据库,切换数据库带来的变更少,甚至可能不用修改代码 支持 存储过程 、 多语句执行 、 预处理语句 最后就是 MySQLi 。...支持面向对象和面向过程两种写法 仅支持 MySQL 数据库 支持 存储过程 、 多语句执行 、 预处理语句 跟随 PHP 及 MySQL 的版本更新,可以更快速地支持更多的 MySQL 高级特性 从它们三个的这些特点来看...$mysqli = mysqli_connect("localhost", "root", "", "blog_test"); $res = mysqli_query($mysqli, "SELECT...mysqli_query() 函数来执行语句,接着又使用面向对象的方式来获取结果集。

    3.7K20

    PHP中的MySQLi扩展学习(三)mysqli的基本操作

    不过,今天的主角是 MySQLi 中如何执行 SQL 语句以及多条 SQL 语句的执行。 连接与选择数据库 首先是一个小内容的学习分享,依然还是连接数据库,不过这次我们用另外一种方式来进行连接。...执行 SQL 语句 对于 PDO 来说,如果是查询语句,我们需要使用 query() 方法,如果是增、删、改之类的其它语句,我们要使用 exec() ,通过这两个方法分别执行不同的 SQL 语句。...我们如果需要获取受影响的行数需要使用 MySQLi 的属性 affected_rows 。对于插入语句来说,获取最新插入的数据ID使用的是 insert_id 属性。...接下来我们就看看 MySQLi 是如何来执行这个多条语句拼接在一起的 SQL 语句的。 $mysqli->multi_query($sql); $i = 1; do{ echo '第' ....总结 光说不练假把式,虽说多语句执行看似很美好,但即使在这简单的测试代码中,也会出现各种问题,大家一定要自己多尝试一下。

    3.8K20

    PHP中的MySQLi扩展学习(三)mysqli的基本操作

    不过,今天的主角是 MySQLi 中如何执行 SQL 语句以及多条 SQL 语句的执行。 连接与选择数据库 首先是一个小内容的学习分享,依然还是连接数据库,不过这次我们用另外一种方式来进行连接。...执行 SQL 语句 对于 PDO 来说,如果是查询语句,我们需要使用 query() 方法,如果是增、删、改之类的其它语句,我们要使用 exec() ,通过这两个方法分别执行不同的 SQL 语句。...我们如果需要获取受影响的行数需要使用 MySQLi 的属性 affected_rows 。对于插入语句来说,获取最新插入的数据ID使用的是 insert_id 属性。...接下来我们就看看 MySQLi 是如何来执行这个多条语句拼接在一起的 SQL 语句的。 $mysqli->multi_query($sql);$i = 1;do{ echo '第' ....总结 光说不练假把式,虽说多语句执行看似很美好,但即使在这简单的测试代码中,也会出现各种问题,大家一定要自己多尝试一下。

    3.8K00

    PHP中的MySQLi扩展学习(五)MySQLI_STMT对象操作

    就像 PDO 中的 PDO_Statment 对象一样,MySQLI_STMT 对象也是一个预处理语句所形成的对象,专门用来操作 MySQLi 所生成的预处理语句的。...其实操作方式之类也都比较相似,不外乎以绑定参数为主的一些针对 SQL 语句和获取结果集的操作。...所以,我们需要通过 MySQLI_STMT 对象的 insert_id 来获得新增加数据的 ID ,或者通过 affected_rows 属性来获得当前语句执行后影响的行数,来确定语句是否真正地执行完成并达到我们的期望...可以看出,MySQLI_STMT 的错误属性和信息基本和 MySQLi 对象的是一样的。 列绑定 除了请求查询语句参数的绑定之外,MySQLI_STMT 也是支持直接绑定列的。...MySQLI_STMT 中绑定列的方法名为 bind_result() ,虽说名字不一样,但功能其实都是差不多的,查询语句中是几个列名,就要绑定几个列名。

    3.3K00

    PHP中的MySQLi扩展学习(五)MySQLI_STMT对象操作

    PHP中的MySQLi扩展学习(五)MySQLI_STMT对象操作 就像 PDO 中的 PDO_Statment 对象一样,MySQLI_STMT 对象也是一个预处理语句所形成的对象,专门用来操作 MySQLi...所生成的预处理语句的。...所以,我们需要通过 MySQLI_STMT 对象的 insert_id 来获得新增加数据的 ID ,或者通过 affected_rows 属性来获得当前语句执行后影响的行数,来确定语句是否真正地执行完成并达到我们的期望...可以看出,MySQLI_STMT 的错误属性和信息基本和 MySQLi 对象的是一样的。 列绑定 除了请求查询语句参数的绑定之外,MySQLI_STMT 也是支持直接绑定列的。...MySQLI_STMT 中绑定列的方法名为 bind_result() ,虽说名字不一样,但功能其实都是差不多的,查询语句中是几个列名,就要绑定几个列名。

    3K10

    PHP扩展 Mysql 与 Mysqli

    作为替代,可以使用 mysqli 或者 PDO_MySQL 扩展代替。 MySQL 增强版。 mysqli扩展允许我们访问MySQL 4.1及以上版本提供的功能。...特性比较 特性 mysqli mysql PHP版本 >=5.0 >3.0 MySQL开发状态 活跃 仅维护 MySQL建议使用 首选 建议 API的字符集支持 是 否 存储过程支持情况 是 否 多语句执行支持情况...相关概念 MySQL 与 MySQLi 都是PHP方面的函数集。 在 PHP5 版本以后,增加了mysqli的函数功能。 某种意义上讲,它是MySQL系统函数的增强版,更稳定更高效更安全。...MySQLi 多次运行将使用同一连接进程,减少了服务器的开销。 链接方式 <?...建议 PHP版本为5.x建议使用 mysqli 扩展。 PHP版本为7 只能使用 mysqli 扩展。 Thanks ~

    3.7K30

    PHP Mysqli 常用代码集合

    PHP5.0开始,不仅可以使用早期的mysql数据库扩展函数,还能使用新扩展的mysqli技术实现与mysql数据库的信息交流,PHP的mysqli扩展被封装在在一个类中,它是一种面向对象技术,只能在PHP5...和MYSQL4,1或更高的版本才能使用,(i)表示该进,使用mysqli,执行速度更快,更方便,更高效,也可以使数据库访问更安全(因为用类模式) 使用mysqli 简单流程 设置PHP.ini 配置文件...stmt->insert_id;          当是插入命令时,返回插入的行id(自动) 事务处理 在默认情况下,MYSQL是以自动提交(autocommit)模式运行,这就意味着所执行的每一个语句都将立即写入数据库中...$res2 or $mysqli->affected_rows !....jpg 以上就是PHP Mysqli 常用代码集合所有详细内容。

    2.4K20

    PHP中的MySQLi扩展学习(二)mysqli类的一些少见的属性方法

    通过打印 mysqli 的 error_list 属性就可以看到当前的错误信息。 错误信息 紧接着上一段,对于执行语句的错误信息,我们可以通过几个 mysqli 中的属性来获得。...这两个错误信息内容都是在执行 SQL 语句之后数据库返回的内容。...返回的内容非常多,官方也没有具体的每个字段的说明文档。不过从字段名中我们还是可以看到一些有用的信息,比如 bytes_sent 字节发送的数量,bytes_received 字节接收的数量。...除了使用 预处理 功能来解决 SQL 注入之外,MySQLi 还为我们提供了一个 real_escape_string() 方法,可以手工地解决SQL语句中的一些特殊符号问题。...我们还没有正式开始学习查询之类的语句,不过从这些属性方法就可以看出,相对于 PDO 来说,mysqli 提供的功能确实更加的全面一些。后面我们将继续深入地学习和探索 mysqli 的各种方法和使用。

    2.2K10
    领券