PHP 7 SQLite:如何用PHP 7訪問SQLite數據庫?
隨著網站和Web應用程序的不斷增長,我們對數據的需求也越來越大。而本文將介紹如何使用PHP 7內置的SQLite擴展來訪問SQLite數據庫以存儲和查詢數據。SQLite是一個輕量級、本地存儲的數據庫,它易于使用、處理和訪問,同時也支持ACID事務和SQL查詢。
在PHP 7中,您可以使用SQLite3類來訪問SQLite數據庫。下面的代碼演示了如何打開一個SQLite數據庫:
// 假設一個名為 test.db 的SQLite數據庫文件已經存在 $db = new SQLite3('test.db');
必須使用SQLite3類的構造函數來創建SQLite3對象。構造函數的參數是SQLite數據庫文件的名稱。如果該文件不存在,則將創建一個新的數據庫。
在打開SQLite數據庫之后,可以使用SQLite3類的exec()方法執行SQL語句。例如,下面的代碼將創建名為“users”的表:
$db->exec('CREATE TABLE users(id INTEGER PRIMARY KEY, name TEXT, email TEXT)');
exec()方法將SQL查詢作為參數,并返回受影響的行數。在上面的代碼中,我們使用CREATE TABLE語句創建了一個新的表,其中包含三個列:id、name和email。id列是主鍵,name和email列都是文本列。
接下來,我們可以使用SQLite3類的prepare()方法來準備SQL查詢,并使用bindValue()方法綁定查詢參數。例如,下面的代碼將插入一行數據到users表中:
$stmt = $db->prepare('INSERT INTO users(name, email) VALUES(:name, :email)'); $stmt->bindValue(':name', 'John Doe'); $stmt->bindValue(':email', 'john@example.com'); $stmt->execute();
prepare()方法將SQL查詢作為參數,并返回一個SQLite3Stmt對象。bindValue()方法用于綁定查詢參數,其中第一個參數是查詢參數的名稱,第二個參數是查詢參數的值。最后,我們使用execute()方法執行該查詢。
一旦數據已插入,我們可以使用SQLite3類的query()方法來查詢數據。例如,下面的代碼將查詢users表中的所有數據,并將其輸出到屏幕上:
$results = $db->query('SELECT * FROM users'); while ($row = $results->fetchArray()) { echo $row['id'] . ': ' . $row['name'] . ' (' . $row['email'] . ')' . '
'; }
query()方法將SQL查詢作為參數,并返回一個SQLite3Result對象。使用fetchArray()方法可逐行檢索結果集中的數據。在上面的代碼中,我們將id、name和email列的值輸出到屏幕上。
最后,我們可以使用SQLite3類的close()方法關閉數據庫連接:
$db->close();
在上面的代碼中,我們使用close()方法關閉與SQLite數據庫的連接。
結論
SQLite是一種靈活、易于使用、可嵌入的輕量級數據庫,適用于很多類型的應用程序。在PHP 7中,您可以使用SQLite3類來訪問SQLite數據庫。本文提供了一些用于處理SQLite數據庫的基本PHP 7代碼示例。您可以使用這些代碼作為參考來開始使用PHP 7和SQLite。