本文实例讲述了php+sqlite数据库操作的方法。分享给大家供大家参考,具体如下:
sqlite是一款轻型的数据库,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非 常的低,在嵌入式设备中,可能只需要几百k的内存就够了。它能够支持windows/linux/unix等等主流的操作系统,同时能够跟很多程序语言相 结合,比如tcl、php、java等,还有odbc接口,同样比起mysql、postgresql这两款开源世界著名的数据库管理系统来讲,它的处理 速度比他们都快。
php 5开始不再默认支持mysql,而是默认支持sqlite,可见它的影响力多么大,所以如果你想做sqlite的php开发,建议你使用php 5.0.0以上版本。
下面是使用sqlite的一个示例
首先可以在目录下新建一个upload.db的空文件
define("ln", __line__);//行号
define("fl", __file__);//当前文件
define("debug", 0);//调试开关
$db_name = "upload.db";
//创建数据库文件,文件内容为空
if (!file_exists($db_name)) {
if (!($fp = fopen($db_name, "w+"))) {
exit(error_code(-1, ln));
}
fclose($fp);
}
//打开数据库文件
if (!($db = sqlite_open($db_name))) {
exit(error_code(-2, ln));
}
//产生数据表结构
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));
}
//插入一条数据
if (!sqlite_query($db, " insert into uploads (file_name, make_time) values ('upload/111.data','".time()."') ")) {
exit(error_code(-4, ln));
}
//把数据检索出来
if (!($result = sqlite_query($db, "select * from uploads"))) {
exit(error_code(-5, ln));
}
//获取检索数据并显示
while ($array = sqlite_fetch_array($result)) {
echo "id: ". $array[file_name] ."
: ". $array[make_time] ;
}
/* 错误信息代码函数 */
function error_code($code, $line_num, $debug=debug)
{
if ($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 = "[ error ]
file: ". basename(fl) ."
line: ". ln ."
mesg: ". $errmsg ."";
if (!$debug) {
($m = $errmsg);
}
return $m;
}
?>
希望本文所述对大家php程序设计有所帮助。
希望与广大网友互动??
点此进行留言吧!