使用系统api实现数据库的增、删、改、查
2015-08-31 00:00
337 查看
首先要在创建数据库的同时获得数据库对象,即打开数据库。然后才能对数据库进行操作,数据库的操作完成后一定要记得关闭数据库。如下图:
注:下面的databaseHelper即上图中的helper
“增”(Insert)的完整语句:
SQLiteDatabase db = databaseHelper.getWritableDatabase();
ContentValues values = newContentValues();
values.put("name","传智播客");
values.put("age", 4);
long rowid = db.insert(“person”,null, values);//添加数据并返回新添记录的行号,与主键id无关。若无需返回行号,则“long rowid=”可以不写。利用行号判断是否插入成功,如果行号大于等于0,则插入成功,若小于0则插入失败。
db.close();//关闭数据库
“删”( delete)的完整语句:
SQLiteDatabase db =databaseHelper.getWritableDatabase();
int number= db.delete("person","personid<?", new String[]{"2"});//number为影响的行数,如果删除成功值为1,删除失败值为0。
db.close();//关闭数据库
上面代码用于从person表中删除personid小于2的记录。
“改”( update)的完整语句:
SQLiteDatabase db =databaseHelper.getWritableDatabase();
ContentValues values = newContentValues();
values.put(“name”, “传智播客”);//key为所要修改的字段名,value为所改成的值
int number=db.update("person",values, "personid=?", new String[]{"1"}); //number为影响的行数,如果修改成功其值将大于0.
db.close();//关闭数据库
上面代码用于把person表中personid等于1的记录的name字段的值改为“传智播客”。
update(String table,ContentValuesvalues,String whereClause,String[] whereArgs)方法各参数的含义:
table:表名。
Values:所要更新的数据。
whereClause:选择条件。
whereArgs:所要修改的数据的id。
“查”( query)的完整语句:
SQLiteDatabase db =databaseHelper.getWritableDatabase();
Cursor cursor = db.query("person", newString[]{"personid,name,age"}, "name like ?", newString[]{"%传智%"}, null, null, "personiddesc", "1,2");
while (cursor.moveToNext()) {
int personid = cursor.getInt(0); //获取第一列的值,第一列的索引从0开始
String name = cursor.getString(1);//获取第二列的值
int age = cursor.getInt(2);//获取第三列的值
}
cursor.close();//关闭结果集(游标)。
db.close();//关闭数据库
上面代码用于从person表中查找name字段含有“传智”的记录,匹配的记录按personid降序排序,对排序后的结果略过第一条记录,只获取2条记录。
query(table, columns, selection,selectionArgs, groupBy, having, orderBy, limit)方法(有七个参数的也有八个参数等或其他个数参数)各参数的含义:
table:表名。相当于select语句from关键字后面的部分。如果是多表联合查询,可以用逗号将两个表名分开。
columns:要查询出来的列名。相当于select语句select关键字后面的部分。
selection:查询条件子句,相当于select语句where关键字后面的部分,在条件子句允许使用占位符“?”
selectionArgs:对应于selection语句中占位符的值,值在数组中的位置与占位符在语句中的位置必须一致,否则就会有异常。
groupBy:相当于select语句group by关键字后面的部分
having:相当于select语句having关键字后面的部分
orderBy:相当于select语句order by关键字后面的部分,如:personiddesc, age asc;
limit:指定偏移量和获取的记录数,相当于select语句limit关键字后面的部分。
版权声明:本文为博主原创文章,未经博主允许不得转载。
注:下面的databaseHelper即上图中的helper
“增”(Insert)的完整语句:
SQLiteDatabase db = databaseHelper.getWritableDatabase();
ContentValues values = newContentValues();
values.put("name","传智播客");
values.put("age", 4);
long rowid = db.insert(“person”,null, values);//添加数据并返回新添记录的行号,与主键id无关。若无需返回行号,则“long rowid=”可以不写。利用行号判断是否插入成功,如果行号大于等于0,则插入成功,若小于0则插入失败。
db.close();//关闭数据库
“删”( delete)的完整语句:
SQLiteDatabase db =databaseHelper.getWritableDatabase();
int number= db.delete("person","personid<?", new String[]{"2"});//number为影响的行数,如果删除成功值为1,删除失败值为0。
db.close();//关闭数据库
上面代码用于从person表中删除personid小于2的记录。
“改”( update)的完整语句:
SQLiteDatabase db =databaseHelper.getWritableDatabase();
ContentValues values = newContentValues();
values.put(“name”, “传智播客”);//key为所要修改的字段名,value为所改成的值
int number=db.update("person",values, "personid=?", new String[]{"1"}); //number为影响的行数,如果修改成功其值将大于0.
db.close();//关闭数据库
上面代码用于把person表中personid等于1的记录的name字段的值改为“传智播客”。
update(String table,ContentValuesvalues,String whereClause,String[] whereArgs)方法各参数的含义:
table:表名。
Values:所要更新的数据。
whereClause:选择条件。
whereArgs:所要修改的数据的id。
“查”( query)的完整语句:
SQLiteDatabase db =databaseHelper.getWritableDatabase();
Cursor cursor = db.query("person", newString[]{"personid,name,age"}, "name like ?", newString[]{"%传智%"}, null, null, "personiddesc", "1,2");
while (cursor.moveToNext()) {
int personid = cursor.getInt(0); //获取第一列的值,第一列的索引从0开始
String name = cursor.getString(1);//获取第二列的值
int age = cursor.getInt(2);//获取第三列的值
}
cursor.close();//关闭结果集(游标)。
db.close();//关闭数据库
上面代码用于从person表中查找name字段含有“传智”的记录,匹配的记录按personid降序排序,对排序后的结果略过第一条记录,只获取2条记录。
query(table, columns, selection,selectionArgs, groupBy, having, orderBy, limit)方法(有七个参数的也有八个参数等或其他个数参数)各参数的含义:
table:表名。相当于select语句from关键字后面的部分。如果是多表联合查询,可以用逗号将两个表名分开。
columns:要查询出来的列名。相当于select语句select关键字后面的部分。
selection:查询条件子句,相当于select语句where关键字后面的部分,在条件子句允许使用占位符“?”
selectionArgs:对应于selection语句中占位符的值,值在数组中的位置与占位符在语句中的位置必须一致,否则就会有异常。
groupBy:相当于select语句group by关键字后面的部分
having:相当于select语句having关键字后面的部分
orderBy:相当于select语句order by关键字后面的部分,如:personiddesc, age asc;
limit:指定偏移量和获取的记录数,相当于select语句limit关键字后面的部分。
版权声明:本文为博主原创文章,未经博主允许不得转载。
相关文章推荐
- 使用C++实现JNI接口需要注意的事项
- Android IPC进程间通讯机制
- Android Manifest 用法
- [转载]Activity中ConfigChanges属性的用法
- Android之获取手机上的图片和视频缩略图thumbnails
- Android之使用Http协议实现文件上传功能
- Android学习笔记(二九):嵌入浏览器
- android string.xml文件中的整型和string型代替
- i-jetty环境搭配与编译
- android之定时器AlarmManager
- android wifi 无线调试
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- android 代码实现控件之间的间距
- android FragmentPagerAdapter的“标准”配置
- Android"解决"onTouch和onClick的冲突问题
- android:installLocation简析
- android searchView的关闭事件
- SourceProvider.getJniDirectories