最新消息:愿得一人心,白首不分离。

PHP对SqlLite数据表相关操作

学习笔记 轮回的落日℡ 187浏览 0评论

PHP操作SqlLite数据表相关函数

前言

自PHP 5.3.0起默认启用 SQLite3 扩展,我们也可以在编译时使用 --without-sqlite3 禁用 SQLite3 扩展,Windows用户必须启用php_sqlite3.dll才能使用该扩展,同样,自PHP 5.3.0起,这个DLL被包含在PHP的Windows分发版中,我们来看下PHP中可以操作sqlite3的一些API,如下:

  1. public void SQLite3::open ( filename, flags, encryption_key )
    打开一个 SQLite 3 数据库。如果构建包括加密,那么它将尝试使用的密钥。
    如果文件名 filename 赋值为 ':memory:',那么 SQLite3::open() 将会在 RAM 中创建一个内存数据库,这只会在 session 的有效时间内持续。
    如果文件名 filename 为实际的设备文件名称,那么 SQLite3::open() 将使用这个参数值尝试打开数据库文件。如果该名称的文件不存在,那么将创建一个新的命名为该名称的数据库文件。
    可选的 flags 用于判断是否打开 SQLite 数据库。默认情况下,当使用 SQLITE3_OPEN_READWRITE | SQLITE3_OPEN_CREATE 时打开。
  2. public bool SQLite3::exec ( string $query )
    该例程提供了一个执行 SQL 命令的快捷方式,SQL 命令由 sql 参数提供,可以由多个 SQL 命令组成。该程序用于对给定的数据库执行一个无结果的查询。
  3. public SQLite3Result SQLite3::query ( string $query )
    该例程执行一个 SQL 查询,如果查询到返回结果则返回一个 SQLite3Result 对象。
  4. public int SQLite3::lastErrorCode ( void )
    该例程返回最近一次失败的 SQLite 请求的数值结果代码。
  5. public string SQLite3::lastErrorMsg ( void )
    该例程返回最近一次失败的 SQLite 请求的英语文本描述。
  6. public int SQLite3::changes ( void )
    该例程返回最近一次的 SQL 语句更新或插入或删除的数据库行数。
  7. public bool SQLite3::close ( void )
    该例程关闭之前调用 SQLite3::open() 打开的数据库连接。
  8. public string SQLite3::escapeString ( string $value )
    该例程返回一个字符串,在 SQL 语句中,出于安全考虑,该字符串已被正确地转义。

一、PHP连接SQLite数据库

使用PHP连接到一个现有的数据库,如果数据库不存在,那么它就会被创建,最后将返回一个数据库对象,如下:

<?php
   class MyDB extends SQLite3
   {
      function __construct()
      {
         $this->open('test.db');
      }
   }
   $db = new MyDB();
   if(!$db){
      echo $db->lastErrorMsg();
   } else {
      echo "Opened database successfully\n";
   }

二、在SQLite数据库创建一个表

先前创建的数据库中创建一个表,如下:

<?php
   class MyDB extends SQLite3
   {
      function __construct()
      {
         $this->open('test.db');
      }
   }
   $db = new MyDB();
   if(!$db){
      echo $db->lastErrorMsg();
   } else {
      echo "Opened database successfully\n";
   }
 
   $sql =<<<EOF
      CREATE TABLE COMPANY
      (ID INT PRIMARY KEY     NOT NULL,
      NAME           TEXT    NOT NULL,
      AGE            INT     NOT NULL,
      ADDRESS        CHAR(50),
      SALARY         REAL);
EOF;
 
   $ret = $db->exec($sql);
   if(!$ret){
      echo $db->lastErrorMsg();
   } else {
      echo "Table created successfully\n";
   }
   $db->close();
?>

三、在SQLite数据库写入数据 INSERT

在上述建好的数据表中写入一些数据,如下:

<?php
   class MyDB extends SQLite3
   {
      function __construct()
      {
         $this->open('test.db');
      }
   }
   $db = new MyDB();
   if(!$db){
      echo $db->lastErrorMsg();
   } else {
      echo "Opened database successfully\n";
   }
 
   $sql =<<<EOF
      INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
      VALUES (1, 'Paul', 32, 'California', 20000.00 );
      INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
      VALUES (2, 'Allen', 25, 'Texas', 15000.00 );
      INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
      VALUES (3, 'Teddy', 23, 'Norway', 20000.00 );
      INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
      VALUES (4, 'Mark', 25, 'Rich-Mond ', 65000.00 );
EOF;
 
   $ret = $db->exec($sql);
   if(!$ret){
      echo $db->lastErrorMsg();
   } else {
      echo "Records created successfully\n";
   }
   $db->close();
?>

四、查询在SQLite数据库写入的数据 SELECT

<?php
   class MyDB extends SQLite3
   {
      function __construct()
      {
         $this->open('test.db');
      }
   }
   $db = new MyDB();
   if(!$db){
      echo $db->lastErrorMsg();
   } else {
      echo "Opened database successfully\n";
   }
 
   $sql =<<<EOF
      SELECT * from COMPANY;
EOF;
 
   $ret = $db->query($sql);
   while($row = $ret->fetchArray(SQLITE3_ASSOC) ){
      echo "ID = ". $row['ID'] . "\n";
      echo "NAME = ". $row['NAME'] ."\n";
      echo "ADDRESS = ". $row['ADDRESS'] ."\n";
      echo "SALARY =  ".$row['SALARY'] ."\n\n";
   }
   echo "Operation done successfully\n";
   $db->close();
?>

五、更新在SQLite数据库写入的数据 UPDATE

<?php
   class MyDB extends SQLite3
   {
      function __construct()
      {
         $this->open('test.db');
      }
   }
   $db = new MyDB();
   if(!$db){
      echo $db->lastErrorMsg();
   } else {
      echo "Opened database successfully\n";
   }
   $sql =<<<EOF
      UPDATE COMPANY set SALARY = 25000.00 where ID=1;
EOF;
   $ret = $db->exec($sql);
   if(!$ret){
      echo $db->lastErrorMsg();
   } else {
      echo $db->changes(), " Record updated successfully\n";
   }
 
   $sql =<<<EOF
      SELECT * from COMPANY;
EOF;
   $ret = $db->query($sql);
   while($row = $ret->fetchArray(SQLITE3_ASSOC) ){
      echo "ID = ". $row['ID'] . "\n";
      echo "NAME = ". $row['NAME'] ."\n";
      echo "ADDRESS = ". $row['ADDRESS'] ."\n";
      echo "SALARY =  ".$row['SALARY'] ."\n\n";
   }
   echo "Operation done successfully\n";
   $db->close();
?>

六、删除在SQLite数据库写入的数据 DELETE

<?php
   class MyDB extends SQLite3
   {
      function __construct()
      {
         $this->open('test.db');
      }
   }
   $db = new MyDB();
   if(!$db){
      echo $db->lastErrorMsg();
   } else {
      echo "Opened database successfully\n";
   }
   $sql =<<<EOF
      DELETE from COMPANY where ID=2;
EOF;
   $ret = $db->exec($sql);
   if(!$ret){
     echo $db->lastErrorMsg();
   } else {
      echo $db->changes(), " Record deleted successfully\n";
   }
 
   $sql =<<<EOF
      SELECT * from COMPANY;
EOF;
   $ret = $db->query($sql);
   while($row = $ret->fetchArray(SQLITE3_ASSOC) ){
      echo "ID = ". $row['ID'] . "\n";
      echo "NAME = ". $row['NAME'] ."\n";
      echo "ADDRESS = ". $row['ADDRESS'] ."\n";
      echo "SALARY =  ".$row['SALARY'] ."\n\n";
   }
   echo "Operation done successfully\n";
   $db->close();
?>

其他:PHP创建SqlLite数据表并让ID自增

<?php
class MyDB extends SQLite3
{
  function __construct()
  {
	 $this->open('test.db');
  }
}
$db = new MyDB();
if(!$db){
  echo $db->lastErrorMsg();
} else {
  echo "Opened database successfully\n";
}
 
/**
* 创建数据库
*/
$sql =<<<EOF
  CREATE TABLE test2(
	id            integer PRIMARY KEY autoincrement,
	NAME           TEXT    NOT NULL,
	AGE            INT     NOT NULL,
	ADDRESS        CHAR(50),
	SALARY         REAL
);
EOF;
$ret = $db->exec($sql);
if(!$ret){
  echo $db->lastErrorMsg();
} else {
  echo "Table created successfully\n";
}
$db->close();
 
 
/**
*数据入库
*/
$sql =<<<EOF
      INSERT INTO test2 (NAME,AGE,ADDRESS,SALARY)
      VALUES ('Paul', 32, 'California', 20000.00 );
EOF;
$ret = $db->exec($sql);
if(!$ret){
  echo $db->lastErrorMsg();
} else {
  echo "Records created successfully\n";
}
$db->close();

其他:PHP SqlLite 类

<?php
/*
注意细节:实例化对象时传入的是数据库的路径,要是数据库不存在的话会自动创建。
*/
class sqlLite extends SQLite3{
	
	/**
	 * 数据库路径设置
	 */
	public $url;
 
	/**
	 * SqlLite 创建数据库
	 */
	function __construct($url)
	{
		$this->url=$url;
		$this->open($url);
	}
 
	function check_input($value)
	{
		if (get_magic_quotes_gpc()) {
  			$value = sqlite_escape_string($value);
		}
		return $value;
	}
	
	/**
	 * SqlLite 创建数据库
	 *
	 * create("test", 
	 *		array("id"=>"integer PRIMARY KEY autoincrement", 
	 *			"name"=>"VARCHAR(50)", 
	 *			"age"=>"INT  NOT NULL",
	 *			"article"=>"TEXT    NOT NULL")
	 *	);
	 *
	 *	$name Array 请传递数组
	 *	$type String 请传递|分割的字符串
	 */
	function create($table,$name,$type=null)
	{
		$sql = 'CREATE TABLE '.$table.'(';
		if($type==null){
			$arrname = array_keys($name);
			$arrtype = array_values($name);
		}else{
			$arrname = explode("|", $name);
			$arrtype = explode("|", $type);
		}
		for($i=0;$i<count($arrname);$i++){
			if($i==count($arrname)-1){
				$sql = $sql.$arrname[$i]."   ".$arrtype[$i]."";
			}else{
				$sql = $sql.$arrname[$i]."   ".$arrtype[$i].",";
			}
			
		}
		$sql = $sql.');';
		$re = $this->query($sql);
		if($re){
			return true;
		}else{
			return false;
		}
	}
 
	/**
	 * SqlLite 删除数据库
	 *
	 * $table 表名
	 */
	function drop($table)
	{
		$sql = 'DROP TABLE '.$table.';';
		$re = $this->query($sql);
		if($re){
			return true;
		}else{
			return false;
		}
	}
 
	/**
	 * SqlLite 插入数据
	 */
	function insert($table,$name,$value=null)
	{
		$sql = "INSERT INTO ".$table.'(';
		if($value == null){
		$arrname = array_keys($name);
		$arrvalue = array_values($name);
		}else{
		$arrname = explode('|', $name);
		$arrvalue = explode('|', $value);
		}
		for($i=0;$i<count($arrname);$i++){
			if($i==count($arrname)-1){
				$sql = $sql.$arrname[$i];
			}else{
				$sql = $sql.$arrname[$i].",";
			}
		}
		$sql = $sql.")VALUES(";
		for($i=0;$i<count($arrvalue);$i++){
			if($i==count($arrvalue)-1){
				$sql = $sql."'".$arrvalue[$i]."'";
			}else{
				$sql = $sql."'".$arrvalue[$i]."',";
			}
		}
		$sql .=");";
		$re = $this->query($sql);
		if($re){
			return true;
		}else{
			return false;
		}
	}
 
	/**
	 * SqlLite 删除数据
	 */
	function delete($table,$Conditionsname,$Conditionsvalue=null)
	{
		if($Conditionsvalue!=null){
			$sql = "DELETE FROM ".$table." WHERE ".$Conditionsname."='".$Conditionsvalue."';";
		}else{
			$sql = "DELETE FROM ".$table." WHERE ";
			$arrname = array_keys($Conditionsname);
			$arrvalue = array_values($Conditionsname);
			for($i=0;$i<count($arrname);$i++){
				if($i==count($arrname)-1){
					$sql.=$arrname[$i].'='."'".$arrvalue[$i]."'";
				}else{
					$sql.=$arrname[$i].'='."'".$arrvalue[$i]."',";
				}
			}
			$sql.=';';
		}
		$re = $this->query($sql);
		if($re){
			return true;
		}else{
			return false;
		}
	}
 
	/**
	 * SqlLite 查询数据
	 *
	 * $table String 表名
	 * $name String 查询字段
	 * $Conditionsname 查询条件
	 *
	 * select("test","id,name,age,article",array("name"=>"张三"));
	 */
	function select($table,$name,$Conditionsname,$Conditionsvalue=null)
	{
		if($Conditionsvalue!=null){
			$sql = "SELECT ".$name." FROM ".$table." WHERE ".$Conditionsname."='".$Conditionsvalue."';";
		}else{
			$sql = "SELECT ".$name." FROM ".$table." WHERE ";
			$arrname = array_keys($Conditionsname);
			$arrvalue = array_values($Conditionsname);
			for($i=0;$i<count($arrname);$i++){
				if($i==count($arrname)-1){
					$sql.=$arrname[$i].'='."'".$arrvalue[$i]."'";
				}else{
					$sql.=$arrname[$i].'='."'".$arrvalue[$i]."' and ";
				}
			}
			$sql.=';';
		}
		$ret = $this->query($sql);
		$return = array();
		while($row = $ret->fetchArray(SQLITE3_ASSOC) ){
			array_push($return, $row);
		}
		return $return;
	}
 
	/**
	 * SqlLite 更新数据
	 *
	 * $table String 表名
	 * $name String 修改的字段
	 * $value String 更新的值
	 * $Conditionsname 修改条件Array
	 */
	function update($table,$name,$value,$Conditionsname,$Conditionsvalue=null)
	{
		if($Conditionsvalue!=null){
			$sql = "UPDATE ".$table." SET ".$name."= '".$value."' WHERE ".$Conditionsname."='".$Conditionsvalue."';";
		}else{
			$sql = "UPDATE ".$table." SET ".$name."= '".$value."' WHERE ";
			$arrname = array_keys($Conditionsname);
			$arrvalue = array_values($Conditionsname);
			for($i=0;$i<count($arrname);$i++){
				if($i==count($arrname)-1){
					$sql.=$arrname[$i].'='."'".$arrvalue[$i]."'";
				}else{
					$sql.=$arrname[$i].'='."'".$arrvalue[$i]."' and ";
				}
			}
			$sql.=';';
		}
		$re = $this->query($sql);
		if($re){
			return true;
		}else{
			return false; 
		}
	}
 
	/**
	 * SqlLite 数据查询分组
	 */
	function group($table,$name){
		$sql = "SELECT ".$name." FROM ".$table.";";
		$return = array();
		$ret = $this->query($sql);
		while($row = $ret->fetchArray(SQLITE3_ASSOC) ){
			array_push($return, $row[$name]);
		}
		return $return;
	}
 
	/**
	 * SqlLite 数组对象转数组
	 */
	function fecthall($sql)
	{
		$return = array();
		$ret = $this->query($sql);
		while($row = $ret->fetchArray(SQLITE3_ASSOC) ){
			array_push($return, $row);
		}
		return $return;
	}
}

php判断SQLite查询结果是否为空

php操作MySql数据库时,判断查询结果一般用mysql_num_rows($array)得到结果集条数,然后判断php执行sql语句返回结果集条数是否大于0。SQLite数据库查询结果无法使用mysql_num_rows()方法。同时MySql查询结果为空时不会返回结果,但是SQLite会返回一个为空的结果集。如果直接用PHP中求数组元素数目的count()函数。会得到结果: 1 

解决方案:

  $sql = <<<EOF
       SELECT * from usertb where user = '不存在';
  EOF;
  $ret = $db->query($sql);
  $obj = array();
  while($row = $ret->fetchArray(SQLITE3_ASSOC)){
           array_push($obj,$row);
         }
   echo "直接判断:".count($ret)."<br>";
   echo "判断push后的结果:".count($obj)."<br>";

运行结果:

直接判断:1
判断push后的结果:0

转载请注明:轮回阁 » PHP对SqlLite数据表相关操作

发表我的评论
取消评论

表情

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)