sqlite数据库简介 -凯发k8国际

`
qepwqnp
  • 浏览: 102735 次
  • 性别:
  • 来自: 成都
最近访客
博主相关
  • 博客
  • 微博
  • 相册
  • 收藏
  • 社区版块
    • ( 0)
    • ( 65)
    • ( 47)
    存档分类
    最新评论

    sqlite数据库简介

    大家好,今天来介绍一下sqlite的相关知识,并结合java实现对sqlite数据库的操作。

    sqlite是d.richard hipp用c语言编写的开源嵌入式数据库引擎。它支持大多数的sql92标准,并且可以在所有主要的操作系统上运行。

    sqlite由以下几个部分组成:sql编译器、内核、后端以及附件。sqlite通过利用虚拟机和虚拟数据库引擎(vdbe),是调试、修改和扩展sqlite的内核变得更加方便。所有sql语句都被编译成易读的、可以在sqlite虚拟机中执行的程序集。sqlite的整体结构图如下:


    值得一提的是,袖珍型的sqlite竟然可以支持高达2tb大小的数据库,每个数据库都是以单个文件的形式存在,这些数据都是以b-tree的数据结构形式存储在磁盘上。

    在事务处理方面,sqlite通过数据库级上的独占性和共享锁来实现独立事务处理。这意味着多个进程可以在同一时间从同一数据库读取数据,但只有一个可以写入数据。在某个进程或线程想数据库执行写操作之前,必须获得独占锁。在获得独占锁之后,其他的读或写操作将不会再发生。

    sqlite采用动态数据类型,当某个值插入到数据库时,sqlite将会检查它的类型,如果该类型与关联的列不匹配,sqlite则会尝试将该值转换成该列的类型,如果不能转换,则该值将作为本身的类型存储,sqlite称这为“弱类型”。但有一个特例,如果是integer primary key,则其他类型不会被转换,会报一个“datatype missmatch”的错误。

    概括来讲,sqlite支持null、integer、real、text和blob数据类型,分别代表空值、整型值、浮点值、字符串文本、二进制对象。

    下面,我们就来亲自操作一下sqlite数据库。

    在操作之前,朋友们要先下载sqlite数据库,官方的下载页面是,我是在windows下试验,所以我选择了precompiled binaries for windows下面的sqlite-shell-win32-x86和sqlite-analyzer-win32-x86的zip包,前者是sqlite数据库引擎,后者是sqlite数据库分析器,主要用于分析数据库的状态等信息,大家也可以根据自己的情况去下载。下载完成后分别解压,得到两个可执行文件,如图:


    这两个文件可以根据自己的喜好放置在指定的位置,我将其放在d盘根目录下。下面我们就来一步一步操作sqlite:


    创建数据库:

    d:\>sqlite3 test.db
    sqlite version 3.7.7.1 2011-06-28 17:39:05
    enter ".help" for instructions
    enter sql statements terminated with a ";"
    sqlite> .databases
    seq  name             file
    ---  ---------------  ----------------------------------------------------------
    0    main             d:\test.db
    sqlite>
    我们执行了sqlite3命令,参数就是数据库的名称,如果该数据库已存在,则使用,如果不存在,则新建一个,这里我们简单的在当前位置创建了test.db,你也可以在任何存在的并且可写的目录下创建自己的数据库。(如果对于sqlite的命令不太熟悉,可以执行“.help”命令列出所有的命令清单进行查看)。


    创建表:

    sqlite> create table person (id integer primary key autoincrement, name varchar(20), age smallint);
    sqlite> .tables
    person
    sqlite> .schema person
    create table person (id integer primary key autoincrement, name varchar(20), age smallint);
    sqlite>
    在我们创建表之后,可以用“.tables”命令去查看已有的表,用“.schema”命令去查看表的结构,如果后面没有表名做参数,则将会输出所有表的建表语句。


    插入数据:

    sqlite> insert into person values (null, 'john', 30);
    sqlite> select * from person;
    1|john|30


    从.sql文件导入数据:

    sqlite> .read test.sql
    sqlite> select * from person;
    1|john|30
    2|david|35
    3|henry|40
    sqlite>


    分析数据库使用状态:

    d:\>sqlite3_analyzer test.db
    /** disk-space utilization report for test.db
    page size in bytes.................... 1024
    pages in the whole file (measured).... 4
    pages in the whole file (calculated).. 4
    pages that store data................. 4          100.0%
    pages on the freelist (per header).... 0            0.0%
    pages on the freelist (calculated).... 0            0.0%
    pages of auto-vacuum overhead......... 0            0.0%
    number of tables in the database...... 4
    number of indices..................... 0
    number of named indices............... 0
    automatically generated indices....... 0
    size of the file in bytes............. 4096
    bytes of user payload stored.......... 39           0.95%
    ...


    备份数据库:

    备份 sqlite 数据库有两种方法。如果数据库正在使用中,则应从命令行界面使用 .dump 命令。这样可以创建一个包含必要命令和数据的文件,从而重新创建数据库。.dump 命令也可以用于备份数据库表。

    sqlite> .dump
    pragma foreign_keys=off;
    begin transaction;
    create table person (id integer primary key autoincrement, name varchar(20), age smallint);
    insert into "person" values(1,'john',30);
    insert into "person" values(2,'david',35);
    insert into "person" values(3,'henry',40);
    delete from sqlite_sequence;
    insert into "sqlite_sequence" values('person',3);
    commit;
    sqlite> .output dump.sql
    sqlite> .dump
    sqlite>
    我们可以指定输出的目标为一个文件,然后再使用命令时,输出信息就会写入指定的文件,如果想恢复为标准输出,可以这样设定:
    sqlite> .output stdout
    sqlite> .dump
    pragma foreign_keys=off;
    begin transaction;
    create table person (id integer primary key autoincrement, name varchar(20), age smallint);
    insert into "person" values(1,'john',30);
    insert into "person" values(2,'david',35);
    insert into "person" values(3,'henry',40);
    delete from sqlite_sequence;
    insert into "sqlite_sequence" values('person',3);
    commit;
    sqlite>

    如果数据库没有处于使用状态,则可以直接将数据库文件复制到安全位置。

    最后,我们可以使用“.quit”或“.exit”退出sqlite。


    管理工具:

    现在网络上的sqlite管理工具很多,我向大家推荐一款好用的工具:sqlite expert。



    在java中使用sqlite:

    我们要想在java中使用sqlite,需要下载sqlite相关驱动,推荐大家到页面去下载最新的驱动包,现在最新版本是sqlite-jdbc-3.7.2.jar,体积有点大,因为它包含了linux、mac、windows的本地类库,如图:


    下载了驱动之后,我们新建一个项目,名为sqlite:


    在上图中,我们引入sqlite驱动包到类路径下,然后建立一个db的文件夹,用于放置数据库文件。最后我们看一下test.java代码:

    package com.scott.sqlite;
    import java.sql.connection;
    import java.sql.drivermanager;
    import java.sql.resultset;
    import java.sql.statement;
    public class test {
    	public static void main(string[] args) throws exception {
    		class.forname("org.sqlite.jdbc");
    		connection conn = drivermanager.getconnection("jdbc:sqlite:db/test.db");
    		statement stmt = conn.createstatement();
    		stmt.executeupdate("drop table if exists person");
    		stmt.executeupdate("create table person(id integer, name string)");
    		stmt.executeupdate("insert into person values(1, 'john')");
    		stmt.executeupdate("insert into person values(2, 'david')");
    		stmt.executeupdate("insert into person values(3, 'henry')");
    		resultset rs = stmt.executequery("select * from person");
    		while (rs.next()) {
    			system.out.println("id=>"   rs.getint("id")   ", name=>"   rs.getstring("name"));
    		}
    		stmt.close();
    		conn.close();
    	}
    }
    
    执行test.java文件,结果如下:


    这个时候,在我们的db目录下,就生成了一个test.db的文件:



    sqlite使用须知:

    目前没有可用于 sqlite 的网络服务器。从应用程序运行位于其他计算机上的 sqlite 的惟一方法是从网络共享运行。这样会导致一些问题,像 unix® 和 windows® 网络共享都存在文件锁定问题。还有由于与访问网络共享相关的延迟而带来的性能下降问题。

    sqlite 只提供数据库级的锁定。

    sqlite 没有用户帐户概念,而是根据文件系统确定所有数据库的权限。


    结束语:

    由于资源占用少、性能良好和零管理成本,嵌入式数据库有了它的用武之地,像android、iphone都有内置的sqlite数据库供开发人员使用,它的易用性可以加快应用程序的开发,并使得复杂的数据存储变得轻松了许多。

    分享到:
    评论

    相关推荐

      android之sqlite数据库开发详解: android 开发中使用 sqlite 数据库 简介: sqlite 是一款非常流行的嵌入式数据库,它支持 sql 查询,并且只用很少的内存。android 在运行时集成了 sqlite,所以每个 android 应用...

      sqlite数据库工具 供比较两个sqlite数据库所用。

       android 绿豆通讯录( sqlite数据库 listview数据展示控件 ) https://blog.csdn.net/weixin_44949135/article/details/106029404 采用 sqlite数据库 listview数据展示控件,可将用户添加的所有信息,分条...

      sqlite数据库加密、解密工具,主要是用于进行给sqlite数据库进行加密,修改密码的工具

      php读取sqlite数据库, php读取sqlite数据库,php读取sqlite数据库

      这是一个使用c#开发的sqlite数据库创建、操作的源码工程,关于sqlite的所有操作已经单独创建了专门的跨平台【.netcore3.1】类库包含相应的帮助类,可以直接生成后拿到任何项目中直接使用,高效简单,省去了从头开发...

      sqlite数据库加密解密小工具,只用于.net中使用sqlite时的加密和加密

      android实验报告sqlite数据库操作.pdf

      qt中sqlite数据库加密sqlitecipher 操作实例,打开多个数据库,附着数据库跨库查询, 对应说明:https://blog.csdn.net/woguanni/article/details/120524602

      sqlite数据库文件经多次添加删除操作后 文件占用磁盘空间过大 c 压缩文件代码 sqlite数据库文件经多次添加删除操作后 文件占用磁盘空间过大 c 压缩文件代码 测试调用testfunction.h文件 bool commit_vacuum...

      sqlite数据库查询时中文乱码;

      wordpress改sqlite数据库操作。解决服务器放多个wp站数据库资源占用过大问题。内附一些插件,及具体操作办法

      在学习的过程中遇到了配置问题是主要的,能得找bug找了大半天,但是还是坚持的心态把问题给解决了,比如需要哪几个文件,需要sqlite3.dll、sqlite3.lib、sqlite3i.h、sqlite3.hdbsqlite.h、dbsqlite.cpp这些都是已经...

      delphi7用asgsqlite3访问sqlite数据库实例: 1、用aducom sqlite3连接数据库,操作非常简单,跟用ado访问一样 2、用navicat制作数据库,显示正常,但数据库中是乱码,不影响程序运行时的显示。 3、支持在设计时显示...

      本文实例讲述了c#操作sqlite数据库之读写数据库的方法。分享给大家供大家参考,具体如下: 这里演示读写数据库并在窗体(form)中显示其数据,其方式为: 读: database(sqlite) -> dataadapter -> dataset -> ...

      实验十 使用sqlite数据库存储数据

      最好用的sqlite数据库打开工具,找了好久才找到,以是上传资源共享出来以便大家下载

      修改sqlite3数据库的密码 备注:在不替换sqlite3.dll的前提下,本程序生成的带密码的db.db文件可以用sqliteexpert_3.4.34.2256打开,如换作其它sqlite3.dll这个文件,则不保证,但换了别的sqlite3.dll本程序依然可用,只有...

      javascript操作sqlite数据库demo,不需要安装软件,可直接操作sqlite数据库。(推荐下载sqlitestudio查看生成的数据是否正确)。

      c语言调用sqlite数据库中表的内容,非常实用

    global site tag (gtag.js) - google analytics
    网站地图