3307
- 收藏
- 点赞
- 分享
- 举报
安卓开发常用数据库SQLite详解
[i=s] 本帖最后由 jp1017 于 2015-8-5 18:55 编辑 [/i]
SQLite这个数据库,异常给力,到底如何给力这里不阐述,看人家的官网,简单,大气。
[size=4][color=Red]官网:[/color][/size][url=http://www.sqlite.org/docs.html]SQLite
[attach]2714[/attach]
今天听老师讲的该[color=DarkOrchid][size=4]数据库的建立,以及增删改查功能实现和单元测试[/size][/color],下面给大家分享下,源码在最后哦。:D
SQLite数据库如何查看请看这里:
SQLite数据库查看工具推荐 http://www.ebaina.com/bbs/forum.php?mod=viewthread&tid=8332&fromuid=8410 (出处: 易百纳论坛)
[b][font=楷体,楷体_GB2312][size=5]一:数据库的建立[/size][/font][/b]
建立一个数据库类DBOpenHelper继承SQLiteOpenHelper类,然后重写父类的两个抽象方法即可,
[attach]2715[/attach]
我在这两个抽象方法里建立一个数据库,以及实现了数据库版本变化后的操作。
[b][font=楷体,楷体_GB2312][size=5]二:数据的操作——增删改查,获取分页记录及获取总数[/size][/font][/b]
这里有两种方法来操作的,归根结底还是几个常用的sql语句,如下:
选择:select * from table1 where 范围
插入:insert into table1(field1,field2) values(value1,value2)
删除:delete from table1 where 范围
更新:update table1 set field1=value1 where 范围
查找:select * from table1 where field1 like ’%value1%’ (所有包含‘value1’这个模式的字符串)---like的语法很精妙,查资料!
排序:select * from table1 order by field1,field2 [desc]
总数:select count(*) as totalcount from table1
[size=4]方法1:利用SQLiteDatabase类的execSQL方法和rawQuery方法[/size]
这个见我的例子里的DBOpenHelper.java文件
说明:
a、各种方法按照上面的sql语句比对,你就可以搞定;
b、里面有个Cursor类,请看这里:
教你识破安卓开发中Cursor类的真实面目 http://www.ebaina.com/bbs/forum.php?mod=viewthread&tid=8330&fromuid=8410 (出处: 易百纳论坛)
c、里面各方法的具体实现可进去看源码。
[size=4]方法2:直接利用SQLiteDatabase类里面的insert, delete, update, query方法[/size]
这个见我的例子OtherPersonService.java文件,也按照上面的sql语句比对即可搞定。
[font=楷体,楷体_GB2312][b][size=5]三:单元测试[/size][/b][/font]
as的单元测试的做法请看我的另一个帖子:
Android Studio 单元测试
http://www.ebaina.com/bbs/forum.php?mod=viewthread&tid=8138&fromuid=8410 (出处: 易百纳论坛)
这里就不给大家演示了,给出几个结果图::)
[align=center][attach]2717[/attach][/align]
[align=center][attach]2716[/attach][/align]
源码下载地址:[color=Red]我点[/color],[color=YellowGreen]我点[/color],[color=Plum]我点点。。。[/color][attach]2718[/attach]
文件: db.zip
下载
我来回答
回答2个
时间排序
认可量排序
认可0
认可0
或将文件直接拖到这里
悬赏:
E币
网盘
* 网盘链接:
* 提取码:
悬赏:
E币
Markdown 语法
- 加粗**内容**
- 斜体*内容*
- 删除线~~内容~~
- 引用> 引用内容
- 代码`代码`
- 代码块```编程语言↵代码```
- 链接[链接标题](url)
- 无序列表- 内容
- 有序列表1. 内容
- 缩进内容
- 图片![alt](url)
相关问答
-
2015-08-05 18:54:12
-
2015-08-05 18:29:58
-
32015-08-17 20:38:04
-
2008-05-24 14:52:19
-
2015-08-11 09:47:25
-
2015-08-07 21:22:46
-
2020-11-22 11:33:56
-
2015-08-19 21:45:26
-
2008-12-26 11:30:20
-
2008-08-07 19:00:12
-
2015-08-05 14:51:39
-
2020-11-30 08:40:32
-
2008-08-04 23:22:43
-
2017-07-07 11:01:18
-
2020-12-09 09:23:28
-
2018-12-21 14:40:32
-
2020-11-11 10:09:54
-
2015-08-09 20:39:38
-
2015-08-03 20:18:40
无更多相似问答 去提问
点击登录
-- 积分
-- E币
提问
—
收益
—
被采纳
—
我要提问
切换马甲
上一页
下一页
悬赏问答
-
5Hi3516CV610 如何使用SD卡升级固件
-
5cat /dev/logmpp 报错 <3>[ vi] [func]:vi_send_frame_node [line]:99 [info]:vi pic queue is full!
-
50如何获取vpss chn的图像修改后发送至vo
-
5FPGA通过Bt1120传YUV422数据过来,vi接收不到数据——3516dv500
-
50SS928 运行PQtools 拼接 推到设备里有一半画面会异常
-
53536AV100的sample_vdec输出到CVBS显示
-
10海思板子mpp怎么在vi阶段改变视频数据尺寸
-
10HI3559AV100 多摄像头同步模式
-
9海思ss928单路摄像头vio中加入opencv处理并显示
-
10EB-RV1126-BC-191板子运行自己编码的程序
举报反馈
举报类型
- 内容涉黄/赌/毒
- 内容侵权/抄袭
- 政治相关
- 涉嫌广告
- 侮辱谩骂
- 其他
详细说明
提醒
你的问题还没有最佳答案,是否结题,结题后将扣除20%的悬赏金
取消
确认
提醒
你的问题还没有最佳答案,是否结题,结题后将根据回答情况扣除相应悬赏金(1回答=1E币)
取消
确认