sqlite在php中是默认安装的本地小型化数据库,类似于xml的小型数据库,但sqlite功能更强。

sqlite.class.php文件:

<?php

   class sqliteDB{

       private $sqliteResult;
private $error = '';
private $createTable = <<<TABLE
/*初始化创建数据表,可创建多个表*/
CREATE TABLE COMPANY
(ID INT PRIMARY KEY NOT NULL,
NAME TEXT NOT NULL,
AGE INT NOT NULL,
DDRESS CHAR(50),
SALARY REAL); /*初始化插入数据,可插入多个数据*/
INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY)
VALUES (1, 'Paul', 32, 'California', 20000.00 ); TABLE; function __construct($fileName){
//如果有数据库,则打开数据库
//如果没有数据库,则创建数据库,并且生成数据表及插入数据
if(file_exists($fileName)){
$this->sqliteResult = new MyDB($fileName);
if(!$this->sqliteResult){
die("Database error:" . $this->sqliteResult->lastErrorMsg());
}
}else{
$this->sqliteResult = new MyDB($fileName);
if(!$this->sqliteResult){
die("Database error:" . $this->sqliteResult->lastErrorMsg());
} $this->execute($this->createTable);
}
}
//此方法用于“增、删、改”
function execute($sql){
$this->error= $this->sqliteResult->exec($sql);
}
//此方法用于“查”
function queryDB($sql){
$result = $this->sqliteResult->query($sql);
$i = 0;
while($row = $result->fetchArray(SQLITE3_ASSOC) ){
$arr[$i] = $row;
$i += 1;
}
return $arr;
} function __destruct(){
if(!$this->error){
die("Database error:" . $this->sqliteResult->lastErrorMsg());
} $this->sqliteResult->close();
}
} class MyDB extends SQLite3{
function __construct($fileName){
$this->open($fileName);
}
}

index.php文件:

<?php
include_once("sqlite.class.php"); $sqliteInsert =<<< EOF
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; $sqliteDelete =<<< EOF
DELETE from COMPANY where ID=2;
EOF; $sqlUpdata =<<< EOF
UPDATE COMPANY set SALARY = 28666.00 where ID=1;
EOF; $sqlSelect =<<<EOF
SELECT * from COMPANY;
EOF; $db = new sqliteDB("test.db");
/*
* $db = new sqliteDB(':memory:');
* 如果文件名赋值为':memory:',那么 SQLite3::open() 将会在
* RAM 中创建一个内存数据库,这只会在 session 的有效时间内持续。
*/ foreach($db->queryDB($sqlSelect) as $value){
if($value["ID"] == 3 OR $value["ID"]== 4){
$isNull = true;
}
} if(!$isNull){
//增加数据
$db->execute($sqliteInsert);
}
//删除数据
$db->execute($sqliteDelete);
//修改数据
$db->execute($sqlUpdata);
echo "<pre>";
//查询数据
print_r($db->queryDB($sqlSelect));
echo "</pre>";

执行后的效果图:

php封装的sqlite操作类的更多相关文章

  1. PHP基于PDO实现的SQLite操作类

    <?php // sqlite分页类 class SqliteDB{ public function __construct(){ // 初始化数据库,并且连接数据库 数据库配置 $this-& ...

  2. 封装一个redis操作类来操作hash格式

    最近项目要用redis,依然是基于tp3.2. 发现thinkphp3.2自带的缓存类并不好使用,就自己封装了一个 目前只支持hash格式,其他数据类型的操作后面用到的时候再补充 <?php / ...

  3. php 封装mysql 数据库操作类

    <?phpheader('content-type:text/html;charset=utf-8');//封装mysql   连接数据库php_mysql//封装mysql   连接数据库ph ...

  4. php 封装Mysql数据库操作类

    花了点时间写了个基于php5.3的Mysql类 $mysql = new Mysql('host','user','pass','db') bool Mysql::insert("表&quo ...

  5. 使用ES6 Class封装的IndexDB 操作类,并实现模糊搜索

     封装如下: indexDBOperate.js export class IndexDBOperate { db = null // 数据库实例 databaseName = null // 数据库 ...

  6. Sqlite操作帮助类

      sqlite帮助类 using System; using System.Collections.Generic; using System.Linq; using System.Text; us ...

  7. 我的DbHelper数据操作类

    其实,微软的企业库中有一个非常不错的数据操作类了.但是,不少公司(起码我遇到的几个...),对一些"封装"了些什么的东西不太敢用,虽然我推荐过微软的企业库框架了...但是还是要&q ...

  8. DbHelper数据操作类

    摘要:本文介绍一下DbHelper数据操作类 微软的企业库中有一个非常不错的数据操作类.但是,不少公司(起码我遇到的几个...),对一些"封装"了些什么的东西不太敢用,虽然我推荐过 ...

  9. 我的DbHelper数据操作类(转)

    其实,微软的企业库中有一个非常不错的数据操作类了.但是,不少公司(起码我遇到的几个...),对一些"封装"了些什么的东西不太敢用,虽然我推荐过微软的企业库框架了...但是还是要&q ...

随机推荐

  1. Power BI 实现实时更新Streaming Dataset

    一.在PowerBI portal端需要准备的操作: 1. https://app.powerbi.cn 登陆,点击左侧My Workspace,你需要有一个账号 2. 选入Datasets,点击页面 ...

  2. c++ io标准库2

    转自:http://www.2cto.com/kf/201110/109445.html 接下来我们来学习一下串流类的基础知识,什么叫串流类? 简单的理解就是能够控制字符串类型对象进行输入输出的类,C ...

  3. Flash与JavaScript互动

    最近做的一个项目需要用javascript来实现自动复制文本到剪切板,但测试时发现只有ie6.0支持. 到百度搜索后才发现,原来ie7.0.firefox是不支持这样的操作的,随后又搜索了一下,找到一 ...

  4. Druid 配置及内置监控,Web页面查看监控内容

    1.配置Druid的内置监控 首先在Maven项目的pom.xml中引入包 <dependency> <groupId>com.alibaba</groupId> ...

  5. python---memcache基本使用以及内部原理

    简单使用: import memcache mc = memcache.Client(['127.0.0.1:8081','127.0.0.1:8082','127.0.0.1:8083','127. ...

  6. springSecurity初步认识和执行流程

    springSecurity是spring官方给我们提供的一个非常强大的一个安全框架.也是现在最受欢迎的安全框架,比shiro更强大 springSecurity主要工作原理是内置了许多过滤器,组成过 ...

  7. Log4net(一)-——配置文件

    一.Log4Net框架介绍 Log4net 是 Apache 下一个开放源码的项目,它是Log4j 的一个克隆版.Log4net中定义了多种日志信息输出模式.它可以根据需要将日志输出到控制台,文本文件 ...

  8. HDU - 4333 Revolving Digits(扩展KMP)

    http://acm.hdu.edu.cn/showproblem.php?pid=4333 题意 一个数字,依次将第一位放到最后一位,问小于本身的数的个数及等于本身的个数和大于本身的个数,但是要注意 ...

  9. java中静态代码执行顺序

    1.Java中静态变量只能在类主体中定义,不能在方法中定义. 静态变量属于类所有而不属于方法. 2. 静态块:用static申明,JVM加载类时执行,仅执行一次 构造块:类中直接用{}定义,每一次创建 ...

  10. 从池子里的beta看秋香, 个性迥异

    从池子里的beta看秋香, 个性迥异 前文里那十只个股为例, 统计了它们的beta值. 回顾如下: Num name code Beta 0 深圳燃气 601139 0.710 公用事业 1 分众传媒 ...