Sqlite命令行(CLP)
======================================================================================
.help //获取帮助,会列出可用命令,如下:
.ver //获得版本
.open test.db //打开数据库文件
.save test.db //保存一个数据库或新建
.database //获取当前目录下存在的数据库文件,一个文件表示一个数据库
.tables //获取表列表
.indices test //获取表的索引列表
.schema test //提供表名则获取表创建语句,不提供则获取所有表,查询sqlite_master系统视图也可
.show //获取用户shell定义的设置
.nullvale NULL //设置null显示为NULL
.echo on //输出执行的语句

//导出为sql文件
.output file.sql
.dump
.output stdout

//导入sql文件
drop table test;
drop view schema;
.read file.sql
或者直接在命令行中用:
sqlite3 test.db .dump > test.sql
sqlite3 test.db < test.sql
sqlite3 -init test.sql test.db

create table test(id integer primary key, value text); //id主键且自增
create index test_idx on test(value) //创建索引。

//简单增删改查询,和Mysql类似
insert into test(id,value)values(1, 'testz');
insert into test(value)values('testz');

.mode column //查询结果显示列,可选格式:csv,html,insert,line,tabs,tcl,默认为list
.headers on //显示头部信息(包含.mode column)
select * from test; //查询数据,不显示列名的
select last_insert_rowid(); //获取最后插入的ID

//结果输出为csv,其中.mode csv也可以用.dump输出备份sql
.output file.csv
.mode csv //或用.separator ,
select * from test;
.output stdout

//导入到test2表
create table test2(id integer primary key, value text);
.import text.csv test2

//备份源文件,二进制文件,但没sql移植好
sqlite3 test.db vacuum
cp test.db test.Backup

工具
======================================================================================
sqlite3_analyzer 可获取数据库磁盘结构的详细技术信息。

SQL
======================================================================================
使用;作为命令终结符。

select * from test;
insert into test(value)values('testz');
delete from test where id =1;
update teable set value="zz" where id=3

//很多和Mysql语法类似,如 :
like "%test%"、count(*)、group by、having、distinct、as、in、子查询、复合查询、

//读一行从第一行开始。desc或asc,可忽略offset。
select * from test order by desc id limit 1 offset 1

//类似MYSQL的左连接
select * from test a left outer join testb b on a.id=b.id;

字段设计
======================================================================================
日期的默认值:
current_date YYYY-MM-DD
current_time HH::MM::SS
current_timestamp YYYY-MM-DD HH:MM:SS

//check约束,小于7个字符就报错。
create table test(
id integer primary key,
name text not null default 'zzz',
unique(name),
check(length(name)>=7));

//外键test_types表的id
create table test(
id integer primary key,
type_id integer references test_types(id)
on delete restrict //父ID被删时,此数据不删除。
deferrable initially deferred,
name text);

完整规则:
set null:如果父值被删除或不存在,剩余子值改为null。
set default:如果父值被删除或不存在,剩余子值改为默认值。
casecade:更新或删除父值时则子值也被更新或删除。
restrict:更新或删除父值,可能会出现孤立的子值,从而阻止事务。
no action:不干涉操作执行,只观察变化。
deferrable:立即强制实施还是延迟到整个事务结束时。

//关于字段类型
通过值的表示法来判断其类型。有5类型:integer、real(浮点)、text、blob(二进制x开头带引号)、null
一个字段可以存储不同类型的值。
select typeof(3.14) 查询其类型

索引
======================================================================================
//创建name大小写不敏感的索引
create index a_idx test(name collate nocase);

//使用单个字段索引的情况: idx on test(a)
column {=|>|>=|<=|<} expression
expression {=|>|>=|<=|<} column
column IN (expression-list)
column IN (subquery)

//多字段索引的情况: idx on test(a,b,c,d)
只有a和b使用了索引
select * from test where a=1 and b=2 and d=3
表达式a>1称为最右边的索引字段,因为用了不等号,后面的查询条件无法使用索引。
select * from test where a>1 and b=2 and c=3 and d=3

事务
======================================================================================
begin,commit,rollback

主要分为:读事务、写事务。
默认多个事务一起运行时,一个事务的非读操作需要等另一个事务(如果有语句执行)结束才能提交。

为了避免死锁,需要使用正确的事务类型,默认3种:
begin [deferred | immediate | exclusive] transaction;
其中:
deferred
是默认情况,直到必须使用时才获取锁。

immediate
在执行时试图获取预留锁,如果成功获取,其它事务无法修改数据库只能读,提交不会被阻碍,提交后其它事务可修改。

exclusive
试着获取对数据库的排它锁,只有等此事务任意操作完并提交后,其它事务才能开始执行查询或增删等语句。
exclusive比immediate更高的安全级别,immediate开始就不会产生死锁了。

函数

======================================================================================

datetime(time, 'unixepoch', 'localtime')                          查询时间戳为本地时间

Sqlite 学习记录的更多相关文章

  1. [QT][SQLITE]学习记录一 querry 查询

    使用 QSqlQuery query ; query("SELECT id FROM TABLE1 WHERE id = '2017'); 的到的结果集就是query本身,此时需要使用 qu ...

  2. [QT][SQLITE]学习记录二 日期查询

    资料例程: 1.dongfangyu SQL时间段查询 : http://blog.csdn.net/dongfangyu/article/details/4607236 2.痕网 - henw  S ...

  3. SQLite学习笔记(七)&&事务处理

    说到事务一定会提到ACID,所谓事务的原子性,一致性,隔离性和持久性.对于一个数据库而言,通常通过并发控制和故障恢复手段来保证事务在正常和异常情况下的ACID特性.sqlite也不例外,虽然简单,依然 ...

  4. Sqlite学习笔记(四)&&SQLite-WAL原理

    Sqlite学习笔记(三)&&WAL性能测试中列出了几种典型场景下WAL的性能数据,了解到WAL确实有性能优势,这篇文章将会详细分析WAL的原理,做到知其然,更要知其所以然. WAL是 ...

  5. [ZHUAN]Flask学习记录之Flask-SQLAlchemy

    From: http://www.cnblogs.com/agmcs/p/4445583.html 各种查询方式:http://www.360doc.com/content/12/0608/11/93 ...

  6. Sqlite学习笔记(四)&&SQLite-WAL原理(转)

    Sqlite学习笔记(三)&&WAL性能测试中列出了几种典型场景下WAL的性能数据,了解到WAL确实有性能优势,这篇文章将会详细分析WAL的原理,做到知其然,更要知其所以然. WAL是 ...

  7. SQLite 学习笔记

    SQLite 学习笔记. 一.SQLite 安装    访问http://www.sqlite.org/download.html下载对应的文件.    1.在 Windows 上安装 SQLite. ...

  8. Android学习记录(3)—Android中ContentProvider的基本原理学习总结

    一.ContentProvider简介        当应用继承ContentProvider类,并重写该类用于提供数据和存储数据的方法,就可以向其他应用共享其数据.虽然使用其他方法也可以对外共享数据 ...

  9. SQlite 学习资料

      很有用的开源跨平台数据库,可以作为客户端的小型内存数据库使用,据说它有N多用户(Nokia's Symbian,Mozilla,Abobe,Google,阿里旺旺,飞信,Chrome,FireFo ...

随机推荐

  1. python字符串列表字典相互转换

    字符串转换成字典 json越来越流行,通过python获取到json格式的字符串后,可以通过eval函数转换成dict格式: >>> a='{"name":&qu ...

  2. php删除多重数组对象属性,重新赋值的方法

    php删除多重数组对象属性,重新赋值的方法 实例:sphinx搜索出来的结果,要去掉某个属性值:$cl = new SphinxClient ();$query = $cl->Query ( $ ...

  3. Java中类方法与实例方法的区别

    实例方法可以对当前对象的实例变量进行操作,也可以对类变量进行操作,但类方法不能访问实例变量.实例方法必须由实例对象来调用,而类方法除了可由实例对象调用外,还可以由类名直接调用. 另外,在类方法中不能使 ...

  4. 【jQuery UI 1.8 The User Interface Library for jQuery】.学习笔记.7.Slider控件

    默认slider的安装启用 为slider自定义风格 修改配置选项 创建一个垂直的slider 设置最大最小值,和默认值 启用多个 手柄 和 范围 slider内置的回调事件 slider的方法 这个 ...

  5. Docker centos 安装syslog

    在通常的Linux服务器中,有一些服务本身没有日志,只能通过 tail -f /var/log/messages来查看其运行日志,比如nrpe server.但是,如果想在docker容器中实现这个功 ...

  6. yii2通过foreach循环遍历在一个用户组中取出id去另一表里查寻信息并且带着信息合并原数组信息---案例

    yii2通过foreach循环遍历在一个用户组中取出id去另一表里查寻信息并且带着信息合并元数组信息---案例 public function actionRandomLists(){ //查询到了所 ...

  7. 杭电1012-u Calculate e

    #include<stdlib.h>#include <stdio.h>  int main ()  {      printf("n e\n");    ...

  8. Dive into python学习笔记

    http://woodpecker.org.cn/diveintopython/index.html 1.第一个程序odbchelper.py def buildConnectionString(pa ...

  9. Android 静默安装

    有时候我们需要软件实现静默安装,但是Android并未提供相应的API,然而我们知道命令行安装android的时候是不会提示用户的,所有要实现这个功能,我们就可以从执行命令行的方式实现.android ...

  10. 一些常用的SQL查询语句

    学习网站:http://www.w3cschool.cc/sql/sql-tutorial.html 一:查询所有表的属性 SELECT 'ALTER TABLE '+ CASE WHEN O.sch ...