2021-07-07

如何使用PDO进行SELECT查询?(代码示例)
原创2019-03-15 14:31:5102920
使用PDO运行SELECT查询的方法是有几种的,它们的区别主要在于参数的存在、参数的类型和结果类型。我将为每种情况展示示例,以便可以选择最适合的一个。

没有参数的SELECT查询

如果查询中没有要使用的变量,我们可以使用传统的query()方法。

1

2

// 选择所有用户

$stmt = $pdo->query(“SELECT * FROM users”);

这将给我们一个$stmt对象,它可以用来获取实际的行。

获取一行

如果一个查询只返回一行,那么你可以调用$stmt变量的fetch()方法:

1

2

3

//获取最后一个注册用户

$stmt = $pdo->query(“SELECT * FROM users ORDER BY id DESC LIMIT 1”);

$user = $stmt->fetch();

注意,在PHP中,你可以调用已返回对象的方法,如:

1

$user = $pdo->query(“SELECT * FROM users ORDER BY id DESC LIMIT 1”)->fetch();

查询多行

有两种方法可以获取查询返回的多行。最传统的方法是在while循环中使用fetch()方法:

1

2

3

4

$stmt = $pdo->query(“SELECT * FROM users”);

while ($row = $stmt->fetch()) {

echo $row['name']."

\n";

}

如果必须逐个处理行,可以推荐使用此方法。例如,如果这样的处理是唯一需要采取的操作,或者数据在使用之前需要以某种方式进行预处理。

但是获取将显示在web页面上的多行数据的最佳方法是调用名为fetchAll()方法。它会将查询返回的所有行放入PHP数组中,以后可以使用模板输出数据(这被认为比在获取过程中直接回显数据要好得多)。

代码如下:

1

2

3

4

$data = $pdo->query(“SELECT * FROM users”)->fetchAll();

foreach ($data as $row) {

echo $row['name']."

\n";

}

带参数的SELECT查询

但是大多数时候,我们必须在查询中使用一两个变量,在这种情况下,我们应该使用一个预处理语句(也称为参数化查询),首先用参数(或占位符标记)准备一个查询,然后执行它,分别发送变量。

在PDO中,我们可以同时使用位置占位符和命名占位符。对于简单的查询,就我个人而言,我更喜欢位置占位符,我发现它们不那么冗长,但这完全是个人喜好的问题。

使用位置占位符的SELECT查询

1

2

3

4

//通过id选择特定的用户

$stmt = $pdo->prepare(“SELECT * FROM users WHERE id=?”);

s t m t − > e x e c u t e ( [ stmt->execute([ stmt>execute([id]);

$user = $stmt->fetch();

使用命名占位符的SELECT查询

1

2

3

4

// 通过id选择特定的用户

$stmt = $pdo->prepare(“SELECT * FROM users WHERE id=:id”);

$stmt->execute([‘id’ => $id]);

$user = $stmt->fetch();

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值