PDO::query

(PHP 5 >= 5.1.0, PHP 7, PHP 8, PECL pdo >= 0.2.0)

PDO::queryBir SQL deyimini çalıştırıp sonucu bir PDOStatement nesnesi olarak döndürür

Açıklama

public PDO::query(string $deyim, int|null $fetch_kipi = null): PDOStatement|false
public PDO::query(string $deyim, int|null $fetch_kipi = PDO::FETCH_COLUMN, int $sütun_num): PDOStatement|false
public PDO::query(
    string $deyim,
    int|null $fetch_kipi = PDO::FETCH_CLASS,
    string $sınıf_adı,
    array $kurucu_değiştirgeleri
): PDOStatement|false
public PDO::query(string $deyim, int|null $fetch_kipi = PDO::FETCH_INTO, object $nesne): PDOStatement|false

Bir SQL deyimini tek bir işlev çağrısında çalıştırır ve sorgu sonucunu (bir sonuç varsa) bir PDOStatement nesnesi olarak döndürür.

Defalarca yineleyeceğiniz bir sorguyu PDO::prepare() yöntemini kullanarak bir PDOStatement nesnesi haline getirip bunu PDOStatement::execute() ile defalarca çalıştırmak başarımı arttıracaktır.

Tekrar bir PDO::query() çağrısı yapmadan önce sonuç kümesindeki veriyi almazsanız çağrınız başarısızlıkla sonuçlanabilir. Yeni bir PDO::query() çağrısını yapmadan önce PDOStatement nesnesi ile ilişkilendirilmiş kaynakları serbest bırakmak için PDOStatement::closeCursor() çağrısı yapmalısınız.

Bilginize:

İşleve fazladan değiştirge aktarılırsa, bunlar sonuç nesnesi üzerinde PDOStatement::setFetchMode() çağrısı yapılmış gibi ele alınır.

Değiştirgeler

deyim

Hazırlanacak ve çalıştırılacak SQL deyimi.

Sorguda kullanılacak verilerin düzgün olarak öncelenmesi gerekir.

Dönen Değerler

Başarısızlık durumunda false, aksi takdirde bir PDOStatement nesnesi.

Örnekler

Örnek 1 - PDO::query() örneği

PDO::query() yönteminin tek özelliği başarıyla çalıştırılmış bir SELECT deyiminden dönen sonuç kümesi üzerinde satır satır verilere erişilebilmesini mümkün kılmasıdır.

<?php
$sql 
'SELECT name, color, calories FROM fruit ORDER BY name';
foreach (
$conn->query($sql) as $row) {
    print 
$row['name'] . "\t";
    print 
$row['color'] . "\t";
    print 
$row['calories'] . "\n";
}
?>

Yukarıdaki örneğin çıktısı:

apple   red     150
banana  yellow  250
kiwi    brown   75
lemon   yellow  25
orange  orange  300
pear    green   150
watermelon      pink    90

Ayrıca Bakınız

  • PDO::exec() - Belirtilen SQL deyimini çalıştırır ve etkilenen satır sayısını döndürür
  • PDO::prepare() - Çalıştırılmak üzere bir deyimi hazırlar ve bir deyim nesnesi olarak döndürür
  • PDOStatement::execute() - Bir hazır deyimi çalıştırır

add a note add a note

User Contributed Notes 7 notes

up
39
fredrik at NOSPAM dot rambris dot com
17 years ago
The handling of errors by this function is controlled by the attribute PDO::ATTR_ERRMODE.

Use the following to make it throw an exception:
<?php
$dbh
->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
?>
up
9
dozoyousan at gmail dot com
18 years ago
> When query() fails, the boolean false is returned.

I think that is "Silent Mode".
If that set attribute ErrorMode "Exception Mode"
then that throw PDOException.
$pdoObj = new PDO( $dsn, $user, $pass );
$pdoObj->setAttribute("PDO::ATTR_ERRMODE", PDO::ERRMODE_EXCEPTION);
up
5
marcos at marcosregis dot com
15 years ago
After a lot of hours working with DataLink on Oracle->MySQL and PDO we (me and Adriano Rodrigues, that solve it) discover that PDO (and oci too) need the attribute AUTOCOMMIT set to FALSE to work correctly with.
There's  3 ways to set autocommit to false: On constructor, setting the atribute after construct and before query data or initiating a Transaction (that turns off autocommit mode)

The examples:
<?php
// First way - On PDO Constructor
$options = array(PDO::ATTR_AUTOCOMMIT=>FALSE);

$pdo = new PDO($dsn,$user,$pass,$options);

// now we are ready to query DataLinks

?>

<?php
// Second Way - Before create statements
$pdo = new PDO($dsn,$user,$pass);

$pdo->setAttribute(PDO::ATTR_AUTOCOMMIT,FALSE);
// or
$pdo->beginTransaction();

// now we are ready to query DataLinks
?>

To use DataLinks on oci just use OCI_DEFAULT on oci_execute() function;
up
0
stefano[dot]bertoli [at] gmail[dot]com
9 years ago
Trying to pass like second argument PDO::FETCH_ASSOC it still work.

So passing FETCH TYPE like argument seems work.

This save you from something like:

<?php
$result
= $stmt->setFetchMode(PDO::FETCH_NUM);
?>

Example:
<?php
$res
= $db->query('SELECT * FROM `mytable` WHERE true', PDO::FETCH_ASSOC);

?>
up
-1
Ilyas Bakirov
3 years ago
I would like to mention fetching rows from SQL query using PDO:

<?php

$dbh
= new PDO('mysql:host=localhost;dbname=test', $user, $pass);

// use the connection here
$sth = $dbh->query('SELECT * FROM countries');

// fetch all rows into array, by default PDO::FETCH_BOTH is used
$rows = $stm->fetchAll();

// iterate over array by index and by name
foreach($rows as $row) {

   
printf("$row[0] $row[1] $row[2]\n");
   
printf("$row['id'] $row['name'] $row['population']\n");

}
?>
up
-20
andrea at bhweb dot it
15 years ago
If someone is suffering of the "MySQL server has gone away" problem after executing multiple queries, this is a solution that solved it for me. It's similar to the one needed for the exact same problem in mysqli.

<?php
$stmt
=$db->prepare($query);
$stmt->execute();
do {
$stmt->fetch(); $stmt->closeCursor(); ++$line; } while($stmt-
>
nextRowset());
?>

I found this only works using prepare and execute this way, not if you
directly execute the query with query().
up
-18
Anonymous
4 years ago
The Documentation doesn’t mention this, but you can use a fetch style as a second parameter. For example:

<?php
    $data
=$pdo->query($sql,PDO::FETCH_NUM);
    foreach(
$data as $row) {
       
//    etc
   
}
?>
To Top