PHP+sqlite數(shù)據(jù)庫(kù)操作示例(創(chuàng)建/打開/插入/檢索)
本文實(shí)例講述了PHP+sqlite數(shù)據(jù)庫(kù)操作的方法。分享給大家供大家參考,具體如下:
SQLite是一款輕型的數(shù)據(jù)庫(kù),它的設(shè)計(jì)目標(biāo)是嵌入式的,而且目前已經(jīng)在很多嵌入式產(chǎn)品中使用了它,它占用資源非 常的低,在嵌入式設(shè)備中,可能只需要幾百K的內(nèi)存就夠了。它能夠支持Windows/Linux/Unix等等主流的操作系統(tǒng),同時(shí)能夠跟很多程序語言相 結(jié)合,比如Tcl、PHP、Java等,還有ODBC接口,同樣比起MySQL、PostgreSQL這兩款開源世界著名的數(shù)據(jù)庫(kù)管理系統(tǒng)來講,它的處理 速度比他們都快。
PHP 5開始不再默認(rèn)支持Mysql,而是默認(rèn)支持SQLite,可見它的影響力多么大,所以如果你想做SQLite的PHP開發(fā),建議你使用PHP 5.0.0以上版本。
下面是使用sqlite的一個(gè)示例
首先可以在目錄下新建一個(gè)upload.db的空文件
<?php
define("LN", __LINE__);//行號(hào)
define("FL", __FILE__);//當(dāng)前文件
define("DEBUG", 0);//調(diào)試開關(guān)
$db_name = "upload.db";
//創(chuàng)建數(shù)據(jù)庫(kù)文件,文件內(nèi)容為空
if (!file_exists($db_name)) {
if (!($fp = fopen($db_name, "w+"))) {
exit(error_code(-1, LN));
}
fclose($fp);
}
//打開數(shù)據(jù)庫(kù)文件
if (!($db = sqlite_open($db_name))) {
exit(error_code(-2, LN));
}
//產(chǎn)生數(shù)據(jù)表結(jié)構(gòu)
if (!sqlite_query($db, "DROP TABLE uploads")) {
exit(error_code(-3, LN));
}
if (!sqlite_query($db, "CREATE TABLE uploads (id integer primary key, file_name varchar(200) UNIQUE, make_time integer)")) {
exit(error_code(-3, LN));
}
//插入一條數(shù)據(jù)
if (!sqlite_query($db, " INSERT INTO uploads (file_name, make_time) VALUES ('upload/111.data','".time()."') ")) {
exit(error_code(-4, LN));
}
//把數(shù)據(jù)檢索出來
if (!($result = sqlite_query($db, "SELECT * FROM uploads"))) {
exit(error_code(-5, LN));
}
//獲取檢索數(shù)據(jù)并顯示
while ($array = sqlite_fetch_array($result)) {
echo "ID: ". $array[file_name] ."<br>: ". $array[make_time] ;
}
/* 錯(cuò)誤信息代碼函數(shù) */
function error_code($code, $line_num, $debug=DEBUG)
{
if ($code<-6 || $code>-1) {
return false;
}
switch($code) {
case -1: $errmsg = "Create database file error.";
break;
case -2: $errmsg = "Open sqlite database file failed.";
break;
case -3: $errmsg = "Create table failed, table already exist.";
break;
case -4: $errmsg = "Insert data failed.";
break;
case -5: $errmsg = "Query database data failed.";
break;
case -6: $errmsg = "Fetch data failed.";
break;
case -7: $errmsg = "";
break;
default: $errmsg = "Unknown error.";
}
$m = "<b>[ Error ]</b><br>File: ". basename(FL) ." <br>Line: ". LN ."<br>Mesg: ". $errmsg ."";
if (!$debug) {
($m = $errmsg);
}
return $m;
}
?>
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP基于pdo操作數(shù)據(jù)庫(kù)技巧總結(jié)》、《PHP+MongoDB數(shù)據(jù)庫(kù)操作技巧大全》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
- DJango的創(chuàng)建和使用詳解(默認(rèn)數(shù)據(jù)庫(kù)sqlite3)
- Python操作SQLite數(shù)據(jù)庫(kù)的方法詳解【導(dǎo)入,創(chuàng)建,游標(biāo),增刪改查等】
- swift3.0 創(chuàng)建sqlite數(shù)據(jù)庫(kù)步驟方法
- C#操作SQLite數(shù)據(jù)庫(kù)方法小結(jié)(創(chuàng)建,連接,插入,查詢,刪除等)
- Android創(chuàng)建和使用數(shù)據(jù)庫(kù)SQLIte
- android創(chuàng)建數(shù)據(jù)庫(kù)(SQLite)保存圖片示例
- SQLite 創(chuàng)建數(shù)據(jù)庫(kù)實(shí)例操作
相關(guān)文章
PHP設(shè)計(jì)模式之建造者模式定義與用法簡(jiǎn)單示例
這篇文章主要介紹了PHP設(shè)計(jì)模式之建造者模式定義與用法,簡(jiǎn)單描述了建造者模式的概念、原理并結(jié)合實(shí)例形式分析了建造者模式的具體定義與使用方法,需要的朋友可以參考下2018-08-08
php阿拉伯?dāng)?shù)字轉(zhuǎn)中文人民幣大寫
這篇文章主要介紹了php阿拉伯?dāng)?shù)字轉(zhuǎn)中文大寫金額,分享了兩種實(shí)現(xiàn)方法,感興趣的小伙伴們可以參考一下2015-12-12
PHP對(duì)文件夾遞歸執(zhí)行chmod命令的方法
這篇文章主要介紹了PHP對(duì)文件夾遞歸執(zhí)行chmod命令的方法,可實(shí)現(xiàn)遞歸執(zhí)行chmod命令改變文件夾執(zhí)行權(quán)限的功能,需要的朋友可以參考下2015-06-06
php下的原生ajax請(qǐng)求用法實(shí)例分析
這篇文章主要介紹了php下的原生ajax請(qǐng)求用法,結(jié)合實(shí)例形式分析了前臺(tái)原生ajax請(qǐng)求與后臺(tái)PHP響應(yīng)相關(guān)操作技巧,需要的朋友可以參考下2020-02-02
利用PHP判斷是手機(jī)移動(dòng)端還是PC端訪問的函數(shù)示例
在平常工作開發(fā)中,我們通常需要開發(fā)出PC端和移動(dòng)端兩個(gè)不同的系統(tǒng),從而根據(jù)訪問端的不同進(jìn)入到不同的操作界面中。下面這篇文章主要給大家介紹了關(guān)于利用PHP判斷是手機(jī)移動(dòng)端還是PC端訪問的函數(shù)的相關(guān)資料,需要的朋友可以參考下。2017-12-12
關(guān)于WordPress的SEO優(yōu)化相關(guān)的一些PHP頁面腳本技巧
這篇文章主要介紹了關(guān)于WordPress的SEO優(yōu)化相關(guān)的一些PHP頁面腳本技巧,包括區(qū)分顯示頁面標(biāo)題和關(guān)鍵字等,需要的朋友可以參考下2015-12-12

