封装的sqlite3简易操作类
封装的sqlite3简易操作类,基于sqlite3扩展写的,用法和前一个mysql一样。
但是要注意的是,数据库不存在时会自动创建一个,但是自动创建的数据库类型是sqlite2数据库,这个要注意下。
<?php
/*
注意细节:实例化对象时传入的是数据库的路径,要是数据库不存在的话会自动创建。
*/
class sqlite extends sqlite3{
public $url;
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;
}
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 fasle;
}
}
function drop($table){
$sql = 'drop table '.$table.';';
$re = $this->query($sql);
if($re){
return true;
}else{
return false;
}
}
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 .=");";
if($debug){
echo $sql;
}
$re = $this->query($sql);
if($re){
return true;
}else{
return false;
}
}
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;
}
}
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);
$row = $ret->fetcharray(sqlite3_assoc);
return $row[$name];
}
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;
}
}
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;
}
function fecthall($sql){
$return = array();
$ret = $this->query($sql);
while($row = $ret->fetcharray(sqlite3_assoc) ){
array_push($return, $row);
}
return $return;
}
}
以上就是封装的sqlite3简易操作类的内容。