前端之家收集整理的这篇文章主要介绍了
SQLite数据库增删改查操作,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
一、使用嵌入式关系型sqlite数据库存储数据
在Android平台上,集成了一个嵌入式关系型数据库——sqlite,sqlite3支持NULL、INTEGER、REAL(浮点数字)、TEXT(字符串文本)和BLOB(二进制对象)数据类型,虽然它支持的类型只有五种,但实际上sqlite3也接受varchar(n)、char(n)、decimal(p,s) 等数据类型,只不过在运算或保存时会转成对应的五种数据类型。sqlite最大的特点是你可以把各种类型的数据保存到任何字段中,而不用关心字段声明的数据类型是什么。例如:可以在Integer类型的字段中存放字符串,或者在布尔型字段中存放浮点数,或者在字符型字段中存放日期型值。 但有一种情况例外:定义为INTEGER PRIMARY KEY的字段只能存储64位整数, 当向这种字段保存除整数以外的数据时,将会产生错误。 另外,在编写CREATE TABLE 语句时,你可以省略跟在字段名称后面的数据类型信息,如下面语句你可以省略name字段的类型信息:
CREATE TABLE person (personid integer primary key autoincrement,name varchar(20));
默认存储时间,在中国为东八区。为了解决这个问题,我们可以这样声明:
- createtableperson(
-
- contentvarchar(256),
- logtimeTIMESTAMPdefault(datetime('now','localtime'))
- )
sqlite可以解析大部分标准
sql语句,如:
查询语句:
select
*
from
表名
where
条件子句
group
by
分组字句
having
...
order
by
排序子句 如:
from
person
by
id
desc
select
name
by
name
having
count
(
*
)
>
1
分页sql与MysqL类似,下面sql语句获取5条记录,跳过前面3条记录
from
Account limit
5
offset
3
或者
3
,
5
插入语句:
insert
into
表名(字段列表)
values
(值列表)。如:
into
person(name,age)
values
(‘传智’,0); line-height:1.5!important">3
) 更新语句:
update
表名
set
字段名
=
值
where
条件子句。如:
update
person
set
name
=
‘传智‘
where
id
=
10
删除语句:
delete
10
@H_
404_56@
@H_616_404@在实际项目开发中,当数据库表结构发生更新时,应该避免用户存放于数据库中的数据丢失。
三、使用sqliteDatabase操作sqlite数据库
Android提供了一个名为sqliteDatabase的类,该类封装了一些操作数据库的API,使用该类可以完成对数据进行添加(Create)、查询(Retrieve)、更新(Update)和删除(Delete)操作(这些操作简称为CRUD)。对sqliteDatabase的学习,我们应该重点掌握execsql()和rawQuery()方法。execsql()方法可以执行insert、delete、update和CREATE TABLE之类有更改行为的sql语句; rawQuery()方法用于执行select语句。
execsql()方法的使用例子:
sqliteDatabase db
=
....; db.execsql("
values
(
'
林计钦
'
,0); line-height:1.5!important">24
)"); db.
close
();
执行上面sql语句会往person表中添加进一条记录,在实际应用中, 语句中的“林计钦”这些参数值会由用户输入界面提供,如果把用户输入的内容原样组拼到上面的insert语句, 当用户输入的内容含有单引号时,组拼出来的sql语句就会存在语法错误。要解决这个问题需要对单引号进行转义,也就是把单引号转换成两个单引号。有些时候用户往往还会输入像“ & ”这些特殊sql符号,为保证组拼好的sql语句语法正确,必须对sql语句中的这些特殊sql符号都进行转义,显然,对每条sql语句都做这样的处理工作是比较烦琐的。sqliteDatabase类提供了一个重载后的execsql(String sql,Object[] bindArgs)方法,使用这个方法可以解决前面提到的问题,因为这个方法支持使用占位符参数(?)。使用例子如下:
values
(?,?)",new Object
[]
{"传智播客",0); line-height:1.5!important">4
}); db.
execsql(String sql,Object[] bindArgs)方法的第一个参数为sql语句,第二个参数为sql语句中占位符参数的值,参数值在数组中的顺序要和占位符的位置对应。
sqliteDatabase的rawQuery()用于执行select语句,使用例子如下:
=
....;
Cursor
cursor
=
db.rawQuery("
from
person",255); line-height:1.5!important">null
);
while
(
cursor
.moveToNext()) {
int
personid
=
cursor
.getInt(
0
);
//
获取第一列的值,第一列的索引从0开始 String name
cursor
.getString(
1
);
//
获取第二列的值
int
age
2
);
//
获取第三列的值 }
cursor
.
close
(); db.
close
();
@H_404_56@
@H_616_404@rawQuery()方法的第一个参数为select语句;第二个参数为select语句中占位符参数的值,如果select语句没有使用占位符,该参数可以设置为null。带占位符参数的select语句使用例子如下:
where
name
like
?
and
age
=
?",new String
[]
{"
%
林计钦
%
","
4
"});
Cursor是结果集游标,用于对结果集进行随机访问,如果大家熟悉jdbc, 其实Cursor与JDBC中的ResultSet作用很相似。使用moveToNext()方法可以将游标从当前行移动到下一行,如果已经移过了结果集的最后一行,返回结果为false,否则为true。另外Cursor 还有常用的moveToPrevIoUs()方法(用于将游标从当前行移动到上一行,如果已经移过了结果集的第一行,返回值为false,否则为true )、moveToFirst()方法(用于将游标移动到结果集的第一行,如果结果集为空,返回值为false,否则为true )和moveToLast()方法(用于将游标移动到结果集的最后一行,如果结果集为空,返回值为false,否则为true ) 。
除了前面给大家介绍的execsql()和rawQuery()方法, sqliteDatabase还专门提供了对应于添加、删除、更新、查询的操作方法: insert()、delete()、update()和query() 。这些方法实际上是给那些不太了解sql语法的菜鸟使用的,对于熟悉sql语法的程序员而言,直接使用execsql()和rawQuery()方法执行sql语句就能完成数据的添加、删除、更新、查询操作。
Insert()方法用于添加数据,各个字段的数据使用ContentValues进行存放。ContentValues类似于MAP,相对于MAP,它提供了存取数据对应的put(String key,Xxx value)和getAsXxx(String key)方法,key为字段名称,value为字段值,Xxx指的是各种常用的数据类型,如:String、Integer等。
=
databaseHelper.getWritableDatabase(); ContentValues
values
=
new ContentValues();
values
.put("name","林计钦");
values
.put("age",0); line-height:1.5!important">24
);
long
rowid
=
db.
insert
(“person”,255); line-height:1.5!important">values
);
//
返回新添记录的行号,与主键id无关