php使用PDO下exec()函数查询执行后受影响行数的方法

yizhihongxing

使用PDO下的exec()函数可以执行一些不需要准备的SQL语句(如INSERT、DELETE、UPDATE等),并且该函数的返回值一般是受影响的记录数。但是,如果在执行INSERT语句时没有在SQL语句中添加RETURNING子句,那么直接执行exec()函数返回的受影响行数可能是0,这显然不符合预期。因此,需要使用其他方法来获取准确的受影响行数。

以下是使用PDO下exec()函数查询执行后受影响行数的具体方法:

  1. 使用PDO的commit()方法返回受影响行数

在PDO中,exec()函数执行的语句是没有被包装在事务中的,如果要使用该方法返回受影响行数,需要先调用PDO的beginTransaction()方法开启事务,然后提交事务并获取返回值。代码示例:

try {
    $pdo = new PDO("mysql:host=127.0.0.1;dbname=test;charset=utf8","root","");
    $pdo->beginTransaction();//开启事务
    $rowCount = $pdo->exec("INSERT INTO `users` (`name`, `age`) VALUES ('Tom', 18)");
    $pdo->commit();//提交事务
    echo '受影响行数为:'.$rowCount;
} catch (PDOException $e) {
    echo '执行失败:'.$e->getMessage();
    $pdo->rollBack();//回滚事务
}
  1. 使用INSERT、DELETE、UPDATE等语句的返回值

在使用PDO执行SQL语句时,INSERT、DELETE、UPDATE等语句的返回值一般都是受影响的记录数,可以将该返回值作为受影响行数。代码示例:

try {
    $pdo = new PDO("mysql:host=127.0.0.1;dbname=test;charset=utf8","root","");
    $rowCount = $pdo->exec("INSERT INTO `users` (`name`, `age`) VALUES ('Mary', 25)");
    echo '受影响行数为:'.$rowCount;
} catch (PDOException $e) {
    echo '执行失败:'.$e->getMessage();
}

总的来说,使用PDO下的exec()函数查询执行后受影响行数的方法可以根据不同情况选择相应的方式,通常可以直接使用INSERT、DELETE、UPDATE等语句的返回值作为受影响行数来使用。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:php使用PDO下exec()函数查询执行后受影响行数的方法 - Python技术站

(0)
上一篇 2023年5月21日
下一篇 2023年5月21日

相关文章

  • php redis 操作手册

    本篇文章给大家分享的内容是关于php redis 操作手册,有着一定的参考价值,有需要的朋友可以参考一下redis手册推荐:   redis中文手册下载地址:http://www.php.cn/xiazai/shouce/54 redis中文在线手册:http://www.php.cn/course/49.html String 类型操作 string是re…

    Redis 2023年4月13日
    00
  • 如何利用percona-toolkit工具检查MySQL数据库主从一致性以及修复

    如何利用percona-toolkit工具检查MySQL数据库主从一致性以及修复 Percona Toolkit 是由 Percona 公司出品的一套 MySQL 工具集,其中包括各种用于分析和管理 MySQL 数据库的工具。本文将重点介绍如何使用 percona-toolkit 工具检查 MySQL 数据库主从一致性,并修复主从不一致的问题。 1. 安装 …

    database 2023年5月18日
    00
  • mybatis 插件: 打印 sql 及其执行时间实现方法

    Mybatis插件是Mybatis框架提供的一种可插拔的机制,可以在Mybatis执行过程中通过拦截拦截器接口来修改其处理逻辑或者增加额外的处理逻辑。其中比较常见的插件是对 SQL 以及它们所需参数的拦截。下面给出实现Mybatis插件打印SQL及其执行时间的完整攻略。 1、实现拦截器类 在Mybatis中实现插件需要实现Interceptor接口,并重写其…

    database 2023年5月21日
    00
  • 如何在MySQL中设置外键约束以及外键的作用

    1.外键的作用,主要有两个:   一个是让数据库自己通过外键来保证数据的完整性和一致性   一个就是能够增加ER图的可读性 2.外键的配置    1)先创建一个主表,代码如下:    #创建表student,并添加各种约束   create table student ( id int primary key , #主键约束 name varchar(20)…

    MySQL 2023年4月13日
    00
  • ASP常用函数收藏乱七八糟未整理版

    ASP常用函数收藏乱七八糟未整理版 总览 本攻略旨在整理ASP中经常使用的函数,让读者们可以快速了解和掌握这些函数的使用方法。 以下是本攻略涉及到的函数列表: Len() LCase() UCase() Left() Right() Mid() Replace() Trim() FormatCurrency() FormatDateTime() Format…

    database 2023年5月22日
    00
  • 超全的webshell权限提升方法

    下面我来详细讲解“超全的webshell权限提升方法”的完整攻略。 什么是WebShell 在开始讲解 WebShell 权限提升的攻略之前,先简要介绍一下 WebShell。WebShell 是一种由黑客通过 Web 服务器的漏洞等方式上传到 Web 服务器中的一种脚本文件,可以通过 Web 服务器 HTTP 服务对外发布,并提供给黑客查看、控制 Web …

    database 2023年5月21日
    00
  • navicatdesignquery.sql.bak系统找不到指定路径错误的解决方法

    当使用 Navicat 进行数据库的查询、编辑等操作时,有时会遇到 “navicatdesignquery.sql.bak系统找不到指定路径” 这样的错误提示,这种情况一般是由于 Navicat 自身或操作系统的问题所造成的,但是这并不意味着我们就无法解决这个问题。下面是解决这个问题的详细攻略: 问题原因分析: Navicat 自身问题,如升级版本或者重装 …

    database 2023年5月22日
    00
  • 图文详解Windows下使用Redis缓存工具的方法

    图文详解Windows下使用Redis缓存工具的方法 什么是Redis Redis是一种开源的内存数据结构存储,也被称为数据结构服务器。Redis支持多种数据结构,包括字符串、哈希表、列表、集合、有序集合等。Redis运行在内存中,因此读写速度非常快。 Redis的安装 1. 下载Redis 首先,需要从Redis的官方网站上下载Windows版本的Redi…

    database 2023年5月22日
    00
合作推广
合作推广
分享本页
返回顶部