我的编程空间,编程开发者的网络收藏夹
学习永远不晚

PHP数据库学习之如何使用PDO执行SQL语句

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

PHP数据库学习之如何使用PDO执行SQL语句

这篇文章主要讲解了“PHP数据库学习之如何使用PDO执行SQL语句”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PHP数据库学习之如何使用PDO执行SQL语句”吧!

PHP数据库学习之如何使用PDO执行SQL语句

exec() 方法

在我们执行 INSERT、UPDATE 和 DELETE 等这些不需要返回结果集的SQL语句的时候,我们就可以使用PDO对象中的 exec() 方法,使用这种方法成功执行之后,返回的结果是受到影响的行数,

exec() 方法的语法格式如下:

PDO::exec(string $sql)

要注意的是:

  • $sql 为要执行的 SQL 语句。

  • exec() 方法不会从 SELECT 查询语句中获取相应的结果。

那接下来我们通过实例尝试向数据库中加入一条数据,示例如下:

<?php    $dsn  = 'mysql:host=127.0.0.1;dbname=test';    $user = 'root';    $pwd  = 'root';    try{        $pdo = new PDO($dsn,$user,$pwd);        $sql = "insert into user(name,age,sex) values('壹壹','21','男')";        $res = $pdo -> exec($sql);        if($res) echo '成功添加 '.$res.' 条数据!';    }catch(PDOException $e){        echo '数据库连接失败:'.$e -> getMessage();    }?>

输出结果:

PHP数据库学习之如何使用PDO执行SQL语句

由上述示例可以看出,我们通过exec()方法成功的向数据库中加入了一条数据,并且返回的结果是收到影响的行数。想要返回一个对象的话就可以通过query() 方法,接下来我们看另一种执行SQL语句的方式:query() 方法。

query() 方法

在上述事例中通过exec()方法能够返回这些不需要返回结果集的语句信息,当执行需要返回结果集的 SELECT 查询语句时,我们就需要通过query()语句。通过该方法执行成功的话,反悔的家国是一个PDOStatement 对象。

如果使用了query() 方法,并想了解获取的数据行总数,可以使用 PDOStatement 对象中的 rowCount() 方法获取。

query()方法的语法格式如下:

PDO::query(string $sql)PDO::query(string $sql, int $PDO::FETCH_COLUMN, int $colno)PDO::query(string $sql, int $PDO::FETCH_CLASS, string $classname, array $ctorargs)PDO::query(string $sql, int $PDO::FETCH_INTO, object $object)

其中需要注意的是:

$sql 为要执行的 SQL 语句;其余的参数用来为语句设置默认的获取模式,相当于调用结果对象 PDOStatement::setFetchMode() 方法。

那接下来我们通过query()方法来查询我们前面添加的那条数据,示例如下:

<?php    $dsn  = 'mysql:host=127.0.0.1;dbname=test';    $user = 'root';    $pwd  = 'root';    try{        $pdo = new PDO($dsn,$user,$pwd);        $sql = "SELECT * FROM user WHERE name='壹壹'";        $res = $pdo -> query($sql,PDO::FETCH_ASSOC);        print_r($res);    }catch(PDOException $e){        echo '数据库连接失败:'.$e -> getMessage();    }?>

输出结果:

PHP数据库学习之如何使用PDO执行SQL语句

其中使用 query() exec() 方法有以下几点需要注意:

  • query() 和 exec() 都可以执行所有的 SQL 语句,只是返回值不同而已;

  • query() 可以实现所有 exec() 的功能;

  • 当把 select 语句应用到 exec() 时,总是返回 0;

  • 如果要看查询的具体结果,可以通过 foreach 语句完成循环输出。

prepare()execute() 方法

当有需要迭代传入不同参数的时候,也就是方同一个查询需要多次执行的时候,使用预处理语句的方式会让实现效率更高,使用预处理语句就需要用到PDO对象中的 prepare() 方法去准备一个将要执行的查询,再使用 PDOStatement 对象中的 execute() 方法来执行。那接下来我们就来看一下prepare() execute() 方法。

prepare() 方法的语法格式如下:

PDO::prepare(string $statement[, array $driver_options = array()])

其中需要注意的是:

  • $statement   表示的是必须是对目标数据库有效的 SQL 语句模板;

  • $driver_options   表示为可选参数,是数组类型的可选参数,包含一个或多个键值对,为返回的 PDOStatement 对象设置属性。

execute() 方法的语法格式如下:

PDOStatement::execute([array $input_parameters])

其中需要注意的是:

  • 参数 $input_parameters 为一个元素个数和将被执行的 SQL 语句中绑定的参数一样多的数组。

  • SQL 语句模板中可以包含零个或多个参数占位标记,格式可以是命名(:name)或问号(?)的形式,当它执行时将用真实数据取代。

  • 在同一个 SQL 语句里,命名和问号形式不能同时使用,只能选择其中一种参数形式。如果使用命名形式的占位标记,那么标记的命名必须是唯一的。

接下来我们看一下使用命名形式的参数占位符,查询指定的 SQL 语句,示例如下:

<?php    $dsn  = 'mysql:host=127.0.0.1;dbname=test';    $user = 'root';    $pwd  = 'root';    try{        $pdo = new PDO($dsn,$user,$pwd);        $sql = "SELECT name,age,sex FROM user WHERE age = :age";        $sth = $pdo -> prepare($sql);        $sth -> execute([':age'=>11]);        $res1 = $sth -> fetchAll();        $sth -> execute(array(':age'=>14));        $res2 = $sth -> fetchAll();        echo '<pre>';        print_r($res1);        print_r($res2);    }catch(PDOException $e){        echo '数据库连接失败:'.$e -> getMessage();    }?>

输出结果:

PHP数据库学习之如何使用PDO执行SQL语句

上述示例是使用命名形式的参数占位符,查询指定的 SQL 语句,接下来我们看一下使用问号形式的参数占位符,查询指定的 SQL 语句。示例如下:

<?php    $dsn  = 'mysql:host=127.0.0.1;dbname=test';    $user = 'root';    $pwd  = 'root';    try{        $pdo = new PDO($dsn,$user,$pwd);        $sql = "SELECT name,age,sex FROM user WHERE age = ? AND sex = ?";        $sth = $pdo -> prepare($sql);        $sth -> execute([12,'男']);        $res1 = $sth -> fetchAll();        $sth -> execute(array(11,'女'));        $res2 = $sth -> fetchAll();        echo '<pre>';        print_r($res1);        print_r($res2);    }catch(PDOException $e){        echo '数据库连接失败:'.$e -> getMessage();    }?>

输出结果:

PHP数据库学习之如何使用PDO执行SQL语句

由此我们便通过使用问号形式的参数占位符,查询指定的 SQL 语句。

感谢各位的阅读,以上就是“PHP数据库学习之如何使用PDO执行SQL语句”的内容了,经过本文的学习后,相信大家对PHP数据库学习之如何使用PDO执行SQL语句这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

PHP数据库学习之如何使用PDO执行SQL语句

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

PHP数据库学习之如何使用PDO执行SQL语句

这篇文章主要讲解了“PHP数据库学习之如何使用PDO执行SQL语句”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PHP数据库学习之如何使用PDO执行SQL语句”吧!exec() 方法在我们执
2023-06-25

如何使用JDBC连接数据库并执行SQL语句

JDBC是Java数据库连接的缩写,是Java程序与数据库进行交互的标准API。JDBC主要包括Java.sql和javax.sql两个包,通过DriverManager获取数据库连接对象Connection,并通过Statement或PreparedStatement执行SQL语句
2023-05-18

PHP数据库学习之如何设置与获取PDO属性

本篇内容主要讲解“PHP数据库学习之如何设置与获取PDO属性”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“PHP数据库学习之如何设置与获取PDO属性”吧!接下来就来了解一下怎样设置与获取PDO属
2023-06-25

IDEA连接MySQL数据库并执行SQL语句使用数据图文详解

目录一、IDEA连接mysql数据库(一)首先新建普通Java项目(二)连接数据库二、使用数据库的数据(一)新建Java类 Test(二)下载MySQL驱动Jar包(三)返回IDEA,新建文件夹lib(四)非常重要(添加到库)(五)编写Te
2023-03-23

阿里云数据库结束执行语句如何正确使用

在阿里云数据库中,结束执行语句是一个非常重要的概念。本文将介绍什么是结束执行语句,以及如何正确使用它。阿里云数据库是一种高性能、高可靠性的云数据库服务。在使用阿里云数据库时,我们经常需要执行一些复杂的SQL语句。但是,有些SQL语句可能会耗费大量的时间和资源,因此我们需要及时终止这些语句的执行。这时,结束执行语句
阿里云数据库结束执行语句如何正确使用
2024-01-18

如何使用 PHP 内置函数执行数据库查询?

php 内置函数可用于执行数据库查询,包括:mysqli_query():执行查询并返回结果。pdostatement:准备查询并绑定参数以防止 sql 注入。mysqli_affected_rows():获取受查询影响的行数(使用 mys
如何使用 PHP 内置函数执行数据库查询?
2024-04-23

学习如何使用numpy库进行数据分析和科学计算

随着信息时代的到来,数据分析和科学计算成为了越来越多领域的重要组成部分。在这个过程中,使用计算机进行数据处理和分析已经成为必不可少的工具。而在Python中,numpy库就是一个非常重要的工具,它可以让我们更加高效地进行数据处理和分析,更加
学习如何使用numpy库进行数据分析和科学计算
2024-01-19

使用Java如何将SQL脚本文件执行到数据库中

使用Java如何将SQL脚本文件执行到数据库中?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。方式一:直接读取SQL脚本文件的内容,然后传递到SQL中。代码:RunSqlSe
2023-05-31

如何使用SQL语句在MySQL中创建和管理数据库?

如何使用SQL语句在MySQL中创建和管理数据库?MySQL是一种广泛应用的关系型数据库管理系统,提供了丰富的SQL语句来创建和管理数据库。在本文中,我们将详细介绍如何使用SQL语句在MySQL中创建和管理数据库,并提供具体的代码示例。一、
如何使用SQL语句在MySQL中创建和管理数据库?
2023-12-17

使用mybatis执行SQL语句时有参数出现返回NULL值如何解决

今天就跟大家聊聊有关使用mybatis执行SQL语句时有参数出现返回NULL值如何解决,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。原来的写法: