如何使用PDO进行SELECT查询?(代码示例)
发布:smiling 来源: PHP粉丝网 添加日期:2020-02-03 14:43:26 浏览: 评论:0
使用PDO运行SELECT查询的方法是有几种的,它们的区别主要在于参数的存在、参数的类型和结果类型。我将为每种情况展示示例,以便可以选择最适合的一个。
没有参数的SELECT查询
如果查询中没有要使用的变量,我们可以使用传统的query()方法。
// 选择所有用户
$stmt = $pdo->query("SELECT * FROM users");
这将给我们一个$stmt对象,它可以用来获取实际的行。
获取一行
如果一个查询只返回一行,那么你可以调用$stmt变量的fetch()方法:
- //获取最后一个注册用户
- $stmt = $pdo->query("SELECT * FROM users ORDER BY id DESC LIMIT 1");
- $user = $stmt->fetch();
注意,在PHP中,你可以调用已返回对象的方法,如:
$user = $pdo->query("SELECT * FROM users ORDER BY id DESC LIMIT 1")->fetch();
查询多行
有两种方法可以获取查询返回的多行。最传统的方法是在while循环中使用fetch()方法:
- $stmt = $pdo->query("SELECT * FROM users");
- while ($row = $stmt->fetch()) {
- echo $row['name']."<br />\n";
- }
如果必须逐个处理行,可以推荐使用此方法。例如,如果这样的处理是唯一需要采取的操作,或者数据在使用之前需要以某种方式进行预处理。
但是获取将显示在web页面上的多行数据的最佳方法是调用名为fetchAll()方法。它会将查询返回的所有行放入PHP数组中,以后可以使用模板输出数据(这被认为比在获取过程中直接回显数据要好得多)。
代码如下:
- $data = $pdo->query("SELECT * FROM users")->fetchAll();
- foreach ($data as $row) {
- echo $row['name']."<br />\n";
- }
带参数的SELECT查询
但是大多数时候,我们必须在查询中使用一两个变量,在这种情况下,我们应该使用一个预处理语句(也称为参数化查询),首先用参数(或占位符标记)准备一个查询,然后执行它,分别发送变量。
在PDO中,我们可以同时使用位置占位符和命名占位符。对于简单的查询,就我个人而言,我更喜欢位置占位符,我发现它们不那么冗长,但这完全是个人喜好的问题。
使用位置占位符的SELECT查询:
- //通过id选择特定的用户
- $stmt = $pdo->prepare("SELECT * FROM users WHERE id=?");
- $stmt->execute([$id]);
- $user = $stmt->fetch();
使用命名占位符的SELECT查询
- // 通过id选择特定的用户
- $stmt = $pdo->prepare("SELECT * FROM users WHERE id=:id");
- $stmt->execute(['id' => $id]);
- $user = $stmt->fetch();
Tags: PDO SELECT
相关文章
- ·PDO版本问题 Invalid parameter number: no parameters were bound(2013-12-03)
- ·pdo连接数据类与中文乱码解决方法(2014-09-11)
- ·pdo连接数据库与查询与保存数据到mysql(2014-09-11)
- ·pdo连接access数据库代码(2014-09-11)
- ·php实现基于PDO的预处理示例(2018-08-31)
- ·Linux(CentOS)下PHP扩展PDO编译安装的方法(2019-10-04)
- ·PHP中PDO的事务处理分析(2019-10-04)
- ·PHP的PDO操作简单示例(2019-10-31)
- ·PHP5.2中PDO的简单使用方法(2019-11-06)
- ·如何获取PDO对象并设置属性?(代码详解)(2020-02-03)
- ·PHP PDOStatement:bindParam插入数据错误问题分析(2020-07-02)
- ·PDO预处理语句PDOStatement对象使用总结(2021-04-27)
- ·PHP PDOStatement对象bindpram()、bindvalue()和bindcolumn之间的区别(2021-04-27)
- ·php使用pdo连接并查询sql数据库的方法(2021-05-04)
- ·php使用pdo连接mssql server数据库实例(2021-05-04)
- ·php使用PDO操作MySQL数据库实例(2021-05-05)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)