android学习笔记49——SQLite2
使用SQLite工具
位于Android SDK/tools-->sqlite3.exe,其是一个简单的SQLite数据库管理工具,类似于MySQL提供的命令行窗口。
.....
使用特定方法操作SQLite数据库
如果开发者对于SQL语法不熟悉,没有使用过SQL,android的SQLiteDatabase为其提供了inset、delete、update、query语句来操作数据库。
1.insert
SQLiteDatabase insert方法签名为:long insert(String table,String nullColumnHack,ContentValues values),这个插入方法参数说明如下:
table——表名称;
nullColumnHack——代表强行插入null值的数据列的列名;
ContentValues——代表一行记录的数据
ContentValues类似于Map,其提供了put方法用于存放数据,put(Sting key,Xxx value)其中key代表列名;getAsXxx(String key)方法用于取出数据。
例如:
ContentValues values = new ContentValues();
values.put("name",“孙悟空”);
values.put("nickName","齐天大圣");
//返回新添加记录的行号,该行号是一个内部值,与主键Id无关,发生错误返回-1
long rowNum = db.insert("pesonInfo",null,values);
注意:无论第三个参数values是否包含数据,执行insert()方法总会添加一条记录,如果第三个参数为空,会添加一条除主键之外其他字段都为null的记录。
insert()的底层实际上依然是通过构造insert SQL语句来进行插入的,因此其生成的SQL语句总是如下所示的语句:
//ContentValues里的key-value对的数量决定下面的key-value
inset into <表名>(key1,key2,...) values(value1,value2...);
此时,如果第三个参数为null或者其中key-value对的数量为0,生成的对应insert语句为:
insert into <表名> values()

2.使用update方法更新记录
SQLiteDatabase的update方法的签名为update(String table,ContentValues values,String whereClause,String[] whereArgs);
table——代表需要更新的表名称;
values——代表需要更新的数据;
whereClause——满足该whereClause子句的记录将会被更新,即更新条件;
whereArgs——用于为第三个参数传入参数;
该方法返回受此update语句影响的记录的条数。
例如,需要更新主键大于20的数据==》
ContentValues values = new ContentValues();
values.put("name","猪八戒");
int result = db.update("personInfo",values,"_id>?",new Integer[]{20});
本质:update 表名 set key1=value1,keyn=valuen where whereClause。其中whereArgs用于为whereClause传参。
3.使用delete方法删除记录
SQLiteDatabase的delete方法签名:delete(String table,String whereClause,String[] whereArgs):
table——代表需要删除的表名称;
whereClause——满足该whereClause子句的记录将会被删除,即删除条件;
whereArgs——用于为第三个参数传入参数;
该方法返回受此delete语句影响的记录的条数。
==》int result = db.delete("personInfo","_id>?",new Integer[]{20});
本质:delete table where whereClause。其中whereArgs用于为whereClause传参。
4.使用query方法查询记录
SQLiteDatabase的query方法的签名为:Cursor query(boolean distinct,String table,String[] columns,String selections,String selectionArgs,
String groupby,String having,String orderby,String limit).
distinct——指定是否除去重复记录;
table——表名;
columns——列;
selections——查询子句 ,相当于select语句where关键字后面的部分,在条件子句中允许使用占位符?;
selectionArgs——用于为selections子句中占位符传入参数值,值在数组中的位置与占位符在语句中的位置必须一致,否则就会异常;
groupby——用于控制分组;
having——用于对分组进行过滤;
orderby——用于排序;
limit——用于进行分页;
5.事务
SQLiteDatabase中包含如下两种方法用于控制事务,如下:
benginTransaction
endTransaction
SQLiteDatabase还提供了inTransaction用来判断当前上下文是否处于事务环境中;inTransaction(),存在返回true,否则false.
注意:
当程序执行endTransaction()时将会结束事务,那到底是提交事务,还是回滚?
其取决于SQLiteDatabase是否调用了setTransactionSuccessful()来设置事务标志,如果程序事务执行中调用该方法设置了事务成功则提交事务;否则程序将会回滚事务。
如下:

android学习笔记49——SQLite2的更多相关文章
- Android 学习笔记之Volley(七)实现Json数据加载和解析...
学习内容: 1.使用Volley实现异步加载Json数据... Volley的第二大请求就是通过发送请求异步实现Json数据信息的加载,加载Json数据有两种方式,一种是通过获取Json对象,然后 ...
- Android学习笔记进阶之在图片上涂鸦(能清屏)
Android学习笔记进阶之在图片上涂鸦(能清屏) 2013-11-19 10:52 117人阅读 评论(0) 收藏 举报 HandWritingActivity.java package xiaos ...
- android学习笔记36——使用原始XML文件
XML文件 android中使用XML文件,需要开发者手动创建res/xml文件夹. 实例如下: book.xml==> <?xml version="1.0" enc ...
- Android学习笔记之JSON数据解析
转载:Android学习笔记44:JSON数据解析 JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,采用完全独立于语言的文本格式,为Web应用开发提供了一种 ...
- udacity android 学习笔记: lesson 4 part b
udacity android 学习笔记: lesson 4 part b 作者:干货店打杂的 /titer1 /Archimedes 出处:https://code.csdn.net/titer1 ...
- Android学习笔记36:使用SQLite方式存储数据
在Android中一共提供了5种数据存储方式,分别为: (1)Files:通过FileInputStream和FileOutputStream对文件进行操作.具体使用方法可以参阅博文<Andro ...
- Android学习笔记之Activity详解
1 理解Activity Activity就是一个包含应用程序界面的窗口,是Android四大组件之一.一个应用程序可以包含零个或多个Activity.一个Activity的生命周期是指从屏幕上显示那 ...
- Pro Android学习笔记 ActionBar(1):Home图标区
Pro Android学习笔记(四八):ActionBar(1):Home图标区 2013年03月10日 ⁄ 综合 ⁄ 共 3256字 ⁄ 字号 小 中 大 ⁄ 评论关闭 ActionBar在A ...
- 【转】Pro Android学习笔记(九八):BroadcastReceiver(2):接收器触发通知
文章转载只能用于非商业性质,且不能带有虚拟货币.积分.注册等附加条件.转载须注明出处:http://blog.sina.com.cn/flowingflying或作者@恺风Wei-傻瓜与非傻瓜 广播接 ...
随机推荐
- PSP进度(11~16)
本周psp 11月14号 内容 开始时间 结束时间 打断时间 净时间 查看Java相关资料 18:31 19:28 0 57分 代码实现 19:30 20:46 0 76分 发布博客 22:55 23 ...
- <转>浏览器内核分类
浏览器的种类成千上百,但所基于的内核,却没有几个.目前主流的浏览器内核主要为以下四种: 一.Trident内核,代表产品Internet Explorer说起Trident,很多人都会感到陌生,但提起 ...
- C#窗体 WinForm 文件操作
文件及文件夹操作 C/S:WinForm可以操作客户端文件 Client ServerB/S:浏览器服务 Brower Server 命名空间:using system .IO; 1. File类:文 ...
- hdu 1032
题目的意思是把输入的i,j 从i到j的每一个数 做循环,输出循环次数最大的值 易错的地方:做循环是容易直接用i进行计算 i=i/2:或i=i*3+1: 这样i的值改变就不能在做下面数的循环 #incl ...
- Linux设备驱动中的并发控制
1.并发是指多个执行单元同时.并行的执行.并发的执行单元对共享资源的访问很容易导致竞态. 在 Linux 内核中,主要的竞态发生于如下几种情况: ①对称多处理器(SMP)的多个 CPU ②单CPU内进 ...
- cookie 路径问题
Path – 路径.指定与cookie关联的WEB页.值可以是一个目录,或者是一个路径.如果http://www.zdnet.com/devhead /index.html 建立了一个cookie,那 ...
- JAVA https证书相关
生成证书: keytool -genkey -alias cas -keyalg RSA -keystore cas.key 导出证书: keytool -export -alias cas -f ...
- Angular - ng-repeat高级用法
ng-repeat高级用法: 遍历数组: <li ng-repeat="item in array">{{item}}</li> 遍历对象: k ...
- yarn 0.9.0 build spark
1. 下载scala并安装.版本为2.10.3.设置SCALA_HOME和PATH环境变量 2. 下载SPARK 0.9.0源代码并解压到/root/Downloads/spark-0.9.0-inc ...
- html a 链接标签title属性换行鼠标悬停提示内容的换行效果
鼠标经过悬停于对象时提示内容(title属性内容)换行排版方法,html title 换行方法总结. html的title属性默认是显示一行的.如何换行呢? 这里DIVCSS5总结介绍两种换行方法为大 ...