android sqlite3

1、进入命令行环境:sqlite3
打开一个控制台窗口,输入 sqlite3 回车,这时你就进入了 SQLite 命令行环境,它显示了版本号,并告诉你每一条 SQL 语句必须用分号 ; 结尾

2、命令行帮助:.help

在命令行环境下输入 .help 回车,显示所有可使用的命令以及这些命令的帮助。注意:所有的命令开头都是一个点

3、退出命令行环境
.quit 或者 .exit  都可以退出

1、创建一个新的数据库:sqlite3     文件名
先建立一个 Db 目录,并在 Db 目录中创建一个 test.db 数据库文件,打开控制台窗口,命令如下:
mkdir Db
cd Db
sqlite3 test.db
 
2、打开一个已经存在的数据库:sqlite3 已经存在的文件名
创建一个新数据库和打开一个已经存在的数据库命令是一模一样的,如果文件在当前目录下不存在,则新建;如果存在,则打开。
 
3、导入数据:.read     数据文件
打开记事本,并将下列 SQL 语句复制到记事本中,保存为 test.sql 到上面说到的 Db 目录下,在命令行环境中输入
.read   test.sql
即将所有的数据导入到 test.db 数据库中。
test.db 导入数据
BEGIN   TRANSACTION ;
CREATE   TABLE  Cars(Id  integer   PRIMARY   KEY , Name  text , Cost  integer );
INSERT   INTO  Cars  VALUES ( 1 , ' Audi ' , 52642 );
INSERT   INTO  Cars  VALUES ( 2 , ' Mercedes ' , 57127 );
INSERT   INTO  Cars  VALUES ( 3 , ' Skoda ' , 9000 );
INSERT   INTO  Cars  VALUES ( 4 , ' Volvo ' , 29000 );
INSERT   INTO  Cars  VALUES ( 5 , ' Bentley ' , 350000 );
INSERT   INTO  Cars  VALUES ( 6 , ' Citroen ' , 21000 );
INSERT   INTO  Cars  VALUES ( 7 , ' Hummer ' , 41400 );
INSERT   INTO  Cars  VALUES ( 8 , ' Volkswagen ' , 21600 );
COMMIT ;


BEGIN TRANSACTION;
CREATE TABLE Orders(Id integer PRIMARY KEY, OrderPrice integer CHECK(OrderPrice>0), 
                    Customer 
text);
INSERT INTO Orders(OrderPrice, Customer) VALUES(1200, "Williamson");
INSERT INTO Orders(OrderPrice, Customer) VALUES(200, "Robertson");
INSERT INTO Orders(OrderPrice, Customer) VALUES(40, "Robertson");
INSERT INTO Orders(OrderPrice, Customer) VALUES(1640, "Smith");
INSERT INTO Orders(OrderPrice, Customer) VALUES(100, "Robertson");
INSERT INTO Orders(OrderPrice, Customer) VALUES(50, "Williamson");
INSERT INTO Orders(OrderPrice, Customer) VALUES(150, "Smith");
INSERT INTO Orders(OrderPrice, Customer) VALUES(250, "Smith");
INSERT INTO Orders(OrderPrice, Customer) VALUES(840, "Brown");
INSERT INTO Orders(OrderPrice, Customer) VALUES(440, "Black");
INSERT INTO Orders(OrderPrice, Customer) VALUES(20, "Brown");
COMMIT;

BEGIN TRANSACTION;
CREATE TABLE Friends(Id integer PRIMARY KEY, Name text UNIQUE NOT NULL
                     Sex 
text CHECK(Sex IN ('M''F')));
INSERT INTO Friends VALUES(1,'Jane''F');
INSERT INTO Friends VALUES(2,'Thomas''M');
INSERT INTO Friends VALUES(3,'Franklin''M');
INSERT INTO Friends VALUES(4,'Elisabeth''F');
INSERT INTO Friends VALUES(5,'Mary''F');
INSERT INTO Friends VALUES(6,'Lucy''F');
INSERT INTO Friends VALUES(7,'Jack''M');
COMMIT;

BEGIN TRANSACTION;
CREATE TABLE IF NOT EXISTS Customers(CustomerId integer PRIMARY KEY, Name text);
INSERT INTO Customers(Name) VALUES('Paul Novak');
INSERT INTO Customers(Name) VALUES('Terry Neils');
INSERT INTO Customers(Name) VALUES('Jack Fonda');
INSERT INTO Customers(Name) VALUES('Tom Willis');

CREATE TABLE IF NOT EXISTS Reservations(Id integer PRIMARY KEY
                                        CustomerId 
integerDay text);
INSERT INTO Reservations(CustomerId, DayVALUES(1'2009-22-11');
INSERT INTO Reservations(CustomerId, DayVALUES(2'2009-28-11');
INSERT INTO Reservations(CustomerId, DayVALUES(2'2009-29-11');
INSERT INTO Reservations(CustomerId, DayVALUES(1'2009-29-11');
INSERT INTO Reservations(CustomerId, DayVALUES(3'2009-02-12');
COMMIT;

BEGIN TRANSACTION;
CREATE TABLE Names(Id integer, Name text);
INSERT INTO Names VALUES(1,'Tom');
INSERT INTO Names VALUES(2,'Lucy');
INSERT INTO Names VALUES(3,'Frank');
INSERT INTO Names VALUES(4,'Jane');
INSERT INTO Names VALUES(5,'Robert');
COMMIT;

4、列出所有的数据表: .tables
完成上面所有的工作以后,我们就可以列出所有的数据表了

5、显示数据库结构:.schema
其实就是一些 SQL 语句,他们描述了数据库的结构

6、显示表的结构:.schema    表名

7、导出某个表的数据: .dump    表名

这时我们可以看到,整个表以 SQL 语句的形式为导出来了,但是只是显示在终端上,如何把它导出到文件中呢?

8、设置导出目标: 
.output     文件名  
或者
.output   stdout
先运行 .output cars.sql ,然后再运行 .dump 命令试试看?如果要回复成导出到终端(标准输出),则运行 .output stdout

1、设置分隔符:.separator    分隔符
我们可以首先运行 SELECT * FROM Names; ,可以看到默认的分隔符是 | 
运行.separator : 以后,再 SELECT * FROM Names;,可以看到分隔符已经变成 : 了

2、设置显示模式:.mode    模式
有好几种显示模式,默认的是 list 显示模式,一般我们使用 column 显示模式,还有其他几种显示模式可以 .help 看 mode 相关内容。看看下面的图,和上面是不是显示的不一样了?

3、显示标题栏:.headers   on
看看,是不是又不太一样了?

4、设置每一列的显示宽度:.width     w1,w2,w3.........
一些内容,默认的宽度显示不下,这个命令就有用了

5、设置 NULL 值显示成什么样子: .nullvalue     你想要的NULL值格式
默认情况下NULL值什么也不显示,你可以设置成你自己想要的样子

6、列出当前显示格式设置情况:.show

7.创建修改删除表:

SQLite 数据库引擎支持下列三种 DDL 语句:

  • CREATE
  • ALTER TABLE
  • DROP
  • http://www.blogjava.net/myqiao/archive/2011/07/12/354133.html
    (网址中有比较详细易懂的概述)

8.另外还有增删改查:
(网址中有比较详细易懂的概述)
http://www.blogjava.net/myqiao/archive/2011/07/13/354298.html





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值