這篇文章主要介紹了php使用pdo串連sqlite3的配置方法,結合執行個體形式較為詳細的分析了php基於pdo操作sqlite3的相關注意事項,需要的朋友可以參考下
剛剛開始使用php+sqlite 的時候,一直以為自己使用的是sqlite3 ,其實不是,php從php5 >=5.3.0 的時候才開始預設支援sqlite3
可參照官方文檔http://www.php.net/manual/zh/sqlite3.open.php
預設的方法介面:
public void SQLite3::open ( string $filename [, int $flags = SQLITE3_OPEN_READWRITE | SQLITE3_OPEN_CREATE [, string $encryption_key ]] )
利用PHP操作資料庫時發現PHP預設只支援到Sqlite2,不支援最新版的Sqlite3。如果想支援Sqlite3就要使用PDO。要想使用PDO,需要在php.ini裡面載入php_pdo.dll和php_pdo_sqlite.dll兩個模組。如下:
extension=php_pdo.dllextension=php_pdo_sqlite.dll
如果沒有使用pdo ,即使你開啟了上面的參數,其實還是使用sqlite2 的,不信你訪問看一下產生的資料庫在檔案的開頭是不是提示:
** This file contains an SQLite 2.1 database **
當php環境沒有開啟上面支援的配置時將報如下錯誤:
Fatal error: Call to undefined function sqlite_open()
sqlite3樣本:
<html><?php//$dsn = 'sqlite:sql.db';try{//$dbh = new PDO($dsn, $user, $password); //建立串連// $dbh = new PDO('sqlite:yourdatabase.db');$dbh = new PDO('sqlite:itlife365.com');echo 'Create Db ok' ;//建表$dbh->exec("CREATE TABLE itlife365(id integer,name varchar(255))");echo 'Create Table itlife365 ok<BR>';$dbh->exec("INSERT INTO itlife365 values(1,'itlife365.com')");echo 'Insert Data ok<BR>';$dbh->beginTransaction();$sth = $dbh->prepare('SELECT * FROM itlife365');$sth->execute();//擷取結果$result = $sth->fetchAll();print_r($result);$dsn=null;}catch (PDOException $e){echo 'Connection failed: ' . $e->getMessage();$dsn = null;}?></html><?php $dbh = null;//或使用unset($dbh); ?>
驗證:查看資料庫:
在檔案頭顯示:
SQLite format 3***
總結:以上就是本篇文的全部內容,希望能對大家的學習有所協助。