安装:
方法一:
wget http:
//www.sqlite.org/sqlite-autoconf-3070500.tar.gz
tar xvzf sqlite-autoconf-3070500.tar.gz
cd sqlite-autoconf-3070500
./configure
make
sudo make install

方法二:

sudo yum install sqlite-devel

方法三:
sudo gem install sqlite3-ruby
 
命令:
查看版本信息:
#sqlite3 -version
 sqlite3终端进入命令:
# sqlite3
 

查看数据库文件信息命令(注意命令前带字符'.'):
sqlite>.database

查看所有表的创建语句:
sqlite>.schema

查看指定表的创建语句:
sqlite>.schema table_name

以sql语句的形式列出表内容:
sqlite>.dump table_name

设置显示信息的分隔符:
sqlite>.separator symble
Example:设置显示信息以‘:'分隔
sqlite>.separator :

设置显示模式:
sqlite>.mode mode_name
Example:默认为list,设置为column,其他模式可通过.help查看mode相关内容
sqlite>.mode column

输出帮助信息:
sqlite>.help

设置每一列的显示宽度:
sqlite>.width width_value
Example:设置宽度为2
sqlite>.width 2

列出当前显示格式的配置:
sqlite>.show

退出sqlite终端命令:
sqlite>.quit

sqlite>.exit

3、sqlite3指令
sql的指令格式:所有sql指令都是以分号(;)结尾,两个减号(--)则表示注释。
如:
sqlite>create studen_table(Stu_no interger PRIMARY KEY, Name text NOT
NULL, Id interger UNIQUE, Age interger CHECK(Age>6), School text
DEFAULT 'xx小学);
该语句创建一个记录学生信息的数据表。

3.1 sqlite3存储数据的类型
NULL:标识一个NULL值
INTERGER:整数类型
REAL:浮点数
TEXT:字符串
BLOB:二进制数

3.2 sqlite3存储数据的约束条件
Sqlite常用约束条件如下:
PRIMARY KEY - 主键:
1)主键的值必须唯一,用于标识每一条记录,如学生的学号
2)主键同时也是一个索引,通过主键查找记录速度较快
3)主键如果是整数类型,该列的值可以自动增长
NOT NULL - 非空:
约束列记录不能为空,否则报错
UNIQUE - 唯一:
除主键外,约束其他列的数据的值唯一
CHECK - 条件检查:
约束该列的值必须符合条件才可存入
DEFAULT - 默认值:
列数据中的值基本都是一样的,这样的字段列可设为默认值

3.3 sqlite3常用指令

1)建立数据表
create table table_name(field1 type1, field2 type1, ...);
table_name是要创建数据表名称,fieldx是数据表内字段名称,typex则是字段类型。
例,建立一个简单的学生信息表,它包含学号与姓名等学生信息:
create table student_info(stu_no interger primary key, name text);

2)添加数据记录
insert into table_name(field1, field2, ...) values(val1, val2, ...);
valx为需要存入字段的值。
例,往学生信息表添加数据:
Insert into student_info(stu_no, name) values(0001, alex);

3)修改数据记录
update table_name set field1=val1, field2=val2 where expression;
where是sql语句中用于条件判断的命令,expression为判断表达式
例,修改学生信息表学号为0001的数据记录:
update student_info set stu_no=0001, name=hence where stu_no=0001;

4)删除数据记录
delete from table_name [where expression];
不加判断条件则清空表所有数据记录。
例,删除学生信息表学号为0001的数据记录:
delete from student_info where stu_no=0001;

5)查询数据记录
select指令基本格式:
select columns from table_name [where expression];
a查询输出所有数据记录
select * from table_name;
b限制输出数据记录数量
select * from table_name limit val;
c升序输出数据记录
select * from table_name order by field asc;
d降序输出数据记录
select * from table_name order by field desc;
e条件查询
select * from table_name where expression;
select * from table_name where field in ('val1', 'val2', 'val3');
select * from table_name where field between val1 and val2;
f查询记录数目
select count (*) from table_name;
g区分列数据
select distinct field from table_name;
有一些字段的值可能会重复出现,distinct去掉重复项,将列中各字段值单个列出。

6)建立索引
当说数据表存在大量记录,索引有助于加快查找数据表速度。
create index index_name on table_name(field);
例,针对学生表stu_no字段,建立一个索引:
create index student_index on student_table(stu_no);
建立完成后,sqlite3在对该字段查询时,会自动使用该索引。

7)删除数据表或索引
drop table table_name;
drop index index_name;

最新文章

  1. iOS--使用UIImageView进行GIF动图播放
  2. SOAP-XML请求(iOS应用下集成携程api)
  3. 【转载】利用Unity自带的合图切割功能将合图切割成子图
  4. OpenGL(三)——函数大全
  5. C# 微信支付教程系列之扫码支付
  6. PHP/MYSQL 查询大数据/遍历表
  7. ASP.NET 将Excel导入数据库
  8. iPhone Tableview分批显示数据
  9. excel小技巧-用于测试用例的编号栏:“获取当前单元格的上一格的值+1”=INDIRECT(ADDRESS(ROW()-1,COLUMN()))+1
  10. 写一函数,用来求表达式1+2+3+.....+n的值,并编写主函数
  11. css设置两行多余文字用..显示
  12. 如果忘记了mysql密码怎么办?
  13. (转) SQL Server编程系列(1):SMO介绍
  14. 中小型研发团队架构实践六:如何用好消息队列RabbitMQ?
  15. 《GPU高性能编程CUDA实战》第九章 原子性
  16. 二维码Aztec简介及其解码实现(zxing-cpp)
  17. getLong not implemented for class oracle.jdbc.driver.T4CRowidAccessor
  18. [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:600)
  19. 【xunsearch】笔记
  20. xftp连接不上阿里云服务器

热门文章

  1. MySQL MHA工作原理
  2. Pod生命周期和健康检查
  3. OpenStack核心组件-horizon web 界面管理
  4. Apache服务器http强制转https(ubuntu系统)
  5. 获取ul li的value的值
  6. C++(五十) — 容器中元素满足的条件
  7. linux卸载mysql误删mysql.pm
  8. iOS 测试在应用发布前后的痛点探索以及解决方案
  9. ASP.NET Core 类库中取读配置文件 appsettings.json
  10. 1.zookeeper是干什么的?