(PHP 5, PECL sqlite >= 1.0.0)
sqlite_fetch_all -- SQLiteResult->fetchAll -- SQLiteUnbuffered->fetchAll — Sonuç kümesindeki tüm satırları bir satır dizileri dizisi olarak döndürür
Nesne yönelimli kullanım
sonuç tanıtıcısı ile belirtilen sonuç kümesindeki tüm satırları bir satır dizileri dizisi olarak döndürür. sqlite_query() (veya sqlite_unbuffered_query()) işlevinin ardından sonuç kümesindeki her satır için sqlite_fetch_array() işlevini çağırmaya eşdeğerdir.
SQLite sonuç özkaynağı. Nesne yönelimli kullanımda bu değiştirgeye gerek yoktur.
İsteğe bağlı bu değiştirgede döndürülen dizinin nasıl oluşturulacağını belirleyen bir sabit belirtilir. SQLITE_ASSOC belirtilirse alanların isimleri indis olarak kullanılır. SQLITE_NUM belirtilirse alanların sıra numaraları indis olarak kullanılır. SQLITE_BOTH için ise hem isimli hem de sayısal indisli bir dizi döner. SQLITE_BOTH bu işlev için öntanımlı değerdir.
TRUE belirtildiği takdirde (öntanımlıdır), veriye sqlite_escape_string() işleviyle ikil kodlama uygulanmışsa PHP bunu çözer. SQLite ile işlem yapan başka uygulamalarca oluşturulmuş veritabanları için bir takım ara işlemler yapmıyorsanız, normal olarak bu değeri öntanımlı haliyle bırakmanız gerekir.
Sonuç kümesindeki tüm satırları bir satır dizileri dizisi olarak döndürür. sqlite_query() işlevinin hemen ardından çağrılırsa tüm satırları döndürür. sqlite_fetch_array(), işlevinden sonra çağrılırsa kalanları döndürür. Sonuç kümesinde hiç satır yoksa boş bir dizi döner.
SQLITE_ASSOC ve SQLITE_BOTH sabitleri kullanılarak döndürülen sütun isimlerinin harf büyüklükleri sqlite.assoc_case php.ini yapılandırma yönergesinin değerine uygun olarak döndürülür.
Örnek 1 - Yordamsal kullanım örneği
<?php
$dbhandle = sqlite_open('sqlitedb');
$query = sqlite_query($dbhandle, 'SELECT name, email FROM users LIMIT 25');
$result = sqlite_fetch_all($query, SQLITE_ASSOC);
foreach ($result as $entry) {
echo 'İsim: ' . $entry['name'] . ' Eposta: ' . $entry['email'];
}
?>
Örnek 2 - Nesne yönelimli kullanım örneği
<?php
$dbhandle = new SQLiteDatabase('sqlitedb');
// Tamponlu sonuç kümesi
$query = $dbhandle->query('SELECT name, email FROM users LIMIT 25');
// Tamponsuz sonuç kümesi
$query = $dbhandle->unbufferedQuery('SELECT name, email FROM users LIMIT 25');
$result = $query->fetchAll(SQLITE_ASSOC);
foreach ($result as $entry) {
echo 'İsim: ' . $entry['name'] . ' Eposta: ' . $entry['email'];
}
?>