SQLite的使用一

简介:

1、从官网下载SQLite(http://www.sqlite.org/download.html)安装后(Mac自带SQLite,也可直接运行下面的命令),打开终端更改目录到sqlite3文件所在的目录,输入如下命令便可以创建一个数据库,如果该数据库已存在将打开:

?
1
sqlite3 test.db

    (如果显示以下信息,则说明SQLite已成功安装:)

?
1
2
3
4
5
MacBook-Pro-MD313:SQL mac$ sqlite3 test.db
SQLite version 3.7.12 2012-04-03 19:43:07
Enter  ".help"  for  instructions
Enter SQL statements terminated with a  ";"
sqlite>


    然后创建一个表:

?
1
sqlite> create table mytable(id integer primary key, value text);

    一般数据采用的固定的静态数据类型,而SQLite采用的是动态数据类型,会根据存入值自动判断。SQLite具有以下五种数据类型:

    1.NULL:空值。
    2.INTEGER:带符号的整型,具体取决有存入数字的范围大小。
    3.REAL:浮点数字,存储为8-byte IEEE浮点数。
    4.TEXT:字符串文本。
    5.BLOB:二进制对象。


    但实际上,sqlite3也接受如下的数据类型:
     smallint 16 位元的整数。
     interger 32 位元的整数。
     decimal(p,s) p 精确值和 s 大小的十进位整数,精确值p是指全部有几个数(digits)大小值,s是指小数点後有几位数。  如果没有特别指定,则系统会设为 p=5; s=0 。
     float  32位元的实数。
     double  64位元的实数。
     char(n)  n 长度的字串,n不能超过 254。
     varchar(n) 长度不固定且其最大长度为 n 的字串,n不能超过 4000。
     graphic(n) 和 char(n) 一样,不过其单位是两个字元 double-bytes, n不能超过127。这个形态是为了支援两个字元长度的字体,例如中文字。
     vargraphic(n) 可变长度且其最大长度为 n 的双字元字串,n不能超过 2000
     date  包含了 年份、月份、日期。
     time  包含了 小时、分钟、秒。
     timestamp 包含了 年、月、日、时、分、秒、千分之一秒。

    datetime 包含日期时间格式,必须写成'2010-08-05'不能写为'2010-8-5',否则在读取时会产生错误!

    

    插入数据:

?
1
sqlite> insert into mytable(id, value) values(1,  'Jacedy' );


    查询数据:

?
1
sqlite> select * from mytable;


    创建视图:

?
1
sqlite> create view nameview as select * from mytable;


    创建索引:

?
1
sqlite> create index testIdx on mytable(value);


2、一些常用的SQLite命令

    显示表结构:

?
1
sqlite> .schema [table]

    获取所有表和视图:

?
1
sqlite > .tables

    获取指定表的索引列表:

?
1
sqlite > .indices [table ]

    导出数据到SQL文件:

?
1
2
3
sqlite > .output [filename ]  
sqlite > .dump  
sqlite > .output stdout

    从SQL文件导入数据库:

?
1
sqlite > .read [filename ]

    格式化输出数据到CSV格式:

?
1
2
3
4
sqlite >.output [filename.csv ]  
sqlite >.separator ,  
sqlite > select * from test;  
sqlite >.output stdout

    从CSV文件导入数据到表中:

?
1
2
sqlite >create table newtable ( id integer primary key, value text );  
sqlite >.import [filename.csv ] newtable

    备份数据库:

?
1
2
/* usage: sqlite3 [database] .dump > [filename] */  
sqlite3 mytable.db .dump > backup.sql

    恢复数据库:

?
1
2
/* usage: sqlite3 [database ] < [filename ] */  
sqlite3 mytable.db < backup.sql

    列出(当前数据库文件中)附加的所有数据库的名字和文件 :

?
1
.databases

    退出程序:

?
1
2
.quit
//.exit

    显示帮助:

?
1
.help

    显示当前的设置:

?
1
.show

    列出所有表名:

?
1
.tables

目录
相关文章
|
13天前
|
存储 SQL 数据库
数据库知识:了解SQLite或其他移动端数据库的使用
【10月更文挑战第22天】本文介绍了SQLite在移动应用开发中的应用,包括其优势、如何在Android中集成SQLite、基本的数据库操作(增删改查)、并发访问和事务处理等。通过示例代码,帮助开发者更好地理解和使用SQLite。此外,还提到了其他移动端数据库的选择。
21 8
|
24天前
|
Web App开发 SQL 数据库
使用 Python 解析火狐浏览器的 SQLite3 数据库
本文介绍如何使用 Python 解析火狐浏览器的 SQLite3 数据库,包括书签、历史记录和下载记录等。通过安装 Python 和 SQLite3,定位火狐数据库文件路径,编写 Python 脚本连接数据库并执行 SQL 查询,最终输出最近访问的网站历史记录。
|
1月前
|
存储 关系型数据库 数据库
轻量级数据库的利器:Python 及其内置 SQLite 简介
轻量级数据库的利器:Python 及其内置 SQLite 简介
|
1月前
|
应用服务中间件 PHP Apache
PbootCMS提示错误信息“未检测到您服务器环境的sqlite3数据库扩展...”
PbootCMS提示错误信息“未检测到您服务器环境的sqlite3数据库扩展...”
|
2月前
|
存储 API 数据库
QML使用Sqlite数据库存储ListModel数据
本文介绍了在QML中使用Sqlite数据库存储ListModel数据的方法,包括如何创建数据库、读取数据、动态添加和删除数据,以及如何在程序启动和退出时与数据库同步数据。
|
2月前
|
数据库 数据库管理
qt对sqlite数据库多线程的操作
本文总结了在Qt中进行SQLite数据库多线程操作时应注意的四个关键问题,包括数据库驱动加载、加锁、数据库的打开与关闭,以及QsqlQuery变量的使用。
112 1
|
23天前
|
存储 缓存 关系型数据库
sqlite 数据库 介绍
sqlite 数据库 介绍
35 0
|
3月前
|
人工智能 小程序 Java
【工具】轻松解锁SQLite数据库,一窥微信聊天记录小秘密
本文介绍了一款名为PyWxDump的开源工具,它可以获取微信账户信息、解密SQLite数据库以查看和备份聊天记录。此工具适用于已登录电脑版微信的用户,通过GitHub下载后简单几步即可操作。适合对数据恢复感兴趣的开发者,但请注意合法合规使用并尊重隐私。
427 2
【工具】轻松解锁SQLite数据库,一窥微信聊天记录小秘密
|
2月前
|
JSON NoSQL 数据库
和SQLite数据库对应的NoSQL数据库:TinyDB的详细使用(python3经典编程案例)
该文章详细介绍了TinyDB这一轻量级NoSQL数据库的使用方法,包括如何在Python3环境中安装、创建数据库、插入数据、查询、更新以及删除记录等操作,并提供了多个编程案例。
100 0
|
3月前
|
关系型数据库 Java MySQL
C#winform中使用SQLite数据库
C#winform中使用SQLite数据库
184 3
C#winform中使用SQLite数据库