如果开发者对于sql语法不熟悉,Android的sqliteDatabase提供了增、删、改、查语句来操作数据库,虽然Android提供了这些所谓的“便捷”方法操作数据库,但笔者认为这些方法纯属“鸡肋”,毕竟sql语法是程序员的基本功。不过Android既然提供了这些方法,这里也简单介绍一下。
1、insert :方法签名:long insert(String table,String nullColumnHack,ContentValues values)
table:表名。
nullColumnHack:强行插入null值的数据列的列名。当values为null或它包含的键值对的数量为0时,就起作用了。它不应是主键列的列名,也不应是非空列的列名。
values:代表一行记录的数据。ContentValues类似于Map集合,存放键值对,键为数据列的列名。
2、update:方法签名:int update(String table,ContentValues values,String whereClause,String[] whereArgs)
values:想更新的数据。
whereClause:条件。
whereArgs:为whereClause子句传入参数。即用来替代占位符的内容。
返回的整数是受此update语句影响的记录的条数。
3、delete:方法签名:int delete(String table,51); font-family:Arial; font-size:14.399999618530273px; line-height:26px"> table:表名
whereClause:条件,满足此条件的记录将会被删除。
whereArgs:用于为whereClause子句传入参数。即替代占位符。
返回的整数是受此delete语句影响的记录的条数。
4、query:方法签名:Cursor query(String table,String[] columns,String selection,String[] selectionArgs,String groupBy,String having,String orderBy)
columns:要查询的列名
selection:查询条件子句 相当于where关键字后面的部分。
selectionArgs:为selection传入参数,替代占位符。
groupBy:控制分组,相当于select语句group by后面的部分
having:用于对分组进行过滤,相当于select语句having后面的部分
orderBy:排序。相当于select语句order by后面的部分
下面通过一个简单实例来演示它们的使用,代码如下:
Activity:
- package@H_403_105@com.lovo.activity;
- import@H_403_105@android.app.Activity;
- import@H_403_105@android.content.ContentValues;
- import@H_403_105@android.database.Cursor;
- import@H_403_105@android.database.sqlite.sqliteDatabase;
- import@H_403_105@android.os.Bundle;
- import@H_403_105@android.view.View;
- import@H_403_105@android.widget.TextView;
- import@H_403_105@com.lovo.dao.DBUtil;
- import@H_403_105@com.lovo.databasetest.R;
- public@H_403_105@class@H_403_105@DatabaseTestActivityextends@H_403_105@Activity{
- private@H_403_105@TextViewshow;
- private@H_403_105@sqliteDatabasedb;
- @Override@H_403_105@
- protected@H_403_105@void@H_403_105@onCreate(BundlesavedInstanceState){
- super@H_403_105@.onCreate(savedInstanceState);
- setContentView(R.layout.main);
- show=(TextView)findViewById(R.id.main_tv_show);
- db=DBUtil.getInstance(this@H_403_105@);
- }
- void@H_403_105@click(Viewv){
- switch@H_403_105@(v.getId()){
- case@H_403_105@R.id.main_btn_insert:
- //添加指定数据@H_403_105@
- ContentValuesinsertValues=new@H_403_105@ContentValues();
- insertValues.put("s_name"@H_403_105@,"李四"@H_403_105@);
- insertValues.put("s_age"@H_403_105@,23@H_403_105@);
- insertValues.put("s_sex"@H_403_105@,"男"@H_403_105@);
- db.insert("t_stu"@H_403_105@,null@H_403_105@,insertValues);
- break@H_403_105@;
- case@H_403_105@R.id.main_btn_delete:
- //根据指定条件删除数据@H_403_105@
- db.delete("t_stu"@H_403_105@,"s_namelike?"@H_403_105@,153); background-color:inherit; font-weight:bold">new@H_403_105@String[]{"李_"@H_403_105@});
- case@H_403_105@R.id.main_btn_update:
- //根据指定ID修改数据@H_403_105@
- ContentValuesupdateValues= updateValues.put("s_name"@H_403_105@,"新人名"@H_403_105@);
- db.update("t_stu"@H_403_105@,updateValues,"_id=?"@H_403_105@,153); background-color:inherit; font-weight:bold">new@H_403_105@String[]{"2"@H_403_105@});
- case@H_403_105@R.id.main_btn_find:
- //查询所有数据@H_403_105@
- Cursorcursor=db.query("t_stu"@H_403_105@,
- null@H_403_105@);
- //根据指定条件查询@H_403_105@
- //Cursorcursor=db.query("t_stu",null,"s_namelike?",new@H_403_105@
- //String[]{"张%"},null);@H_403_105@
- StringBuffersb=new@H_403_105@StringBuffer();
- while@H_403_105@(cursor.moveToNext()){
- int@H_403_105@id=cursor.getInt(cursor.getColumnIndex("_id"@H_403_105@));
- Stringname=cursor.getString(cursor.getColumnIndex("s_name"@H_403_105@));
- Stringsex=cursor.getString(cursor.getColumnIndex("s_sex"@H_403_105@));
- int@H_403_105@age=cursor.getInt(cursor.getColumnIndex("s_age"@H_403_105@));
- sb.append(id+""@H_403_105@+name+""@H_403_105@+sex+""@H_403_105@+age+"\n"@H_403_105@);
- }
- show.setText(sb.toString());
- break@H_403_105@;
- }
sqliteOpenHelper子类(DBUtil):