文档库 最新最全的文档下载
当前位置:文档库 › SQLITE数据库操作

SQLITE数据库操作

SQLITE数据库操作
SQLITE数据库操作

使用SQLiteDatabase操

作SQLite数据库

view plaincopy to clipboardprint?

1./*

2.Android提供了一个名为SQLiteDatabase的类,该类封装了一些操作数据库的API,使用该类

可以完成对数据进行添加(Create)、查询(Retrieve)、更新(Update)和删除(Delete)操作(这些操作简称为CRUD)。对SQLiteDatabase的学习,我们应该重点掌握execSQL()和rawQuery()方法。execSQL()方法可以执行insert、delete、update和CREATE TABLE之类有更改行为的SQL语句;rawQuery()方法用于执行select语句。

3.execSQL()方法的使用例子:

4.SQLiteDatabase db=....;

5.db.execSQL("insert into person(name,age)values('测试数据',4)");

6.db.close();

7.执行上面SQL语句会往person表中添加进一条记录,在实际应用中,语句中的“测试数据”这些

参数值会由用户输入界面提供,如果把用户输入的内容原样组拼到上面的insert语句,当用户输入的内容含有单引号时,组拼出来的SQL语句就会存在语法错误。要解决这个问题需要对单引号进行转义,也就是把单引号转换成两个单引号。有些时候用户往往还会输入像“&”这些特殊SQL符号,为保证组拼好的SQL语句语法正确,必须对SQL语句中的这些特殊SQL符号都进行转义,显然,对每条SQL语句都做这样的处理工作是比较烦琐的。SQLiteDatabase类提供了一个重载后的execSQL(String sql,Object[]bindArgs)方法,使用这个方法可以解决前面提到的问题,因为这个方法支持使用占位符参数(?)。使用例子如下:

8.SQLiteDatabase db=....;

9.db.execSQL("insert into person(name,age)values(?,?)",new Object[]{"测试数

据",4});

10.db.close();

11.execSQL(String sql,Object[]bindArgs)方法的第一个参数为SQL语句,第二个参数为SQL

语句中占位符参数的值,参数值在数组中的顺序要和占位符的位置对应。

12.*/

view plaincopy to clipboardprint?

1.public class DatabaseHelper extends SQLiteOpenHelper{

2.//类没有实例化,是不能用作父类构造器的参数,必须声明为静态

3.private static final String name="itcast";//数据库名称

4.private static final int version=1;//数据库版本

5.public DatabaseHelper(Context context){

6.//第三个参数CursorFactory指定在执行查询时获得一个游标实例的工厂类,设置为null,代表

使用系统默认的工厂类

7.super(context,name,null,version);

8.}

9.@Override public void onCreate(SQLiteDatabase db){

10.db.execSQL("CREATE TABLE IF NOT EXISTS person(personid intege

r primary key autoincrement,name varchar(20),age INTEGER)");

11.}

12.@Override public void onUpgrade(SQLiteDatabase db,int oldVersion,i

nt newVersion){

13.db.execSQL("ALTER TABLE person ADD phone VARCHAR(12)NULL");

//往表中增加一列

14.//DROP TABLE IF EXISTS person删除表

15.}

16.}

17.//在实际项目开发中,当数据库表结构发生更新时,应该避免用户存放于数//据库中的数据丢

失。

view plaincopy to clipboardprint?

1./*

2.Android提供了一个名为SQLiteDatabase的类,该类封装了一些操作数据库的API,使用该类

可以完成对数据进行添加(Create)、查询(Retrieve)、更新(Update)和删除(Delete)操作(这些操作简称为CRUD)。对SQLiteDatabase的学习,我们应该重点掌握execSQL()和rawQuery()方法。execSQL()方法可以执行insert、delete、update和CREATE TABLE之类有更改行为的SQL语句;rawQuery()方法用于执行select语句。

3.execSQL()方法的使用例子:

4.SQLiteDatabase db=....;

5.db.execSQL("insert into person(name,age)values('测试数据',4)");

6.db.close();

7.执行上面SQL语句会往person表中添加进一条记录,在实际应用中,语句中的“测试数据”这些

参数值会由用户输入界面提供,如果把用户输入的内容原样组拼到上面的insert语句,当用户输入的内容含有单引号时,组拼出来的SQL语句就会存在语法错误。要解决这个问题需要对单引号进行转义,也就是把单引号转换成两个单引号。有些时候用户往往还会输入像“&”这些特殊

SQL符号,为保证组拼好的SQL语句语法正确,必须对SQL语句中的这些特殊SQL符号都进行转义,显然,对每条SQL语句都做这样的处理工作是比较烦琐的。SQLiteDatabase类提供了一个重载后的execSQL(String sql,Object[]bindArgs)方法,使用这个方法可以解决前面提到的问题,因为这个方法支持使用占位符参数(?)。使用例子如下:

8.SQLiteDatabase db=....;

9.db.execSQL("insert into person(name,age)values(?,?)",new Object[]{"测试数

据",4});

10.db.close();

11.execSQL(String sql,Object[]bindArgs)方法的第一个参数为SQL语句,第二个参数为SQL

语句中占位符参数的值,参数值在数组中的顺序要和占位符的位置对应。

12.*/

view plaincopy to clipboardprint?

1./*

2.SQLiteDatabase的rawQuery()用于执行select语句,使用例子如下:

SQLiteDatabase db=....;

3.Cursor cursor=db.rawQuery(“select*from person”,null);

4.while(cursor.moveToNext()){

5.int personid=cursor.getInt(0);//获取第一列的值,第一列的索引从0开始

6.String name=cursor.getString(1);//获取第二列的值

7.int age=cursor.getInt(2);//获取第三列的值

8.}

9.cursor.close();

10.db.close();

11.rawQuery()方法的第一个参数为select语句;第二个参数为select语句中占位符参数的值,

如果select语句没有使用占位符,该参数可以设置为null。带占位符参数的select语句使用例子如下:

12.Cursor cursor=db.rawQuery("select*from person where name like?and age=?

",new String[]{"%传智%","4"});

13.Cursor是结果集游标,用于对结果集进行随机访问,如果大家熟悉jdbc,其实Cursor与JDBC

中的ResultSet作用很相似。使用moveToNext()方法可以将游标从当前行移动到下一行,如果已经移过了结果集的最后一行,返回结果为false,否则为true。另外Cursor还有常用的

moveToPrevious()方法(用于将游标从当前行移动到上一行,如果已经移过了结果集的第一行,返回值为false,否则为true)、moveToFirst()方法(用于将游标移动到结果集的第一行,如果结果集为空,返回值为false,否则为true)和moveToLast()方法(用于将游标移动到

结果集的最后一行,如果结果集为空,返回值为false,否则为true)。

14.

15.*/

view plaincopy to clipboardprint?

1./*

2.除了前面给大家介绍的execSQL()和rawQuery()方法,SQLiteDatabase还专门提供了对应于

添加、删除、更新、查询的操作方法:insert()、delete()、update()和query()。这些方法实际上是给那些不太了解SQL语法的菜鸟使用的,对于熟悉SQL语法的程序员而言,直接使用execSQL()和rawQuery()方法执行SQL语句就能完成数据的添加、删除、更新、查询操作。

3.Insert()方法用于添加数据,各个字段的数据使用ContentValues进行存放。ContentValues

类似于MAP,相对于MAP,它提供了存取数据对应的put(String key,Xxx value)和

getAsXxx(String key)方法,key为字段名称,value为字段值,Xxx指的是各种常用的数

据类型,如:String、Integer等。

4.SQLiteDatabase db=databaseHelper.getWritableDatabase();

5.ContentValues values=new ContentValues();

6.values.put("name","测试数据");

7.values.put("age",4);

8.long rowid=db.insert(“person”,null,values);//返回新添记录的行号,与主键id无

9.不管第三个参数是否包含数据,执行Insert()方法必然会添加一条记录,如果第三个参数为空,

会添加一条除主键之外其他字段值为Null的记录。Insert()方法内部实际上通过构造

insert SQL语句完成数据的添加,Insert()方法的第二个参数用于指定空值字段的名称,相信大家对该参数会感到疑惑,该参数的作用是什么?是这样的:如果第三个参数values为Null

或者元素个数为0,由于Insert()方法要求必须添加一条除了主键之外其它字段为Null值的

记录,为了满足SQL语法的需要,insert语句必须给定一个字段名,如:

insert into person(name)values(NULL),倘若不给定字段名,insert语句就成了这

样:insert into person()values(),显然这不满足标准SQL的语法。对于字段名,建议使用主键之外的字段,如果使用了INTEGER类型的主键字段,执行类似

insert into person(personid)values(NULL)的insert语句后,该主键字段值也不会为

NULL。如果第三个参数values不为Null并且元素的个数大于0,可以把第二个参数设置为

null。

10.*/

view plaincopy to clipboardprint?

1./*

2.delete()方法的使用:

3.SQLiteDatabase db=databaseHelper.getWritableDatabase();

4.db.delete("person","personid

5.db.close();

6.上面代码用于从person表中删除personid小于2的记录。

7.update()方法的使用:

8.SQLiteDatabase db=databaseHelper.getWritableDatabase();

9.ContentValues values=new ContentValues();

10.values.put(“name”,“测试数据”);//key为字段名,value为值

11.db.update("person",values,"personid=?",new String[]{"1"});

12.db.close();

13.上面代码用于把person表中personid等于1的记录的name字段的值改为“测试数据”。

14.

15.*/

view plaincopy to clipboardprint?

1./*

2.query()方法实际上是把select语句拆分成了若干个组成部分,然后作为方法的输入参数:

3.SQLiteDatabase db=databaseHelper.getWritableDatabase();

4.Cursor cursor=db.query("person",new String[]{"personid,name,age"},"name

like?",new String[]{"%传智%"},null,null,"personid desc","1,2");

5.while(cursor.moveToNext()){

6.int personid=cursor.getInt(0);//获取第一列的值,第一列的索引从0开始

7.String name=cursor.getString(1);//获取第二列的值

8.int age=cursor.getInt(2);//获取第三列的值

9.}

10.cursor.close();

11.db.close();

12.上面代码用于从person表中查找name字段含有“传智”的记录,匹配的记录按personid降序排

序,对排序后的结果略过第一条记录,只获取2条记录。

13.query(table,columns,selection,selectionArgs,groupBy,having,orderBy,li

mit)方法各参数的含义:

14.table:表名。相当于select语句from关键字后面的部分。如果是多表联合查询,可以用逗号

将两个表名分开。

15.columns:要查询出来的列名。相当于select语句select关键字后面的部分。

16.selection:查询条件子句,相当于select语句where关键字后面的部分,在条件子句允许使

用占位符“?”

17.selectionArgs:对应于selection语句中占位符的值,值在数组中的位置与占位符在语句中的

位置必须一致,否则就会有异常。

18.groupBy:相当于select语句group by关键字后面的部分

19.having:相当于select语句having关键字后面的部分

20.orderBy:相当于select语句order by关键字后面的部分,如:personid desc,age asc;

21.limit:指定偏移量和获取的记录数,相当于select语句limit关键字后面的部分。

22.*/

view plaincopy to clipboardprint?

1.package com.zyq.db;

2.import android.app.Activity;

3.import android.os.Bundle;

4.public class MainActivity extends Activity

5.{

6.@Override

7.public void onCreate(Bundle savedInstanceState)

8.{

9.super.onCreate(savedInstanceState);

10.setContentView(https://www.wendangku.net/doc/927321740.html,yout.main);

11.}

12.}

view plaincopy to clipboardprint?

1.package com.zyq.db;

2.import java.util.List;

3.import android.test.AndroidTestCase;

4.import android.util.Log;

5.import com.zyq.service.DBOpenHelper;

6.import com.zyq.service.PersonService;

7.import com.zyq.voo.Person;

8.

9./**

10.*测试方法通过Junit单元测试

11.*1.>实例化测试类

12.*2.>把与应用有关的上下文信息传入到测试类实例

13.*3.>运行测试方法

14.*@author Administrator

15.*

16.*/

17.public class PersonServiceTest extends AndroidTestCase

18.{

19.private final static String TAG="PersonServiceTest";

20.

21./**

22.*测试创建数据库

23.*@throws Throwable

24.*/

25.public void testCreateDB()throws Throwable

26.{

27.DBOpenHelper dbOpenHelper=new DBOpenHelper(this.getContext());

28.dbOpenHelper.getReadableDatabase();//Create and/or open a database.

29.}

30./**

31.*测试新增一条记录

32.*@throws Throwable

33.*/

34.public void testSave()throws Throwable

35.{

36.PersonService personService=new PersonService(this.getContext());

37.personService.save(new Person("zhangsan","1360215320"));

38.personService.save(new Person("lisi","1123"));

39.personService.save(new Person("lili","232"));

40.personService.save(new Person("wangda","123123"));

41.personService.save(new Person("laozhu","234532"));

42.}

43./**

44.*查找一条记录

45.*@throws Throwable

46.*/

47.public void testFind()throws Throwable

48.{

49.PersonService personService=new PersonService(this.getContext());

50.Person person=personService.find(1);

51.Log.i(TAG,person.toString());

52.}

53./**

54.*测试更新一条记录

55.*@throws Throwable

56.*/

57.public void testUpdate()throws Throwable

58.{

59.PersonService personService=new PersonService(this.getContext());

60.Person person=personService.find(1);

61.person.setName("lisi");

62.personService.update(person);

63.}

64./**

65.*测试得到所有记录数

66.*@throws Throwable

67.*/

68.public void testGetCount()throws Throwable

69.{

70.PersonService personService=new PersonService(this.getContext());

71.Log.i(TAG,personService.getCount()+"********");

72.}

73./**

74.*测试分页

75.*@throws Throwable

76.*/

77.public void testScroll()throws Throwable

78.{

79.PersonService personService=new PersonService(this.getContext());

80.Listpersons=personService.getScrollData(3,3);

81.for(Person person:persons)

82.{

83.Log.i(TAG,person.toString());

84.}

85.}

86./**

87.*测试删除一条记录

88.*@throws Throwable

89.*/

90.public void testDelete()throws Throwable

91.{

92.PersonService personService=new PersonService(this.getContext());

93.personService.delete(5);

94.}

95.}

view plaincopy to clipboardprint?

1.package com.zyq.service;

2.import android.content.Context;

3.import android.database.sqlite.SQLiteDatabase;

4.import android.database.sqlite.SQLiteOpenHelper;

5.public class DBOpenHelper extends SQLiteOpenHelper

6.{

7./**

8.*如果想额外的增加一个字段(需求)

9.*可以把版本号更改掉但必须>=1

10.*更改版本号之后会根据版本号判断是不是上次创建的时候(目前的版本号和传入的版

本号是否一致)

11.*如果不是会执行onUpgrade()方法

12.*@param context

13.*/

14.public DBOpenHelper(Context context)

15.{

16.super(context,"zyq.db",null,2);

17.}

18./**

19.*在数据库创建的时候第一个调用的方法

20.*适合创建表结构

21.*/

22.@Override

23.public void onCreate(SQLiteDatabase db)

24.{

25.db.execSQL("CREATE TABLE person(personid integer primary key autoin

crement,name varchar(20))");//创建表

26.}

27./**

28.*更新表结构在数据库版本号发生改变的时候调用

29.*应用升级

30.*/

31.@Override

32.public void onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion)

33.{

34.db.execSQL("ALTER TABLE person ADD phone VARCHAR(12)NULL");//往表

中增加一列

35.}

36.}

view plaincopy to clipboardprint?

1.

2.

3.package="com.zyq.db"

4.android:versionCode="1"

5.android:versionName="1.0">

6.

7.

8.

9.android:label="@string/app_name">

10.

11.

12.

13.

14.

15.

16.

17.

18.android:targetPackage="com.zyq.db"android:label="Tests for My App"

/>

19.

view plaincopy to clipboardprint?

1.package com.zyq.service;

2.import java.util.ArrayList;

3.import java.util.List;

4.import android.content.Context;

5.import android.database.Cursor;

6.import android.database.sqlite.SQLiteDatabase;

7.import com.zyq.voo.Person;

8.public class PersonService

9.{

10.private DBOpenHelper helper;

11.public PersonService(Context context)

12.{

13.helper=new DBOpenHelper(context);

14.}

15./**

16.*新增一条记录

17.*@param person

18.*/

19.public void save(Person person)

20.{

21.SQLiteDatabase db=helper.getWritableDatabase();//Create and/or open

a database that will be used for reading and writing

22.db.execSQL("INSERT INTO person(name,phone)values(?,?)",new Object[]

{person.getName().trim(),person.getPhone().trim()});//使用占位符进行转译

23.//db.close();不关数据库连接。可以提高性能因为创建数据库的时候的操作模式

是私有的。

24.//代表此数据库,只能被本应用所访问单用户

的,可以维持长久的链接

25.}

26./**

27.*更新某一条记录

28.*@param person

29.*/

30.public void update(Person person)

31.{

32.SQLiteDatabase db=helper.getWritableDatabase();

33.db.execSQL("update person set phone=?,name=?where personid=?",

34.new Object[]{person.getPhone().trim(),person.getName().t

rim(),person.getId()});

35.}

36./**

37.*根据ID查询某条记录

38.*@param id

39.*@return

40.*/

41.public Person find(Integer id)

42.{

43.SQLiteDatabase db=helper.getReadableDatabase();

44.Cursor cursor=db.rawQuery("select*from person where personid=?",n

ew String[]{id.toString()});//Cursor游标和ResultSet很像

45.if(cursor.moveToFirst())//Move the cursor to the first row.This met

hod will return false if the cursor is empty.

46.{

47.int personid=cursor.getInt(cursor.getColumnIndex("personid"));

49.String phone=cursor.getString(cursor.getColumnIndex("phone"));

50.

51.return new Person(personid,name,phone);

52.}

53.return null;

54.}

55./**

56.*删除某一条记录

57.*@param id

58.*/

59.public void delete(Integer id)

60.{

61.SQLiteDatabase db=helper.getWritableDatabase();

62.db.execSQL("delete from person where personid=?",

63.new Object[]{id});

64.}

65.

66./**

67.*得到记录数

68.*@return

69.*/

70.public long getCount()

71.{

72.SQLiteDatabase db=helper.getReadableDatabase();

73.Cursor cursor=db.rawQuery("select count(*)from person",null);

74.cursor.moveToFirst();

75.return cursor.getLong(0);

76.}

77./**

78.*分页查询方法SQL语句跟MySQL的语法一样

79.*@return

80.*/

81.public ListgetScrollData(int offset,int maxResult)

82.{

83.Listpersons=new ArrayList();

84.SQLiteDatabase db=helper.getReadableDatabase();

85.Cursor cursor=db.rawQuery("select*from person limit?,?",

86.new String[]{String.valueOf(offset),Stri

ng.valueOf(maxResult)});

87.while(cursor.moveToNext())

88.{

89.int personid=cursor.getInt(cursor.getColumnIndex("personid"));

90.String name=cursor.getString(cursor.getColumnIndex("name"));

92.

93.persons.add(new Person(personid,name,phone));

94.}

95.

96.return persons;

97.}

98.}

view plaincopy to clipboardprint?

1.package com.zyq.voo;

2.public class Person

3.{

4.private Integer id;

5.private String name;

6.private String phone;

7.

8.public Person(int personid,String name,String phone)

9.{

10.this.id=personid;

https://www.wendangku.net/doc/927321740.html,=name;

12.this.phone=phone;

13.}

14.

15.public Person(String name,String phone)

16.{

https://www.wendangku.net/doc/927321740.html,=name;

18.this.phone=phone;

19.}

20.public String toString()

21.{

22.return"Person[id="+id+",name="+name+",phone="+phone+

"]";

23.}

24.public Integer getId()

25.{

26.return id;

27.}

28.public void setId(Integer id)

29.{

30.this.id=id;

31.}

32.public String getName()

33.{

34.return name;

35.}

36.public void setName(String name)

37.{

https://www.wendangku.net/doc/927321740.html,=name;

39.}

40.public String getPhone()

41.{

42.return phone;

43.}

44.public void setPhone(String phone)

45.{

46.this.phone=phone;

47.}

48.

49.

50.

51.}

sqlite3常用命令及语法

https://www.wendangku.net/doc/927321740.html,/linchunhua/article/details/7184439 sqlite数据库只用一个文件就ok,小巧方便,所以是一个非常不错的嵌入式数据库,SQLite 大量的被用于手机,PDA,MP3播放器以及机顶盒设备。 Mozilla Firefox使用SQLite作为数据库。 Mac计算机中的包含了多份SQLite的拷贝,用于不同的应用。 PHP将SQLite作为内置的数据库。 Skype客户端软件在内部使用SQLite。 SymbianOS(智能手机操作平台的领航)内置SQLite。 AOL邮件客户端绑定了SQLite。 Solaris 10在启动过程中需要使用SQLite。 McAfee杀毒软件使用SQLite。 iPhones使用SQLite。 Symbian和Apple以外的很多手机生产厂商使用SQLite。 下面就sqlite中的常用命令和语法介绍 https://www.wendangku.net/doc/927321740.html,/download.html可下载不同操作系统的相关版本sqlite gedit 也可以使用火狐中的插件sqlite manager 新建数据库 sqlite3 databasefilename 检查databasefilename是否存在,如果不存在就创建并进入数据库(如果直接退出,数据库文件不会创建)如果已经存在直接进入数据库对数据库进行操作 sqlite中命令: 以.开头,大小写敏感(数据库对象名称是大小写不敏感的) .exit .help 查看帮助针对命令 .database 显示数据库信息;包含当前数据库的位置 .tables 或者.table 显示表名称没有表则不显示 .schema 命令可以查看创建数据对象时的SQL命令; .schema databaseobjectname查看创建该数据库对象时的SQL的命令;如果没有这个数据库对象就不显示内容,不会有错误提示 .read FILENAME 执行指定文件中的SQL语句 .headers on/off 显示表头默认off .mode list|column|insert|line|tabs|tcl|csv 改变输出格式,具体如下 sqlite> .mode list sqlite> select * from emp; 7369|SMITH|CLERK|7902|17-12-1980|800||20 7499|ALLEN|SALESMAN|7698|20-02-1981|1600|300|30 如果字段值为NULL 默认不显示也就是显示空字符串

sqlite3数据库使用实例

SQLite version 3.7.9 2011-11-01 00:52:41 Enter ".help" for instructions Enter SQL statements terminated with a ";" sqlite> create table students( ...> id integer primary key, ...> name text not null unique, ...> sex int default 1, ...> bak text); sqlite> .tables students sqlite> .help .backup ?DB? FILE Backup DB (default "main") to FILE .bail ON|OFF Stop after hitting an error. Default OFF .databases List names and files of attached databases .dump ?TABLE? ... Dump the database in an SQL text format If TABLE specified, only dump tables matching LIKE pattern TABLE. .echo ON|OFF Turn command echo on or off .exit Exit this program .explain ?ON|OFF? Turn output mode suitable for EXPLAIN on or off. With no args, it turns EXPLAIN on. .header(s) ON|OFF Turn display of headers on or off .help Show this message .import FILE TABLE Import data from FILE into TABLE .indices ?TABLE? Show names of all indices If TABLE specified, only show indices for tables matching LIKE pattern TABLE. .load FILE ?ENTRY? Load an extension library .log FILE|off Turn logging on or off. FILE can be stderr/stdout .mode MODE ?TABLE? Set output mode where MODE is one of: csv Comma-separated values column Left-aligned columns. (See .width) html HTML

code insert SQL insert statements for TABLE line One value per line list Values delimited by .separator string tabs Tab-separated values tcl TCL list elements .nullvalue STRING Print STRING in place of NULL values .output FILENAME Send output to FILENAME .output stdout Send output to the screen .prompt MAIN CONTINUE Replace the standard prompts .quit Exit this program .read FILENAME Execute SQL in FILENAME

浅谈嵌入式SQLITE数据库实现与应用

开源(Opensource):这是它最强大的地方。开源,意味着你可以品读它的源码,你可以随时修改它,加入你自己的特性,而这一切完全免费的。开源,是一种精神。 实现部分 好了,现在从实现的角度来谈谈个人体会,这也是我比较关注的。 SQLite是一款优秀的嵌入式数据库管理系统,这里有两层含义:一是它经常作为动态库嵌入到应用程序; 另外一方面它通常用于嵌入式设备或其它要求较低的桌面应用。如果把它作为内存数据库,个人觉得不是很适合。毕竟,它的写并发性不是很好,此时,TimesTen也许会更好,Berkey DB也许是一个不错的选择。SQLite这样的嵌入式数据库与主存数据库的应用场景、实现以及对资源的需求都是不一样的。 (1)事务处理 事务的核心问题有两个:并发控制和恢复。解决了并发控制和恢复问题的系统,就能允许它的用户假设程序是原子的(atomically)执行的——好像没有其它的程序同时执行;而且是可靠的(reliably)——不会产生失败。原子性和可靠性的抽象,则称为事务(transaction)。其实,事务并不是DBMS的专利,任何分布式系统,都面对并发和恢复问题,而解决的方法就是事务,只不过,我们更常听到DBMS中的事务。 并发控制保证事务的原子执行,它使得交错执行的事务看起来是一个接一个的顺序执行的,完全没有交错执行。如果交错执行的结果与顺序执行的结果一致,则称为串行化(serializable)。 恢复使得数据库仅仅包含那些正常完成的事务的结果。如果事务在执行的过程中发生错误,不能继续进行,恢复算法必须清除部分完成事务产生的影响。 ?并发控制 SQLite只支持库级锁,库级锁意味着什么?——意味着同时只能允许一个写操作,也就是说,即事务T1在A表插入一条数据,事务T2在B表中插入一条数据,这两个操作不能同时进行,即使你的机器有100个CPU,也无法同时进行,而只能顺序进行。表级都不能并行,更别说元组级了——这就是库级锁。但是,SQLite尽量延迟申请X锁,直到数据块真正写盘时才申请X锁,这是非常巧妙而有效的。 ?恢复 SQLite的恢复技术是影子分页技术(shadow paging)技术的典型代表。 DBMS的常用恢复技术有影子分页技术与基于日志的技术,前者在早其数据库管理系统中用到,比如Sys tem R,现代DBMS中已经很难见到它的身影了。 影子分页技术与基于日志技术相比,优点是实现简单,消除了写日志记录的开销,恢复的速度也快(不需要redo和undo)。影子分页的缺点就是事务提交时要输出多个块,这使得提交的开销很大,而且以块为单位,很难应用到允许多个事务并发执行的情况——这是它致命的缺点。 (2)查询处理 SQLite的查询处理本质上就是一个SQL编译器和一个虚拟机。而实现这些功能只用了十多个文件,整个实现实现简单而有效,但是也存在一些问题。首先,SQLite字典数据很简单,实际上它的字典就一个表s qlite_mater,所有的信息都是通过对sqlite_master中SQL语句进行解析获取的,而解析一个SQL语句,都需要进行词法分析、语法分析、甚至虚拟机代码的生成。而这一过程是很需要时间的,而且,查询计划也没有重用。其次,查询优化还比较简单,特别是连接操作,只通过循环来做(MySQL也一样)。但是,仅仅数万代码,我们不能对它要求太苛求。 (3)存储模型

SQLITE3的操作方法及应用

数据库的操作 我们在这个项目中使用的是SQLITE3数据库软件。 通过使用SQLITE3进行创建数据库,创建表,插入记录,查询记录,更新记录,关闭数据库等操作来实现将相应的数据存入数据库中。 1.打开数据库,创建表 1.1sqlite*db;定义一个sqlite*的变量 sqlite3_open(“./link.db”,&db); 在当前目录下打开一个名为link.db的数据库,若是没有则在当前目录下创建一个名为link.db 的数据库。 1.2sql="create table weblink(id integer primary key,domain text,page text,fromdomain text,status integer);" 在已打开的数据库中创建一个名weblink的表。表的属性如下: id integer primary key:ID号(表中黙认包含的) domain text:域名 page text:子网页 fromdomain text:源域名 status integer:状态标志 1.3sqlite3_exec(db,sql,NULL,NULL,NULL); 执行一条sql语句的函数。 函数原型:int sqlite3_exec(sqlite3*,const char*sql,sqlite3_callback,void*,char**errmsg) 第1个参数是前面open函数得到的指针。说了是关键数据结构。 第2个参数const char*sql是一条sql语句,以\0结尾。 第3个参数sqlite3_callback是回调,当这条语句执行之后,sqlite3会去调用你提供的这个函数。(什么是回调函数,自己找别的资料学习) 第4个参数void*是你所提供的指针,你可以传递任何一个指针参数到这里,这个参数最终会传到回调函数里面,如果不需要传递指针给回调函数,可以填NULL。等下我们再看回调函数的写法,以及这个参数的使用。 第5个参数char**errmsg是错误信息。注意是指针的指针。sqlite3里面有很多固定的错误信息。执行sqlite3_exec之后,执行失败时可以查阅这个指针(直接printf(“%s\n”,errmsg))得到一串字符串信息,这串信息告诉你错在什么地方。sqlite3_exec函数通过修改你传入的指针的指针,把你提供的指针指向错误提示信息,这样sqlite3_exec函数外面就可以通过这个char*得到具体错误提示。 说明:通常,sqlite3_callback和它后面的void*这两个位置都可以填NULL。填NULL表

Qt4访问sqlite数据库

目录 Qt4访问sqlite数据库 (2) RedHat 9 Linux下在QT3.1中连接SQLite3全过程详细记录 (6) 基于ARM-Linux的SQLite嵌入式数据库技术 (17) 关于在qt中如何连接sqlite3数据库的问题 (23) SQLite 完整中文FAQ (32) C/C++中调用SQLITE3的基本步骤 (40) SQLite嵌入式数据库系统的研究与实现 (50)

Qt4访问sqlite数据库 https://www.wendangku.net/doc/927321740.html,/index.php/2008/09/qt-sqlite/ sqlite简介 sqlite 是一款轻量级的、基于文件的嵌入式数据库,2000年就已经诞生,经过7年多的发展,直到今天已经成为最流行的嵌入式数据库,包括google在内的公司在其桌面软件中亦使用sqlite 存储用户数据。由此可以看出,已经没有任何理由去怀疑sqlite的稳定性了。 sqlite的优势 1. 免配置,和access一样,只要把数据库文件通过ftp上传到服务器上就可以使用,不需要服务器的额外支持 2. 备份方便,因为只是一个文件,只要复制一份该文件,就能备份整个数据库 3. 虽然是轻量级数据库,但他支持最大2tb 的单个库文件。 4. 快,无与伦比的快。经过实际测试,在几百万记录的情况下,sqlite的插入和查询速度和mysql 不分上下,快于sql server,10倍于access (但这并不意味着它可以替代sql server ) 用QT操作sqlite 由于sqlite属于轻量级的数据库,不需要配置,不需要安装,也不需要管理员,所以也就没必要像操作mysql等数据库一样的设置主机,用户和密码了。样例如下: 1 2 3 4 5 6 7 8 9 10 11 12 #include #include #include #include #include #include

sqlite 基本操作 全

sqlite3本地数据库学习 sqlite3只是一个轻型的嵌入式数据库引擎,占用资源非常低,处理速度比mysql还快,专门用于移动设备上进行适量的数据存取,它只是个文件,不需要服务器进程。 常用术语:表(table)、字段(colum,列,属性)、记录(row,record) 关键字:select、insert、updete、delete、from、creat、where、desc、order、by、group、table、alter、view、index等。 1、安装sqlite3 sudo()apt-get()install()sqlite3 2、存储类型 integer 整型:int,shoert,long text 文本字符串:string real 浮点型:float,double blob 二进制 3、字段结束 not null:字段的值不能为空 unique:字段的值必须是唯一的 default:指定字段的默认值 primarykey:主键,用来唯一的标识某条记录,相当于记录的身份证。主键可以是一个或多个字段,应由计算机自动生成和管理。主键字段默认包含了not null和unique两个约束。 autoincrement:当主键是integer类型时,应该增加autoincrement约束,能实现主键值的自动增长。 外键:利用外键可以用来建立表与表之间的联系,一般是一张表的某个字段,引用着另一张表的主键。 4、创建数据库usr.db在当前目录下 sqlite3()usr.db 5、创建表格,表格内容以树状存储 create()table()表名(字段名1()字段类型1,字段名2()字段类型2...) 6、数据库中不能使用关键字命名表和字段,不区分大小写,每条语句后加";"结尾 7、删除表格 drop()table()表名 8、向表格里添加数据 insert()into()表名(字段1,字段2...)values(字段1的值,字段2的值...) 8、修改表中的数据 updata()表名()set()字段1=字段1的值,字段2=字段2的值... //将字段为name全部修改成'Tom' updata()stu()set()name='Tom'; //将字段为id=1001的字段name修改成'Tom' updata()stu()set()name='Tom'()where()id=1001; //将字段为id=1001同时字段name='lisi'的字段name修改成'Tom' updata()stu()set()name='Tom'()where()id=1001()and()name='lisi'; 9、删除表中的数据

嵌入式系统技术报告(题目 SQLITE数据库的概述和使用)

合肥学院 嵌入式系统设计课程 技术报告 (2014-2015第2学期) 报告题目:SQLite数据库概述和使用专业:自动化 班级:级自动化卓越班 姓名: 指导老师:干开峰

摘要 自几十年前出现的商业应用程序以来,数据库就成为软件应用程序的主要组成部分。正与数据库管理系统非常关键一样,它们也变的非常庞大,并占用相当多的系统资源。嵌入式数据库直接在应用程序进程中运行,提供了零配置运行模式,并且资源占用非常少。作为一个开源的嵌入式数据库产品,SQLite具有系统开销小,检索效率高的特性,嵌入式数据库无须独立运行的数据库引擎,它是由程序直接调用相应的API去实现对数据的存取操作。更直白的讲,嵌入式数据库是一种具备了基本数据库特性的数据文件。嵌入式数据库与其它数据库产品的区别是,前者是程序驱动式,而后者是引擎响应式。嵌入式数据库的一个很重要的特点是体积非常小,同时,很多嵌入式数据库在性能上也优于其它数据库,所以在高性能的应用上也常见嵌入式数据库的身影。SQLite是D·理查德·希普开发出来的用一个小型C库实现的一种强有力的嵌入式关系数据库管理体制。SQLite虽然很小巧,但是支持的SQL语句不会逊色于其他开源数据库。 关键词:SQLite;嵌入式;数据库

目录 1SQLite简介 (1) 2SQLite工作原理 (1) 3SQLite的功能特性 (2) 4SQLite的结构 (2) 5SQLite的使用 (4) 5.1SQLite里面的一些基本的操作: (4) 5.2SQLite的一些类的使用及说明: (5) 5.3SQLite嵌入式数据库使用注意: (10) 6总结 (11)

sqlite命令

Sqlite命令操作 建立数据库档案 用sqlite3建立数据库的方法很简单,只要在shell下键入(以下$符号为shell 提示号,请勿键入): $ sqlite3 foo.db 如果目录下没有foo.db,sqlite3就会建立这个数据库。sqlite3并没有强制数据库档名要怎么取,如果你喜欢,也可以取个foo.icannameitwhateverilike 的档名。 在sqlite3提示列下操作 进入了sqlite3之后,会看到以下文字: SQLite version 3.1.3 Enter ".help" for instructions sqlite> 这时如果使用.help可以取得求助,.quit则是离开(请注意:不是quit) SQL的指令格式 所以的SQL指令都是以分号(;)结尾的。如果遇到两个减号(--)则代表注解,sqlite3会略过去。 建立资料表 假设我们要建一个名叫film的资料表,只要键入以下指令就可以了:

create table film(title, length, year, starring); 这样我们就建立了一个名叫film的资料表,里面有name、length、year、starring 四个字段。 这个create table指令的语法为: create table table_name(field1, field2, field3, ...); table_name是资料表的名称,fieldx则是字段的名字。sqlite3与许多SQL数据库软件不同的是,它不在乎字段属于哪一种资料型态:sqlite3的字段可以储存任何东西:文字、数字、大量文字(blub),它会在适时自动转换。 建立索引 如果资料表有相当多的资料,我们便会建立索引来加快速度。好比说: create index film_title_index on film(title); 意思是针对film资料表的name字段,建立一个名叫film_name_index的索引。这个指令的语法为 create index index_name on table_name(field_to_be_indexed); 一旦建立了索引,sqlite3会在针对该字段作查询时,自动使用该索引。这一切的操作都是在幕后自动发生的,无须使用者特别指令。 加入一笔资料 接下来我们要加入资料了,加入的方法为使用insert into指令,语法为:insert into table_name values(data1, data2, data3, ...); 例如我们可以加入

SQLITE最基本操作

SQLite数据库的基本操作 main.xml(主布局)

android:orientation="vertical">

SQLite 数据库文件分析

SQLite数据库文件分析 前言 性急的兄弟可以跳过前言直接看第1章,特别性急的兄弟可以跳过前面各章,直接看鸣谢。最近对SQLite数据库很感兴趣,认真地学了有半个多月了,越学越觉着好玩。好玩归好玩,只是目前没什么实际用途,那就写点儿东西吧,否则半个月不是白学了嘛! SQLite数据库包括多方面的知识,比如VDBE什么的。据说那些东西会经常变。确实,我用的是3.6.18版,我看跟其它文档中描述的3.3.6的VDBE已经很不一样了。所以决定先写文件格式,只要是3.?.?的版本,文件格式应该不会有太大变化吧。 网上介绍SQLite文件格式的文章并不少,但一般都是针对小文件:一个表,几条记录,两个页。本文准备一直分析到比较大的文件,至少B-tree和B+tree中得有内结点(就是说不能只有一个既是根又是叶的结点,就是说表中得多点记录,得建索引),还要争取对SQLite 的各类页都做出分析。 在分析的过程中,争取把SQLite数据库关于文件格式的基本规定也都介绍一下。这样,本文既是一个综合性的技术文档,又带有实例说明,兄弟们参考时岂不是就很方便了吗?既然是技术文档,要想读懂总得先掌握点SQLite数据库的基本知识吧。所以,先介绍参考文献。 0.1 参考文献 1-The Definitive Guide to SQLite . Michael Owens:据说是比较经典的SQLite著作,我看写得是挺好的。边看边翻译了其中的主要部分,但不敢拿出来,大家还是看原文吧。 2-SQLite源代码:其实有关SQLite的最原始说明可能都在源代码中了。把此项列在第2,只是因为我是先看的书再看的代码,估计大家也会是这个顺序吧。先浏览一下代码还是很有收获的,特别是几个主要的.h文件,对本文的写作很有帮助。有关文件格式的说明主要在btreeInt.h中。 3-SQLite入门与分析:网上Arrowcat的系列文章。Arrowcat应该是一个很博学的人,看他的文章收获很大,在此也算是鸣谢吧。 4-SQLite . Chris Newman:我没看,因为也是网上能够下载到的重要资源,所以也在此列出。看目录内容应该比参考文献1简单一些,但出版日期也更早了一些。 5-NULL:在网上搜了半天,国内为什么就没有关于SQLite的好书呢? 6- https://www.wendangku.net/doc/927321740.html,/fileformat.html:如果这篇文章看懂了,其实我这篇东西根本就不用再看了。这是介绍SQLite文件格式的权威文档,列在最后,是因为我也是写完这篇东西后才看到的。该文档由SQLite官方网站提供,当初没看,一是因为上网少,还没仔细浏览人家的网站就开始干了(太激动),其实归根结蒂还是因为英语不好。看到此文档这后还敢把我的东西发出来,有两个原因:一、为其他英语比我强不了多少的兄弟提供一点方便,二、我这里有例子,看起来更形象一些吧。

SQLite数据库中如何列出所有的表和索引

SQLite数据库中如何列出所有的表和索引 如果你运行sqlite3命令行来访问你的数据库,可以键入“.tables”来获得所有表的列表。或者,你可以输入“.schema” 来看整个数据库模式,包括所有的表的索引。输入这些命令,后面跟一个LIKE模式匹配可以限制显示的表。 在一个C/C++ 程序中(或者脚本语言使用Tcl/Ruby/Perl/Python 等)你可以在一个特殊的名叫SQLITE_MASTER上执行一个SELECT查询以获得所有表的索引。每一个SQLite 数据库都有一个叫SQLITE_MASTER 的表,它定义数据库的模式。 SQLITE_MASTER 表看起来如下: CREATE TABLE sqlite_master ( type TEXT, name TEXT, tbl_name TEXT, rootpage INTEGER, sql TEXT ); 对于表来说,type字段永远是'table',name字段永远是表的名字。所以,要获得数据库中所有表的列表,使用下列SELECT语句: SELECT name FROM sqlite_master WHERE type='table' ORDER BY name; 对于索引,type等于'index', name则是索引的名字,tbl_name是该索引所属的表的名字。不管是表还是索引,sql字段是原先用CREATE TABLE 或CREATE INDEX 语句创建它们时的命令文本。对于自动创建的索引(用来实现PRIMARY KEY 或UNIQUE 约束),sql字段为NULL。 SQLITE_MASTER 表是只读的。不能对它使用UPDATE、INSERT 或DELETE。它会被CREATE TABLE、CREATE INDEX、DROP TABLE 和DROP INDEX 命令自动更新。临时表不会出现在SQLITE_MASTER 表中。临时表及其索引和触发器存放在另外一个叫SQLITE_TEMP_MASTER 的表中。SQLITE_TEMP_MASTER 跟SQLITE_MASTER 差不多,但它只是对于创建那些临时表的应用可见。如果要获得所有表的列表,不管是永久的还是临时的,可以使用类似下面的命令:SELECT name FROM (SELECT * FROM sqlite_master UNION ALL SELECT * FROM sqlite_temp_master) WHERE type='table' ORDER BY name

浅谈SQLite

浅谈SQLite:实现与应用 1、前言 有一些日子没有仔细关注SQLite了,今天打开其主页,发现其最新的版本已经是3.6.22了,更让我惊喜的是它的用户越来越多,而且邮件列表的关注者也越来越多,突然觉得自己已经太old了。惊喜的同时,不得不聊上几句了。 首先,来看看都有哪些人在使用SQLite,主页上列举一长串NB的用户,其中不乏像Adobe,Apple,Firefox,甚至连google,Microsoft,SUN这样的用户。 Firefox:这是我的机器上V3.5.7安装目录下的文件: 可以发现用的SQLite 3.6.16.1。 据说,Google在它的Desktop for Mac,Google Gears,以及Android,甚至Chrome 中都用到SQLite,而且,Google的工程师对SQLite的全文检索功能作了很大的贡献(contribution)。还有Apple,Micorsoft,SUN等等,这里就不列举了。详细见 https://www.wendangku.net/doc/927321740.html,/famous.html。有这些公司的参与,对SQLite的发展应该有很大的帮助,尤其是像Google这样的用户。 2、实现与应用 下面从实现及应用的角度来谈谈SQLite,先看看SQLite的特点(功能)吧。 特点

简单(simple):SQLite是一个非常轻量级自包含(lightweight and self-contained)的DBMS:一个头文件,一个动态库文件,你就拥有了关系数据库的所有功能了。简单,是SQLite最明显的哲学。它提供的API少而简单。只需要一个DLL文件,你的程序马上就拥有了一个功能强大的数据库引擎,这是一件很美妙的事。 小巧(small):我用VS 2005在Windows下编译的3.6.11,Release版为368K,用时不到20秒——而编译MySQL时,要花上几分钟。而当我插入10000条int数据时,内存开销660K,磁盘开销92K。 事务(transaction):事务是现代商业数据处理系统最基本的要求,而Access,不论是在可执行文件大小(看了一下Access2003的可执行文件大小为6.32M,两者不是一个量级),还是事务特性,都是不能和SQLite 相比的。 并发性(Concurrency):由于SQLite通过OS的文件锁来实现库级锁,粒度很大,但是,它通过一些复杂特殊的处理(具体可以参见分析系列),尽量的提升了读写的并发度。如果你还有担心,你可以看看这篇文章: https://www.wendangku.net/doc/927321740.html,/database/sqlite_cms.html。 SQL92:SQLite支持绝大部分的标准SQL语句,你只需要几百K的空间,就可以换来需要上百兆的通用DBMS几乎所有操作了。 方便(Convenience):如果你的程序要使用SQLite,只需要将拷贝你的程序目录即可。 开源(Opensource):这是它最强大的地方。开源,意味着你可以品读它的源码,你可以随时修改它,加入你自己的特性,而这一切完全免费的。开源,是一种精神。 实现部分 好了,现在从实现的角度来谈谈个人体会,这也是我比较关注的。 SQLite是一款优秀的嵌入式数据库管理系统,这里有两层含义:一是它经常作为动态库嵌入到应用程序;另外一方面它通常用于嵌入式设备或其它要求较低的桌面应用。如果把它作为内存数据库,个人觉得不是很适合。毕竟,它的写并发性不是很好,此时,TimesTen

QSQLite 数据库

这里我们只是演示了一下使用这个框架完成最简单的程序的过程,只起到抛砖引玉的作用。这个框架很复杂,但是功能也很强大,Qt Creator中自带了几个相关的例子(在帮助中查找Graphics View Examples即可),你可以参考一下。因为篇幅问题,我们就只讲这么多,如果以后有机会,我会推出一个相关的专题来讲述这个框架。 分类:Qt系列教程作者: yafeilinux 日期:四月 30th, 2010. 3,006 views Tags: 2D绘图, creator, qt, yafeilinux, 教程

二十一、Qt数据库(一)简介 本文章原创于https://www.wendangku.net/doc/927321740.html,转载请注明出处。 从今天开始我们学习Qt数据库编程的内容。 先说明:我们以后使用现在最新的基于Qt 4.6.2的Qt Creator 1.3.1 Windows版本,该版本是2010年2月17日发布的。 数据库几乎是每个较大的软件所必须应用的,而在Qt中也使用QtSql模块实现了对数据库的完美支持。我们在Qt Creator的帮助中查找QtSql Module,其内容如下图: 可以看到这个模块是一组类的集合,使用这个模块我们需要加入头文件#include ,而在工程文件中需要加入一行代码:QT += sql 这里每个类的作用在后面都有简单的介绍,你也可以进入其中查看其详细内容。下面我们先简单的说一下QSqlDatabase类和QSqlQuery类。 QSqlDatabase类实现了数据库连接的操作,现在Qt支持的数据库类型有如下几种: 而现在我们使用的免费的Qt只提供了SQLite和ODBC数据库的驱动(我们可以在Qt Creator 安装目录下的qt\plugins\sqldrivers文件夹下查看),而其他数据库的驱动需要我们自己添加。SQLite是一个小巧的嵌入式数据库,关于它的介绍你可以自己在网上查找。 QSqlQuery类用来执行SQL语句。(关于SQL语句:在我的教程中只会出现很简单的SQL语句,你没有相关知识也可以看懂,但是如果想进行深入学习,就需要自己学习相关知识了。)

SQLite3 API使用大全

SQLite3API使用大全E-mail:18918737 (at) qq dot com,智有不明

前序: (1) 一、版本 (1) 二、基本编译 (2) 三、 SQLITE操作入门 (2) (1)基本流程 (2) (2) SQL语句操作 (4) (3)操作二进制 (8) (4)事务处理 (10) 四、给数据库加密 (10) 五、后记 (25) 前序: Sqlite3 的确很好用。小巧、速度快。但是因为非微软的产品,帮助文档总觉得不够。这些天再次研究它,又有一些收获,这里把我对 sqlite3 的研究列出来,以备忘记。 这里要注明,我是一个跨平台专注者,并不喜欢只用 windows 平台。我以前的工作就是为unix 平台写代码。下面我所写的东西,虽然没有验证,但是我已尽量不使用任何 windows 的东西,只使用标准 C 或标准C++。但是,我没有尝试过在别的系统、别的编译器下编译,因此下面的叙述如果不正确,则留待以后修改。 下面我的代码仍然用 VC 编写,因为我觉得VC是一个很不错的IDE,可以加快代码编写速度(例如配合 Vassist )。下面我所说的编译环境,是VC2003。如果读者觉得自己习惯于 unix 下用 vi 编写代码速度较快,可以不用管我的说明,只需要符合自己习惯即可,因为我用的是标准 C 或 C++ 。不会给任何人带来不便。 一、版本 从https://www.wendangku.net/doc/927321740.html,网站可下载到最新的 sqlite 代码和编译版本。我写此文章时,最新代码是 3.3.17 版本。 很久没有去下载 sqlite 新代码,因此也不知道 sqlite 变化这么大。以前很多文件,现在全部合并成一个 sqlite3.c 文件。如果单独用此文件,是挺好的,省去拷贝一堆文件还担心有没有遗漏。但是也带来一个问题:此文件太大,快接近7万行代码,VC开它整个机器都慢下来了。如果不需要改它代码,也就不需要打开 sqlite3.c 文件,机器不会慢。但是,下面我要写通过修改 sqlite 代码完成加密功能,那时候就比较痛苦了。如果个人水平较高,建议用些简单的编辑器来编辑,例如 UltraEdit 或 Notepad 。速度会快很多。 二、基本编译 这个不想多说了,在 VC 里新建 dos 控制台空白工程,把 sqlite3.c 和 sqlite3.h 添加到工程,再新建一个 main.cpp 文件。在里面写: extern "C" { #include "./sqlite3.h" }; int main( int , char** ) { return 0; }

SQLite数据库常用命令

SQLite数据库入门及常用命令 SQLite软件包中包含了一个名字叫做sqlite3的命令行,它可以让用户手工输入并执行面向SQLite数据库的SQL命令。本文档提供了一个较为详尽的关于sqlite3的使用说明。 启动sqlite3程序,仅仅需要敲入带有SQLite数据库名字的“sqlite3”命令即可。如果文件不存在,则创建一个新的数据库文件。然后,sqlite3程序将提示你输入SQL语句。敲入SQL语句,以分号“;”结束,敲击回车键后,SQL语句就会执行。 例如,创建一个包含一个表“tbl1”名称为“ex1”的SQLite数据库,你可以这样操作: 你可以通过敲击你所用系统的文件结束符(通常是Ctrl+D)或者中断字符(通常是Ctrl+C),来终止sqlite3程序。请记得在每个SQL语句结束后敲入分号!sqlite3程序通过查找分号来决定一个SQL语句是否结束。如果你省略分号,sqlite3将给你一个连续的命令行提示符并等你给当前的SQL命令添加更多的文字。这个特点很利于多行的SQL语句输入。 SQLite数据库的框架被保存在一个名叫“sqlite_master”的特殊表中。你可以像查询其他表一样通过执行“SELECT”语句查询这个特殊的表:

但是,我们不能在sqlite_master表中执行诸如DROP TABLE、UPDATE、INSERT或者DELETE之类的命令。Sqlite_master表在你创建、删除和索引数据库时自动更新这个表。我们不能手工地更改这个表。 temporary表的结构没有存储在“sqlite_master”表中,这是由于temporary表对应用是不可见的,而不是应用程序创建的。temporary表的结构是被存储在另外一个名叫“sqlite_temp_master”的特定表中。 sqlite3的特殊命令。大多数的时候,sqlite3读入用户输入的行,并把它们传递到SQLite库中去运行。但是,如果用户输入的行以一个点“.”开始,那么,这行将被sqlite3程序自身截获并进行解释。这些“点命令”通常被用来改变查询输出的格式,或者执行某个预定义的查询语句。 你可以在任何时候输入“.help”,列出可用的“点命令”。 sqlite3命令可以以8中不同的格式输出查询结果:“csv”、“列”、“html”、“插入”、“行”、“制表”和“tcl”。你可以使用“.mode”这个点命令来在这些输出格式之间进行切换。 默认的输出格式是“列表”。在列表模式下,每条查询结果记录被写在一行中,并且,每列之间以一个字符串分隔符隔开。默认的分隔符是一个管道符号“|”。列表符号模式在当你输出查询结果到另外一个字符处理器的程序(如awk)中时是尤为有用的: 我们也可以使用“.separator”点命令来改变分界符。例如,为了把分隔符改为一个逗号和空格,我们可以这么做:

sqlite3的数据类型详解

sqlite3中的数据类型 大多数的数据库引擎(到现在据我们所知的除了sqlite的每个sql数据库引擎)都使用静态的、刚性的类型,使用静态类型,数据的类型就由它的容器决定,这个容器是这个指被存放的特定列。 Sqlite使用一个更一般的动态类型系统,sqlite中,值的数据类型跟值本身相关,而不是与它的容器相关。Sqlite的动态类型系统和其他数据库的更为一般的静态类型系统相兼容,但同时,sqlite中的动态类型允许它能做到一些传统刚性类型数据库所不可能做到的事。 1.存储类和数据类型 每个存放在sqlite数据库中(或者由这个数据库引擎操作)的值都有下面中的一个存储类: ●NULL,值是NULL ●INTEGER,值是有符号整形,根据值的大小以1,2,3,4,6或8字节存放 ●REAL,值是浮点型值,以8字节IEEE浮点数存放 ●TEXT,值是文本字符串,使用数据库编码(UTF-8,UTF-16BE或者UTF-16LE) 存放 ●BLOB,只是一个数据块,完全按照输入存放(即没有准换) 从上可以看出存储类比数据类型更一般化。比如INTEGER存储类,包括6中不同长度的不同整形数据类型,这在磁盘上造成了差异。但是只要INTEGER值被从磁盘读出进入到内存进行处理,它们被转换成最一般的数据类型(8-字节有符号整形)。 Sqlite v3数据库中的任何列,除了整形主键列,可以用于存储任何一个存储列的值。sql语句中的中所有值,不管它们是嵌入在sql文本中或者是作为参数绑定到一个预编译的sql语句,它们的存储类型都是未定的。在下面描述的情况中,数据库引擎会在查询执行过程中在数值(numeric)存储类型(INTEGER和REAL)和TEXT 之间转换值。 1.1布尔类型 Sqlite没有单独的布尔存储类型,它使用INTEGER作为存储类型,0为false,1为true 1.2 Date和Time Datatype Sqlite没有另外为存储日期和时间设定一个存储类集,内置的sqlite日期和时间函数能够将日期和时间以TEXT,REAL或INTEGER形式存放 ●TEXT 作为IS08601字符串("YYYY-MM-DD HH:MM:SS.SSS") ●REAL 从格林威治时间11月24日,4174 B.C中午以来的天数 ●INTEGER 从 1970-01-01 00:00:00 UTC以来的秒数 程序可以任意选择这几个存储类型去存储日期和时间,并且能够使用内置的日期和时间函数在这些格式间自由转换 2.0 类型近似

相关文档 最新文档