使用特定方法操作SQLite数据库

前端之家收集整理的这篇文章主要介绍了使用特定方法操作SQLite数据库前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

如果开发者对于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:

[java] view plain copy
  1. package@H_403_105@com.lovo.activity;
  2. import@H_403_105@android.app.Activity;
  3. import@H_403_105@android.content.ContentValues;
  4. import@H_403_105@android.database.Cursor;
  5. import@H_403_105@android.database.sqlite.sqliteDatabase;
  6. import@H_403_105@android.os.Bundle;
  7. import@H_403_105@android.view.View;
  8. import@H_403_105@android.widget.TextView;
  9. import@H_403_105@com.lovo.dao.DBUtil;
  10. import@H_403_105@com.lovo.databasetest.R;
  11. public@H_403_105@class@H_403_105@DatabaseTestActivityextends@H_403_105@Activity{
  12. private@H_403_105@TextViewshow;
  13. private@H_403_105@sqliteDatabasedb;
  14. @Override@H_403_105@
  15. protected@H_403_105@void@H_403_105@onCreate(BundlesavedInstanceState){
  16. super@H_403_105@.onCreate(savedInstanceState);
  17. setContentView(R.layout.main);
  18. show=(TextView)findViewById(R.id.main_tv_show);
  19. db=DBUtil.getInstance(this@H_403_105@);
  20. }
  21. void@H_403_105@click(Viewv){
  22. switch@H_403_105@(v.getId()){
  23. case@H_403_105@R.id.main_btn_insert:
  24. //添加指定数据@H_403_105@
  25. ContentValuesinsertValues=new@H_403_105@ContentValues();
  26. insertValues.put("s_name"@H_403_105@,"李四"@H_403_105@);
  27. insertValues.put("s_age"@H_403_105@,23@H_403_105@);
  28. insertValues.put("s_sex"@H_403_105@,"男"@H_403_105@);
  29. db.insert("t_stu"@H_403_105@,null@H_403_105@,insertValues);
  30. break@H_403_105@;
  31. case@H_403_105@R.id.main_btn_delete:
  32. //根据指定条件删除数据@H_403_105@
  33. 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@});
  34. case@H_403_105@R.id.main_btn_update:
  35. //根据指定ID修改数据@H_403_105@
  36. ContentValuesupdateValues= updateValues.put("s_name"@H_403_105@,"新人名"@H_403_105@);
  37. 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@});
  38. case@H_403_105@R.id.main_btn_find:
  39. //查询所有数据@H_403_105@
  40. Cursorcursor=db.query("t_stu"@H_403_105@,
  41. null@H_403_105@);
  42. //根据指定条件查询@H_403_105@
  43. //Cursorcursor=db.query("t_stu",null,"s_namelike?",new@H_403_105@
  44. //String[]{"张%"},null);@H_403_105@
  45. StringBuffersb=new@H_403_105@StringBuffer();
  46. while@H_403_105@(cursor.moveToNext()){
  47. int@H_403_105@id=cursor.getInt(cursor.getColumnIndex("_id"@H_403_105@));
  48. Stringname=cursor.getString(cursor.getColumnIndex("s_name"@H_403_105@));
  49. Stringsex=cursor.getString(cursor.getColumnIndex("s_sex"@H_403_105@));
  50. int@H_403_105@age=cursor.getInt(cursor.getColumnIndex("s_age"@H_403_105@));
  51. sb.append(id+""@H_403_105@+name+""@H_403_105@+sex+""@H_403_105@+age+"\n"@H_403_105@);
  52. }
  53. show.setText(sb.toString());
  54. break@H_403_105@;
  55. }

sqliteOpenHelper子类(DBUtil):

copy
    package@H_403_105@com.lovo.dao;
  1. import@H_403_105@android.content.Context;
  2. import@H_403_105@android.database.sqlite.sqliteDatabase.CursorFactory;
  3. import@H_403_105@android.database.sqlite.sqliteOpenHelper;
  4. class@H_403_105@DBUtilextends@H_403_105@sqliteOpenHelper{
  5. private@H_403_105@static@H_403_105@DBUtildbUtil;
  6. private@H_403_105@DBUtil(Contextcontext,Stringname,CursorFactoryfactory,
  7. int@H_403_105@version){
  8. super@H_403_105@(context,name,factory,version);
  9. static@H_403_105@sqliteDatabasegetInstance(Contextcontext){
  10. if@H_403_105@(dbUtil==null@H_403_105@){
  11. //指定数据库名为student,需修改时在此修改;此处使用默认工厂;指定版本为1@H_403_105@
  12. dbUtil=new@H_403_105@DBUtil(context,"student"@H_403_105@,0); background-color:inherit">1@H_403_105@);
  13. return@H_403_105@dbUtil.getReadableDatabase();
  14. @Override@H_403_105@
  15. void@H_403_105@onCreate(sqliteDatabasedb){
  16. try@H_403_105@{
  17. db.execsql("createtablet_stu(_idintegerprimarykey,s_nametext,s_ageinteger,s_sextext)"@H_403_105@);
  18. }catch@H_403_105@(Exceptione){
  19. e.printStackTrace();
  20. void@H_403_105@onUpgrade(sqliteDatabasedb,153); background-color:inherit; font-weight:bold">int@H_403_105@oldVersion,153); background-color:inherit; font-weight:bold">int@H_403_105@newVersion){
  21. System.out.println("-----onUpgradeCalled-----"@H_403_105@+oldVersion+"--->"@H_403_105@
  22. +newVersion);
  23. 布局XML:

    [html] copy
    <LinearLayout@H_403_105@xmlns:android@H_403_105@="http://schemas.android.com/apk/res/android"@H_403_105@
  1. android:layout_width@H_403_105@="match_parent"@H_403_105@
  2. android:layout_height@H_403_105@="match_parent"@H_403_105@
  3. android:orientation@H_403_105@="vertical"@H_403_105@>@H_403_105@
  4. Button@H_403_105@
  5. android:id@H_403_105@="@+id/main_btn_insert"@H_403_105@
  6. android:layout_width@H_403_105@="wrap_content"@H_403_105@
  7. android:layout_height@H_403_105@="wrap_content"@H_403_105@
  8. android:onClick@H_403_105@="click"@H_403_105@
  9. android:text@H_403_105@="添加"@H_403_105@/>@H_403_105@
  10. Button@H_403_105@
  11. android:id@H_403_105@="@+id/main_btn_delete"@H_403_105@
  12. android:layout_width@H_403_105@="wrap_content"@H_403_105@
  13. android:layout_height@H_403_105@="wrap_content"@H_403_105@
  14. android:onClick@H_403_105@="click"@H_403_105@
  15. android:text@H_403_105@="删除"@H_403_105@/>@H_403_105@
  16. android:id@H_403_105@="@+id/main_btn_update"@H_403_105@
  17. android:text@H_403_105@="修改"@H_403_105@ android:id@H_403_105@="@+id/main_btn_find"@H_403_105@
  18. android:text@H_403_105@="查找"@H_403_105@TextView@H_403_105@
  19. android:id@H_403_105@="@+id/main_tv_show"@H_403_105@
  20. android:layout_height@H_403_105@="wrap_content"@H_403_105@</LinearLayout>

猜你在找的Sqlite相关文章