[Editor's note: to get short column names there's an undocumented PRAGMA setting. You can exec "PRAGMA short_column_names = ON" to force that behavior.]
I noticed that if you use Joins in SQL queries, the field name is messed up with the dot!
for example if you have this query:
SELECT n.*, m.nickname FROM news AS n, members AS m WHERE n.memberID = m.id;
now if you want to print_r the results returned using SQLITE_ASSOC type, the result array is like this :
array
(
[n.memberID] => 2
[n.title] => test title
[m.nickname] => NeverMind
[tablename.fieldname] => value
)
and I think it looks horriable to use the variable ,for example, $news['m.nickname'] I just don't like it!
so I've made a small function that will remove the table name (or its Alias) and will return the array after its index is cleaned
<?php
function CleanName($array)
{
foreach ($array as $key => $value) {
//if you want to keep the old element with its key remove the following line
unset($array[$key]);
//now we clean the key from the dot and tablename (alise) and set the new element
$key = substr($key, strpos($key, '.')+1);
$array[$key] = $value;
}
return $array;
}
?>
sqlite_fetch_array
SQLiteResult->fetch
SQLiteUnbuffered->fetch
(PHP 5 < 5.4.0, PECL sqlite >= 1.0.0)
sqlite_fetch_array -- SQLiteResult->fetch -- SQLiteUnbuffered->fetch — Liest die nächste Zeile aus dem Datenbankergebnis und gibt sie als Array zurück
Beschreibung
$result
[, int $result_type = SQLITE_BOTH
[, bool $decode_binary = true
]] )Objektorientierter Stil (Methode):
$result_type = SQLITE_BOTH
[, bool $decode_binary = true
]] )$result_type = SQLITE_BOTH
[, bool $decode_binary = true
]] )
Liest die nächste Zeile von angegebenen
result-Handle. Sind alle Zeilen ausgelesen,
wird FALSE, anderenfalls ein assoziatives Array zurückgegeben, das
die Daten der gelesenen Zeile enthält.
Parameter-Liste
-
result -
Die SQLite-Ergebnisressource. Dieser Parameter wird nicht benötigt, wenn die objektorientierte Notation genutzt wird.
-
result_type -
Der optionale Parameter
Ergebnis_Typakzeptiert eine Konstante und bestimmt, wie das zurückgegebene Array indiziert wird. Während mitSQLITE_ASSOCnur assoziative Indizes (Namensfelder) zurückgegeben werden, werden mitSQLITE_NUMnur numerische Indizes (geordnete Feldnummern) zurückgegeben.SQLITE_BOTHgibt sowohl assoziative als auch numerische Indizes zurück.SQLITE_BOTHist die Standardeinstellung. -
decode_binary -
Falls der Parameter
decode_binaryaufTRUEgesetzt ist (das ist die Standardeinstellung), dekodiert PHP die Binärkodierung, die bei Verwendung von sqlite_escape_string() auf die Daten angewendet wird. Solange Sie die Daten nicht mit anderen SQLite-Fähigen Applikationen teilen, sollten Sie diesen Wert in der Standardeinstellung lassen.
Rückgabewerte
Liefert ein Array der nächsten Zeile des Datenbankerbegnisses oder
FALSE, wenn die Position der nächsten Zeile ausserhalb des
Datenbankergebnisses liegt.
Die Groß- und Kleinschreibung der
Spaltennamen, die von SQLITE_ASSOC und
SQLITE_BOTH zurückgegeben werden, wird entsprechend der
Konfigurationsdirektive sqlite.assoc_case geändert.
Beispiele
Beispiel #1 Beispiel zur prozduralen Notation
<?php
$dbhandle = sqlite_open('sqlitedb');
$query = sqlite_query($dbhandle, 'SELECT name, email FROM users LIMIT 25');
while ($entry = sqlite_fetch_array($query, SQLITE_ASSOC)) {
echo 'Name: ' . $entry['name'] . ' E-mail: ' . $entry['email'];
}
?>
Beispiel #2 Beispiel zur objektorientierten Notation
<?php
$dbhandle = new SQLiteDatabase('sqlitedb');
$query = $dbhandle->query('SELECT name, email FROM users LIMIT 25'); // gepuffertes Datenbankergebnis
$query = $dbhandle->unbufferedQuery('SELECT name, email FROM users LIMIT 25'); // ungepuffertes Datenbankergebnis
while ($entry = $query->fetch(SQLITE_ASSOC)) {
echo 'Name: ' . $entry['name'] . ' E-mail: ' . $entry['email'];
}
?>
Siehe auch
- sqlite_array_query() - Führt eine Datenbankabfrage durch und liefert das gesamte Abfrageergebnis als Liste zurück
- sqlite_fetch_string() - Alias von sqlite_fetch_single
