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

使用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日

相关文章

  • html css javascript mysql php一些简单随笔

    1.格式 <!doctype html> 声明文档类型,说明html版本号 <html> 说明代码格式 <head>  网页的头部 <meta charset=”utf-8″> 定义网页字符集,关键词等内容:例如:<meta name=”keywords” content=”html”> <t…

    MySQL 2023年4月12日
    00
  • nodejs集成sqlite使用示例

    下面是“nodejs集成sqlite使用示例”的完整攻略: 步骤1 安装 sqlite3 包 在终端运行以下命令: npm install sqlite3 步骤2 创建和连接数据库 在 node.js 中,需先连接数据库才能进行后续的查询、更新等操作。在此之前先创建一个名为“mydatabase”的 sqlite 数据库,用 SQLite3 包连接该数据库,…

    database 2023年5月21日
    00
  • SQL 计算两个日期之间相差的月份和年份

    计算两个日期之间相差的月份,可以使用DATEDIFF函数,但是它只返回两个日期之间相差的天数,因此需要使用其他函数来将天数转换为月份。以下是一种使用YEAR()、MONTH()和DATEDIFF()函数计算两个日期之间相差月份的方法: SELECT YEAR(date2) * 12 + MONTH(date2) – (YEAR(date1) * 12 + M…

    database 2023年3月27日
    00
  • docker-compose 安装 mysql:5.7.31

        目录 一.新建一个启动服务的目录 二.新建文件docker-compose.yml 三.新建角本文件 init-mysql.sh 四.实使化目录和配置文件 启动服务 登陆mysql 其它操作   参考文档: 一.新建一个启动服务的目录 mkdir /usr/local/docker/mysql cd /usr/local/docker/mysql 二…

    MySQL 2023年4月13日
    00
  • SQL Server数据迁移至PostgreSQL出错的解释以及解决方案

    问题解释 在将SQL Server数据迁移到PostgreSQL的过程中,可能会出现以下错误: ERROR: null value in column “xxxx” violates not-null constraint ERROR: relation “xxxx” does not exist ERROR: invalid input syntax fo…

    database 2023年5月21日
    00
  • SpringBoot异常处理器的使用与添加员工功能实现流程介绍

    一、SpringBoot异常处理器的使用 异常处理是我们在软件开发时不可避免的问题,一旦程序发生了错误,我们就需要通过一个有效的异常处理器来帮助我们来排查和解决问题。SpringBoot提供了许多种异常处理的方式,其中比较常用的方式是使用@ControllerAdvice和@ExceptionHandler注解来进行异常处理。 首先,在SpringBoot的…

    database 2023年5月21日
    00
  • WMware redhat 5 oracle 11g 安装方法

    安装 VMware Workstation 第一步,需要准备好 VMware Workstation 软件包,并在 Windows 中进行安装。 第二步,启动 VMware Workstation,创建一个新的虚拟机。在新建虚拟机的过程中,选择 Red Hat EL 5 作为虚拟机操作系统。 第三步,设置硬件参数。建议在最小硬件要求的基础上增加一些内存和磁盘…

    database 2023年5月22日
    00
  • Oracle如何直接运行OS命令(上)第1/2页

    下面是详细讲解“Oracle如何直接运行OS命令(上)第1/2页”的完整攻略。 标题 Oracle如何直接运行OS命令(上)第1/2页 正文 Oracle可以直接运行操作系统(OS)命令,可以帮助管理员更方便地进行一些操作。但是需要注意的是,这个功能只应在必要的情况下使用,并需要小心谨慎地使用。在此介绍Oracle如何直接运行OS命令的攻略。 需要使用的命令…

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