一、SQLite简介
SQLite是D.Richard Hipp用C语言编写的开源嵌入式数据库引擎。它支持大多数的SQL92标准,并且可以在所有主要的操作系统上运行。
——支持高达2TB大小的数据库
——每个数据库以单个文件的形式存在
——每个文件以B-Tree的数据结构形式存储在磁盘
二、特点主要包括:
1. 轻量级 一个动态库即单文件
2. 独立型 没有依赖、无需安装
3. 隔离性 全部在一个文件夹中
4. 跨平台 支持众多操作系统
5. 多语言接口 支持众多编程语言
6. 安全性 事务处理的安全性
——通过数据库上的独占性和共享锁来实现独立事务处理
——多个进程可以同一时间从同一数据库读取数据,但只有一个可以写入数据。
三、SQLite的数据类型
(整型值)、REAL(浮点值)、TEXT(字符串值)、BLOB(二进制对象)
2. 动态数据类型(弱引用)
当某个值插入到数据库时,SQLite将会检查它的类型,如果该类型与关联的列不匹配,SQLite则会尝试将该值转换成该列的类型,如果不能转换,则该值将作为本身的类型存储。
注意:主键为INTEGER时,再转换类型就会报错。
四、使用须知
-由于资源占用少、性能良好和零管理成本,嵌入式数据库有了它的用武之地。如Android、IOS
-没有可用于SQLite的网络服务器、只能通过网络共享,可能存在文件锁定或者性能问题。
-只提供数据库级的锁定
-没有用户账户概念,而是根据文件系统确定所有数据库的权限。
五、在Android中如何使用SQLite(主要两个类)
-SQLiteDatabase
(1)提供了一些管理SQLite数据库的类
(2)提供创建,删除,执行SQL命令,并执行其他常见的数据库管理任务的方法。
(3)每个程序的数据库名字是唯一的,默认情况下是各自互相不干扰。
db.execSQL(sql) //执行任何SQL语句
db.insert(table,nullColumnHack,values)
db.delete(table,whereClause,whereArgs)
db.update(table,values,whereClause,whereArgs)
db.query(table,columns,selection,selectionArgs,groupBy,having,orderBy)
db.rawQuery(sql,selectionArgs) //sql语句查询
-SQLiteOpenHelper
1.创建一个数据库并且打开(Activity间接继承Content,Content提供方法openOrCreateDatabase())
SQLiteDatabase db= openOrCreateDatabase("name数据库名字.db", mode权限——可读可写私有库, factory可为null);
db.execSQL("create table if not exists usertb (_id integer primary key autoincrement, name text not null,age integer not null, sex text not null)");//建议主键的名字一定写上下划线 完成表的创建
db.execSQL("insert into usertb(name,sex,age) values('张三','女',18)");
Cursor cursor = db.rawQuery("select * from usertb",null);//查询结果存在Cursor对象中
if(cursor!=null){
c.moveToFirst();//其实默认就在第一行
while(cursor.moveToNext()){
cursor.getInt(cursor.getColumnIndex("_id")); //取第一行的第一个字段
cursor.getString(cursor.getColumnIndex("name")); //取第一行的第二个字段
cursor.getInt(cursor.getColumnIndex("age")); //取第一行的第三个字段
cursor.getString(cursor.getColumnIndex("sex")); //取第一行的第四个字段
}
cursor.close(); //关闭游标、释放内存
}
db.close();//释放数据库所占内存
然而如果Cursor的数据量特别大,特别是里面有Blob信息时,应该保证Cursor占用的内存被及时的释放掉,而不是等待GC来处理。并且Android明显是倾向于编程者手动的将Cursor close掉,因为在源代码中我们发现,如果等到垃圾回收器来回收时,也就是如果不手动关闭,系统会报错,会给用户以错误提示。
Cursor:游标接口,提供了遍历查询结果的方法,如移动指针方法move(),获得列值方法getString()等,常用方法:
getCount()//总记录条数
isFirst() //判断是否第一条记录
isLast() //判断是否最后一条记录
moveToFirst() //移动到第一条记录
moveToLast() //移动到最后一条记录
move(int offset) //移动到指定记录
moveToNext() //移动到下一条记录
moveToPrevious() //移动到上一条记录
getColumnIndexOrThrow(String columnName) //据列名称获得列索引
getInt(int columnIndex)//获得指定列索引的int类型值
getString(int columnIndex)//获得指定列索引的String类型值
六、Android内置函数访问SQLite数据库
1. ContentValues: 这个类用来存储一组可以被ContentResolver处理的值
(1)ContentValues values = new ContentValues();//类似hashMap key value
(2)values.put("name","张三");
(3)执行对应的Sql操作
SQLiteDatabase db= openOrCreateDatabase("name数据库名字.db", mode权限——可读可写私有库, factory可为null);
db.execSQL("create table if not exists stutb(_id integer primary key autoincrement, name text not null,age integer not null, sex text not null)");//建议主键的名字一定写上下划线 完成表的创建
ContentValues values = new ContentValues();
values.put("name","张三");
values.put("sex","男");
values.put("age",19);
long rowID = db.insert("stutb",null,values); //插入行的ID
values.clear(); //清空后重新put值,插入新值,就不需要重new ContentValues
values.put("name","张已");
values.put("sex","男");
values.put("age",20);
db.insert("stutb",null,values);
//更新
values.clear();
values.put("sex","女");
db.update("stub",values,"_id>?",new String[]{"3"}); //将所有ID大于3的性别改为女
//删除
db.delete("stutb","name like ?",new String[]{"%风%"});//删除所有名字中带有风的人
//查询
Cursor c = db.query("stutb",null,"_id>?",new String[]{"0"},null,null,"name");
if(c!=null){
String[] columns = c.getColumnNames();//获取所有的字段名字
while(c.moveToNext()){
for(String columnName:columns){
Log.i("info",c.getString(c.getColumnIndex(columnName)));
}
}
c.close();
}
db.close();
七、SQLiteOpenHelper——可以控制数据库的初始化操作
1. SQLiteOpenHelper是SQLiteDatabase的帮助类,用于管理数据库的创建和版本更新
2. 一般要建立一个类继承它(名为DBOpenHelper),并重写构造函数及onCreate()和onUpgrade()方法
3. 方法说明
(1)onCreate(SQLiteDatabase db) 首次创建数据库时调用 如果以有这个库,则不会自动回调该方法,一般可把建库建表的操作放于此
db.execSQL("create table if not exists stutb(_id integer primary key autoincrement,name text not null,sex text not null, age integer not null"));
db.execSQL("insert into stutb(name,sex,age) values ('张上','女',14)");
(2)onUpgrade(SQLiteDatabase db, int oldVersion, int new Version) 当数据库的版本发生变化时自动调用
(3)getReadableDatabase() 创建或打开一个只读数据库
(4)getWritableDatabase() 创建或打开一个读写数据库
4. 示例
DBOpenHelper helper = new DBOpenHelper(MainActivity.this,"stu.db");
//helper.getReadableDatabase();//获取一个只读数据库,只能查询
SQLiteDatabase db = helper.getWritableDatabase();
Cursor c=db.rawQuery("select * from stutb",null);
if(c!=null){
//与上面ContenValues中一样
}