• PDO中获取结果集


    fetch()方法
    fetch()方法用于获取结果集的下一行。语法例如以下:
    mixed PDOStatement::fetch([int fetch_style][,int cursor_orientation[,int cursor_offset]]])
    參数fetch_style控制结果集的返回方式
    PDO::FETCH_ASSOC -- 关联数组形式
    PDO::FETCH_NUM -- 数字索引数组形式
    PDO::FETCH_BOTH -- 两者数组形式都有。这是缺省的
    PDO::FETCH_OBJ -- 依照对象的形式。相似于曾经的 mysql_fetch_object()
    PDO::FETCH_BOUND--以布尔值的形式返回结果,同一时候获取的列值赋给bindParam()方法中的指定变量。
    PDO::FETCH_LAZY--以关联数组、数字索引数组和对象3种形式返回结果

    cursor_orientation:PDOStatement对象的一个滚动游标,可用于获取指定的一行。
    cursor_offset: 游标的偏移量

    比如:
    在PDO中通过预处理语句prepare()和execute()执行SQL查询语句。而且应用while()语句和fetch()方法完毕数据的循环输出


    $dbms='mysql';//数据库类型
    $dbName='admin';//使用的数据库
    $user='root';//数据库连接用户名
    $pwd='password';//数据库连接密码
    $host='localhost';//数据库主机名
    $dsn="$dbms:host=$host;port=3306;dbname=$dbName";
    try{
    $pdo=new PDO($dsn,$user,$pwd);//初始化一个PDO对象。就是创建了数据库连接对象$pdo
    $query="select * from user";//须要执行的sql语句
    $res=$pdo->prepare($query);//准备查询语句
    $res->execute();
    while($result=$res->fetch(PDO::FETCH_ASSOC)){
    echo $result['id']." ".$result['username']." ".$result['password'].'<br>';
        }
    }catch(Exception $e){
    die("Error!:".$e->getMessage().'<br>');
    }

    执行结果为:
    1 107lab e10adc3949ba59abbe56e057f20f883e
    4 admin 123456
    5 admin 123456


    fetchAll()方法
    fetchAll()方法用于获取结果集中的全部行,其返回值是一个包括结果集中全部数据的二进制数组。语法例如以下:
    array PDOStatement::fetchAll([int fetch_style[,int column_index]])
    參数说明:
    fetch_style:控制结果集中数据的显示方式。


    column_index: 字段的索引。
    比如:

    $dbms='mysql';//数据库类型
    $dbName='admin';//使用的数据库
    $user='root';//数据库连接用户名
    $pwd='password';//数据库连接密码
    $host='localhost';//数据库主机名
    $dsn="$dbms:host=$host;port=3306;dbname=$dbName";
    try{
    $pdo=new PDO($dsn,$user,$pwd);//初始化一个PDO对象,就是创建了数据库连接对象$pdo
    $query="select * from user";//须要执行的sql语句
    $res=$pdo->prepare($query);//准备查询语句
    $res->execute();
    $result=$res->fetchAll(PDO::FETCH_ASSOC);
    print_r($result);
    }catch(Exception $e){
    die("Error!:".$e->getMessage().'<br>');
    }

    执行结果为:
    Array
    (
        [0] => Array
            (
                [id] => 1
                [username] => 107lab
                [password] => e10adc3949ba59abbe56e057f20f883e
            )
    
        [1] => Array
            (
                [id] => 4
                [username] => admin
                [password] => 123456
            )
    
        [2] => Array
            (
                [id] => 5
                [username] => admin
                [password] => 123456
            )
    
    )
    
    此时能够通过foreach来遍历这个二维数组
    foreach($result as $val){
    echo $val['username'].'<br>';
    }

    执行结果为:
    107lab
    admin
    admin


    fetchColumn()方法
    fetchColumn()方法获取结果集中下一行指定列的值。语法例如以下:
    string PDOStatement::fetchColumn([int column_number])
    可选參数column_number设置行中列的索引值,该值从0開始。假设省略该參数则将从第1列開始取值
    比如:
    通过fetchColumn()方法获取结果集中下一行中指定列的值。(或第一列id的值)
    $dbms='mysql';//数据库类型
    $dbName='admin';//使用的数据库
    $user='root';//数据库连接用户名
    $pwd='password';//数据库连接密码
    $host='localhost';//数据库主机名
    $dsn="$dbms:host=$host;port=3306;dbname=$dbName";
    try{
        $pdo=new PDO($dsn,$user,$pwd);//初始化一个PDO对象,就是创建了数据库连接对象$pdo
        $query="select * from user";//须要执行的sql语句
        $res=$pdo->prepare($query);//准备查询语句
        $res->execute();
        echo $res->fetchColumn(0).'<br>';
        echo $res->fetchColumn(0).'<br>';
        echo $res->fetchColumn(0).'<br>';
    }catch(Exception $e){
        die("Error!:".$e->getMessage().'<br>');
    }

    执行结果为:
    1
    4
    5



  • 相关阅读:
    扇入扇出的概念
    ISE Simulator综合后仿真 How do you run Post Synthesis Simulation in ISE Project Navigator?
    通信相关经典书籍
    the advantages of using SRL16 to make large delay
    Illegal redeclaration of module <glbl>.&Element index 2 into memp is out of bounds
    双口RAM
    twisted综述和reactor概述
    python os模块
    Twisted简单安装和rpc简单使用示例
    select, poll和epoll的区别
  • 原文地址:https://www.cnblogs.com/zhchoutai/p/8325245.html
Copyright © 2020-2023  润新知