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

使用SQLiteOpenHelper和单例模式操作SQLite数据库

发布时间:2020-12-12 20:14:56 所属栏目:百科 来源:网络整理
导读:在前文中总结了SQLite数据库的基本用法,本文中将使用SQLiteOpenHelper和单例模式来操作数据库。SQLiteOpenHelper是Android提供的一个管理数据库的工具类,可以用于管理数据库的创建和版本更新。一般的用法是创建它的子类,并扩展它的onCreate()和onUpgrade

在前文中总结了SQLite数据库的基本用法,本文中将使用SQLiteOpenHelper和单例模式来操作数据库。SQLiteOpenHelper是Android提供的一个管理数据库的工具类,可以用于管理数据库的创建和版本更新。一般的用法是创建它的子类,并扩展它的onCreate()和onUpgrade方法。

SQLiteOpenHelper包含如下方法:

同上文一样,数据仍是手动写死的,实际情况应该根据业务需求从界面或其他地方获取,实例代码如下,关键是后面两个类:

Activity:

[java] view plain copy
  1. packagecom.lovo.activity;
  2. importandroid.app.Activity;
  3. importandroid.database.Cursor;
  4. importandroid.os.Bundle;
  5. importandroid.view.View;
  6. importandroid.widget.TextView;
  7. importcom.lovo.dao.StuDao;
  8. importcom.lovo.databasetest.R;
  9. publicclassDatabaseTestActivityextendsActivity{
  10. privateTextViewshow;
  11. privateStuDaodao;
  12. @Override
  13. protectedvoidonCreate(BundlesavedInstanceState){
  14. super.onCreate(savedInstanceState);
  15. setContentView(R.layout.main);
  16. show=(TextView)findViewById(R.id.main_tv_show);
  17. dao=newStuDao(this);
  18. }
  19. voidclick(Viewv){
  20. switch(v.getId()){
  21. caseR.id.main_btn_insert:
  22. //添加数据
  23. dao.insert("张三",24,"男");
  24. break;
  25. caseR.id.main_btn_delete:
  26. //根据指定ID删除数据
  27. dao.del(2);
  28. caseR.id.main_btn_update:
  29. //根据指定ID修改数据
  30. dao.update("王斌",0); background-color:inherit">34,"男",0); background-color:inherit">1);
  31. caseR.id.main_btn_find:
  32. StringBuffersb=newStringBuffer();
  33. //查询所有数据
  34. Cursorcursor=dao.findAll();
  35. //根据指定ID查询数据
  36. //Cursorcursor=dao.findById(1);
  37. while(cursor.moveToNext()){
  38. intid=cursor.getInt(cursor.getColumnIndex("_id"));
  39. Stringname=cursor.getString(cursor.getColumnIndex("s_name"));
  40. Stringsex=cursor.getString(cursor.getColumnIndex("s_sex"));
  41. intage=cursor.getInt(cursor.getColumnIndex("s_age"));
  42. sb.append(id+""+name+""+sex+""+age+"n");
  43. }
  44. show.setText(sb.toString());
  45. break;
  46. }

布局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>

SQLiteOpenHelper的子类(DBUtil):

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

StuDao类:封装数据操作的方法

copy
    importandroid.database.sqlite.SQLiteDatabase;
  1. classStuDao{
  2. privateSQLiteDatabasedb;
  3. publicStuDao(Contextcontext){
  4. db=DBUtil.getInstance(context);
  5. /**
  6. *查询所有数据
  7. *
  8. *@returnCursor
  9. */
  10. publicCursorfindAll(){
  11. Cursorcursor=db.rawQuery("select*fromt_stu",153); background-color:inherit; font-weight:bold">null);
  12. returncursor;
  13. *添加数据
  14. *@paramname姓名
  15. *@paramage年龄
  16. *@paramsex性别
  17. voidinsert(Stringname,153); background-color:inherit; font-weight:bold">intage,Stringsex){
  18. db.execSQL("insertintot_stuvalues(null,?,?)",153); background-color:inherit; font-weight:bold">newString[]{name,
  19. age+"",sex});
  20. *删除数据
  21. *@paramid
  22. voiddel(intid){
  23. db.execSQL("deletefromt_stuwhere_id=?",153); background-color:inherit; font-weight:bold">newString[]{id+""});
  24. /**
  25. *根据id查询数据
  26. *
  27. *@paramid
  28. publicCursorfindById( Cursorcursor=db.rawQuery("select*fromt_stuwhere_id=?",153); background-color:inherit; font-weight:bold">newString[]{id+""});
  29. returncursor;
  30. *修改数据
  31. *@paramname姓名
  32. *@paramage年龄
  33. *@paramsex性别
  34. *@paramidid
  35. voidupdate(Stringname,Stringsex,248); line-height:17.600000381469727px; margin:0px!important; padding:0px 3px 0px 10px!important"> db.execSQL("updatet_stusets_name=?,s_age=?,s_sex=?where_id=?",153); background-color:inherit; font-weight:bold">newObject[]{name,age,sex,id});
  36. }

(编辑:李大同)

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

    推荐文章
      热点阅读