• 技术文章 >后端开发 >php教程

    如何使用PDO进行SELECT查询?(代码示例)

    藏色散人藏色散人2019-03-15 14:31:51原创2355
    使用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();

    本篇文章就是关于使用PDO进行SELECT查询的相关介绍,希望对需要的朋友有所帮助!

    以上就是如何使用PDO进行SELECT查询?(代码示例)的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:PDO SELECT查询
    上一篇:php多线程是什么意思 下一篇:PHP如何使用shuffle()函数生成随机密码?(代码示例)
    大前端线上培训班

    相关文章推荐

    • 实现PDO分页和url重写• 什么是PDO• 什么是PDO以及如何在Unix和Windows系统上进行安装?• 如何获取PDO对象并设置属性?(代码详解)

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网