PHP数据库学习之怎样使用PDO执行SQL语句?

在之前的文章中给大家带来了《PHP数据库学习之怎样使用PDO连接数据库?》,其中给大家详细的介绍了在PHP中怎样通过PDO来连接数据库,本篇文章我们继续来看一下PHP中怎样使用PDO执行SQL语句。希望对大家有帮助!

在之前的文章中给大家带来了《PHP数据库学习之怎样使用PDO连接数据库?》,其中给大家详细的介绍了在PHP中怎样通过PDO来连接数据库,本篇文章我们继续来看一下PHP中怎样使用PDO执行SQL语句。希望对大家有帮助!

PHP数据库学习之怎样使用PDO执行SQL语句?

千万级数据并发如何处理?进入学习

在之前的文章中我们已经学习到了PHP怎样通过PDO来连接到数据库,连接到数据库那就得执行SQL语句。在 PDO 中,我们可以使用三种方式来执行 SQL 语句,分别是 exec() 方法,query() 方法,以及预处理语句 prepare() 和 execute() 方法。那接下来我们一起来看一下吧。

exec() 方法

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

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

PDO::exec(string $sql)登录后复制

要注意的是:

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

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

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

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()方法来查询我们前面添加的那条数据,示例如下:

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 语句,示例如下:

prepare($sql);
$sth -> execute([;:age;=>11]);
$res1 = $sth -> fetchAll();
$sth -> execute(array(;:age;=>14));
$res2 = $sth -> fetchAll();
echo ;;;
print_r($res1);
print_r($res2);
}catch(PDOException $e){
echo ;数据库连接失败:;.$e -> getMessage();
}
?>登录后复制

输出结果:

PHP数据库学习之怎样使用PDO执行SQL语句?

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

prepare($sql);
$sth -> execute([12,;男;]);
$res1 = $sth -> fetchAll();
$sth -> execute(array(11,;女;));
$res2 = $sth -> fetchAll();
echo ;;;
print_r($res1);
print_r($res2);
}catch(PDOException $e){
echo ;数据库连接失败:;.$e -> getMessage();
}
?>登录后复制

输出结果:

PHP数据库学习之怎样使用PDO执行SQL语句?

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

大家如果感兴趣的话,可以点击《PHP视频教程》进行更多关于PHP知识的学习。

php pdo类的方法有哪些

原创2021-07-15 11:25:00950 + php学习QQ群(点击入群)

php pdo类的方法:beginTransaction()、commit()、__construct()、errorCode()、errorInfo()、exec()、getAttribute()、query()、quote()等等。

PHP数据库学习之怎样使用PDO执行SQL语句?

php入门到就业线上直播课:进入学习API 文档、设计、调试、自动化测试一体化协作工具:点击使用

本教程操作环境:windows7系统、PHP7.1版,DELL G3电脑

PDO 是什么

PDO 是 PHP Date Object(PHP 数据对象)的简称,它是 PHP 为访问数据库定义的一个轻量级的、一致性的接口,它提供了一个数据访问抽象层,这样无论你使用什么数据库,都可以通过同一函数执行查询和获取数据,大大简化了数据库的操作,并能够屏蔽不同数据库之间的差异。

PDO 是与 PHP5.1 版本一起发行的,使用 PDO 可以很方便地进行跨数据库程序的开发,以及不同数据库间的移植,目前 PDO 支持的数据库包括 Firebird、FreeTDS、Interbase、MySQL、SQL Server、ODBC、Oracle、Postgre SQL、SQLite 和 Sybase 等。

有了 PDO 就不必再使用 mysqli_* 的一系列函数了,只需要使用 PDO 中的方法就可以对数据库进行操作。

PDO 类的方法:

  • beginTransaction() — 启动一个事务

  • commit() — 提交一个事务

  • __construct() — 创建一个表示数据库连接的 PDO 实例

  • errorCode() — 获取跟数据库句柄上一次操作相关的 SQLSTATE

  • errorInfo() — 返回最后一次操作数据库的错误信息

  • exec() — 执行一条 SQL 语句,并返回受影响的行数

  • getAttribute() — 取回一个数据库连接的属性

  • getAvailableDrivers() — 返回一个可用驱动的数组

  • inTransaction() — 检查是否在一个事务内

  • lastInsertId() — 返回最后插入行的ID或序列值

  • prepare() — 备要执行的SQL语句并返回一个 PDOStatement 对象

  • query() — 执行 SQL 语句,返回PDOStatement对象,可以理解为结果集

  • quote() — 为SQL语句中的字符串添加引号。

  • rollBack() — 回滚一个事务

  • setAttribute() — 设置属性

其中pdo类常用方法:

  • exec()

  • query()

  • lastInsertId()

exec('set names utf8');

$pdo->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE,PDO::FETCH_BOTH);

$sql=”insert into user(username,age) values('user123','55')”;

if($pdo->exec($sql)){
$lastid=$pdo->lastInsertId();
echo “ID为{$lastid}的数据插入成功!”;
}
?>登录后复制

PHP数据库学习之怎样使用PDO执行SQL语句?

  • setAttribute()

设置获取模式属性

exec('set names utf8');
$pdo->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE,PDO::FETCH_ASSOC);

$sql=”select * from user”;

$smt=$pdo->query($sql);
$rows=$smt->fetchAll();

echo '';
print_r($rows);
echo '';
?>登录后复制

PHP数据库学习之怎样使用PDO执行SQL语句?***获取索引数组

exec('set names utf8');

$pdo->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE,PDO::FETCH_NUM);

$sql=”select * from user”;
$smt=$pdo->query($sql);
$rows=$smt->fetchAll();

echo '';
print_r($rows);
echo '';
?>登录后复制

PHP数据库学习之怎样使用PDO执行SQL语句?

获取混合数组

exec('set names utf8');

$pdo->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE,PDO::FETCH_BOTH);

$sql=”select * from user”;
$smt=$pdo->query($sql);
$rows=$smt->fetchAll();

echo '';
print_r($rows);
echo '';
?>登录后复制

PHP数据库学习之怎样使用PDO执行SQL语句?

以上就是php pdo类的方法有哪些的详细内容,更多请关注钦钦技术栈其它相关文章!

转载至:php中文网【www.php.cn】

版权声明:本文(即:原文链接:https://www.qin1qin.com/catagory/27237/)内容由互联网用户自发投稿贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 630367839@qq.com 举报,一经查实,本站将立刻删除。

(0)
上一篇 2022年 9月 29日 5:07:43
下一篇 2022年 9月 29日 5:08:51

软件定制开发公司

相关阅读

发表回复

登录后才能评论
通知:禁止投稿所有关于虚拟货币,币圈类相关文章,发现立即永久封锁账户ID!