>  기사  >  데이터 베이스  >  PDO에서 결과 세트 가져오기

PDO에서 결과 세트 가져오기

黄舟
黄舟원래의
2017-02-25 10:35:171420검색

fetch() 메서드

fetch() 메서드는 결과 집합의 다음 행을 가져오는 데 사용됩니다. 구문은 다음과 같습니다.

mixed PDOStatement::fetch([int fetch_style][,int cursor_orientation[,int cursor_offset]]])

매개변수 fetch_style은 결과 집합의 반환 방법을 제어합니다.

PDO::FETCH_ASSOC - 연관 배열 form
PDO::FETCH_NUM -- 숫자 인덱스 배열 형식
PDO::FETCH_BOTH -- 두 배열 형식을 모두 사용할 수 있으며 이것이 기본값입니다.
PDO:: FETCH_OBJ -- 이전 mysql_fetch_object()

PDO::FETCH_BOUND와 유사한 객체 형식--결과를 Boolean 값 형태로 변환하고, 얻은 컬럼 값을 할당합니다. 지정된 변수를 지정된 변수를 BindParam() 메소드에 제공합니다.

PDO::FETCH_LAZY--연관 배열, 숫자 인덱스 배열 및 객체의 3가지 형식으로 결과를 반환합니다.

cursor_orientation: PDOStatement 지정된 행을 검색하는 데 사용할 수 있는 객체의 스크롤 커서입니다.

cursor_offset: 커서의 오프셋

예:

PDO에서 준비된 문을 통해 준비 () 및 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[&#39;id&#39;]." ".$result[&#39;username&#39;]." ".$result[&#39;password&#39;].&#39;<br>&#39;;
    }
}catch(Exception $e){
die("Error!:".$e->getMessage().&#39;<br>&#39;);
}

실행 결과는 다음과 같습니다.

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=&#39;mysql&#39;;//数据库类型
$dbName=&#39;admin&#39;;//使用的数据库
$user=&#39;root&#39;;//数据库连接用户名
$pwd=&#39;password&#39;;//数据库连接密码
$host=&#39;localhost&#39;;//数据库主机名
$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().&#39;<br>&#39;);
}


运行结果为:

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[&#39;username&#39;].&#39;<br>&#39;;
}

运行结果为:

107lab
admin
admin

fetchColumn()方法

fetchColumn()方法获取结果集中下一行指定列的值,语法如下:

string PDOStatement::fetchColumn([int column_number])

可选参数column_number设置行中列的索引值,该值从0开始。如果省略该参数则将从第1列开始取值

例如:

通过fetchColumn()方法获取结果集中下一行中指定列的值。(或第一列id的值)

$dbms=&#39;mysql&#39;;//数据库类型
$dbName=&#39;admin&#39;;//使用的数据库
$user=&#39;root&#39;;//数据库连接用户名
$pwd=&#39;password&#39;;//数据库连接密码
$host=&#39;localhost&#39;;//数据库主机名
$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).&#39;<br>&#39;;
    echo $res->fetchColumn(0).&#39;<br>&#39;;
    echo $res->fetchColumn(0).&#39;<br>&#39;;
}catch(Exception $e){
    die("Error!:".$e->getMessage().&#39;<br>&#39;);
}


运行结果为:

1
4
5


 以上就是PDO中获取结果集的内容,更多相关内容请关注PHP中文网(www.php.cn)!


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
이전 기사:PDO에서 SQL 문 실행다음 기사:PDO에서 SQL 문 실행