加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-12 20:14:58 所属栏目:百科 来源:网络整理
导读:如果开发者对于SQL语法不熟悉,Android的SQLiteDatabase提供了增、删、改、查语句来操作数据库,虽然Android提供了这些所谓的“便捷”方法操作数据库,但笔者认为这些方法纯属“鸡肋”,毕竟SQL语法是程序员的基本功。不过Android既然提供了这些方法,这里也

如果开发者对于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. packagecom.lovo.activity;
  2. importandroid.app.Activity;
  3. importandroid.content.ContentValues;
  4. importandroid.database.Cursor;
  5. importandroid.database.sqlite.SQLiteDatabase;
  6. importandroid.os.Bundle;
  7. importandroid.view.View;
  8. importandroid.widget.TextView;
  9. importcom.lovo.dao.DBUtil;
  10. importcom.lovo.databasetest.R;
  11. publicclassDatabaseTestActivityextendsActivity{
  12. privateTextViewshow;
  13. privateSQLiteDatabasedb;
  14. @Override
  15. protectedvoidonCreate(BundlesavedInstanceState){
  16. super.onCreate(savedInstanceState);
  17. setContentView(R.layout.main);
  18. show=(TextView)findViewById(R.id.main_tv_show);
  19. db=DBUtil.getInstance(this);
  20. }
  21. voidclick(Viewv){
  22. switch(v.getId()){
  23. caseR.id.main_btn_insert:
  24. //添加指定数据
  25. ContentValuesinsertValues=newContentValues();
  26. insertValues.put("s_name","李四");
  27. insertValues.put("s_age",23);
  28. insertValues.put("s_sex","男");
  29. db.insert("t_stu",null,insertValues);
  30. break;
  31. caseR.id.main_btn_delete:
  32. //根据指定条件删除数据
  33. db.delete("t_stu","s_namelike?",153); background-color:inherit; font-weight:bold">newString[]{"李_"});
  34. caseR.id.main_btn_update:
  35. //根据指定ID修改数据
  36. ContentValuesupdateValues= updateValues.put("s_name","新人名");
  37. db.update("t_stu",updateValues,"_id=?",153); background-color:inherit; font-weight:bold">newString[]{"2"});
  38. caseR.id.main_btn_find:
  39. //查询所有数据
  40. Cursorcursor=db.query("t_stu",
  41. null);
  42. //根据指定条件查询
  43. //Cursorcursor=db.query("t_stu",null,"s_namelike?",new
  44. //String[]{"张%"},null);
  45. StringBuffersb=newStringBuffer();
  46. while(cursor.moveToNext()){
  47. intid=cursor.getInt(cursor.getColumnIndex("_id"));
  48. Stringname=cursor.getString(cursor.getColumnIndex("s_name"));
  49. Stringsex=cursor.getString(cursor.getColumnIndex("s_sex"));
  50. intage=cursor.getInt(cursor.getColumnIndex("s_age"));
  51. sb.append(id+""+name+""+sex+""+age+"n");
  52. }
  53. show.setText(sb.toString());
  54. break;
  55. }

SQLiteOpenHelper子类(DBUtil):

copy
    packagecom.lovo.dao;
  1. importandroid.content.Context;
  2. importandroid.database.sqlite.SQLiteDatabase.CursorFactory;
  3. importandroid.database.sqlite.SQLiteOpenHelper;
  4. classDBUtilextendsSQLiteOpenHelper{
  5. privatestaticDBUtildbUtil;
  6. privateDBUtil(Contextcontext,Stringname,CursorFactoryfactory,
  7. intversion){
  8. super(context,name,factory,version);
  9. staticSQLiteDatabasegetInstance(Contextcontext){
  10. if(dbUtil==null){
  11. //指定数据库名为student,需修改时在此修改;此处使用默认工厂;指定版本为1
  12. dbUtil=newDBUtil(context,"student",0); background-color:inherit">1);
  13. returndbUtil.getReadableDatabase();
  14. @Override
  15. voidonCreate(SQLiteDatabasedb){
  16. try{
  17. db.execSQL("createtablet_stu(_idintegerprimarykey,s_nametext,s_ageinteger,s_sextext)");
  18. }catch(Exceptione){
  19. e.printStackTrace();
  20. voidonUpgrade(SQLiteDatabasedb,153); background-color:inherit; font-weight:bold">intoldVersion,153); background-color:inherit; font-weight:bold">intnewVersion){
  21. System.out.println("-----onUpgradeCalled-----"+oldVersion+"--->"
  22. +newVersion);
  23. 布局XML:

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

    (编辑:李大同)

    【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读