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

SQLite 数据库操作(三)

发布时间:2020-12-12 19:37:43 所属栏目:百科 来源:网络整理
导读:上一讲中我们讲到了SQLite数据库的操作方法 [数据存储之SQLite数据库操作(二)],我们主要是以SQL语句对数据库进行增删改查,这一讲我们来学习一下 Android 建议的对数据库的操作方法 查看 SQLiteDatabase 中,在上一讲中有讲到 execSQL (String sql,Object[]
上一讲中我们讲到了SQLite数据库的操作方法 [数据存储之SQLite数据库操作(二)],我们主要是以SQL语句对数据库进行增删改查,这一讲我们来学习一下 Android 建议的对数据库的操作方法
查看 SQLiteDatabase 中,在上一讲中有讲到 execSQL (String sql,Object[] bindArgs) 这个方法,在这里Android建议我们在操纵数据库的时候用以下几种方式:
1) 插入: insert(String,String,ContentValues) insertOrThrow(String,ContentValues) insertWithOnConflict(String,ContentValues,int)
2) 更新:
update(String,String[]) updateWithOnConflict(String,String[],int)

3) 删除:
delete(String,String[])

[注]这一讲中我们就来使用Android推荐的这些操作数据库的方法来进行数据库的操作,Demo 还是与上一讲类似,读者可以结合上一讲内容来学习,对比之间的不同。

1. 方法概要

1) 查看API文档 SQLiteDatabase 中的
public long insert (String table,String nullColumnHack,ContentValues values)
插入一行数据到数据库中
参数:
table : 需要插入行的表的名称 nullColumnHack : 这个参数是可选的,可以为null,SQL 不允许插入一个至少一列都不命名的完全空的行。如果你提供的 values 是空的,而且
没有已知的的列名,这就是一个空行,这是不能被插入的。如果设置非空,nullColumnHack 参数提供一个可为空的列的名称,当插入的 values 是空的时候,就将这个列名置为NULL,然后values值插入。
values : 指定行对应的列的值,这个类型很类似Map,key表示列的名称,values表示列的值
返回值:
返回新插入的行的ID,如果存在错误默认返回 -1
[备注]第二个参数翻译的有些拘谨,我们可以这样理解
当在没有任何已知的列名的情况下,values参数为空的时候,insert是会失败的(数据库不允许插入一个空行),为了防止Insert()方法要求必须添加一条除了主键之外其它字段为Null值的记录,我们要在这里必须指定一个列名[因为values值是以ContentValues 的形式来存储的],到时候如果发现将要插入的行为空行时,就会将你指定的这个列名的值设为null,然后再将values值向NULL列中插入。查看源代码,我们可以发现 Android 中操作数据库的方法底层也是通过构造SQL语句来实现的。
2)查看API文档SQLiteDatabase 中的
public int delete (String table,String whereClause,String[] whereArgs)
删除操作

参数:
table :表示表名 whereClause : 可选项,是可以通过 SQL语句中where语句来过滤条件删除的条目,如果是null 表示删除所有行 whereArgs : 紧跟第二个参数,作为删除过滤条件的占位符,详情请看下面程序 PersonDao2 的 deletePerson() 方法的操作。
返回值:
如果是 0 表示未删除任何行,如果已经有删除行的操作 会得到 count > 0的数,表示删除的行数

3)查看API文档SQLiteDatabase 中的

public int update (String table,ContentValues values,String[] whereArgs)
更新操作

参数 :
table : 表示表名 values :Map 中指定列名用来更新新的值,如果是null 值则为修改为 NULL whereClause :可选项,支持SQL中的更新语句,用来做条件过滤,如果设置null 则会更新所有行 whereArgs :紧跟第二个参数,作为更新过滤条件的占位符,详情请看下面程序 PersonDao2 的updatePerson() 方法的操作。
返回值:
返回所更新的数据库的行数

4)查看API文档SQLiteDatabase 中的

查询操作 query(),可以发现 SQLiteDatabase 中有大量的 query() 查询的重载方法,其实这边它不管怎么重载,都是遵循 SQL 语句来的这里我就剖析一个最为常见的查询方法,其他的读者自己查看文档说明.

public Cursor query (boolean distinct,String table,String[] columns,String selection,String[] selectionArgs,String groupBy,String having,String orderBy,String limit)
参数:
distinct : 判断是否返回的行是唯一值,如果想要返回唯一的行,则为true,否则为false。 table : 需要查询的表的名称。 columns : 需要返回的列,如果要返回所有列则置为null。 selection : 过滤需要返回的行,格式遵从SQL中 SQL WHERE 语句(除了Where关键字以外).如果返回给定表的所有行,则置为Null。 selectionArgs :过滤条件的占位符,这里的值会代替过滤语句中 "?"。 groupBy : 过滤条件对行进行分组,格式遵从SQL中 SQL GROUP BY 语句 (除了关键字GROUP BY之外),如果不分组,置为Null。 having : 对分组过滤条件的占位符操作。 orderBy : 如何进行排序,遵从SQL中的SQL ORDER BY 语句,如果是null表示使用默认的排序顺序。 limit :是否对数据库进行分页的查询。
返回值:
它返回的是一个游标,这个用法之前有讲过,不懂的可以查看前面几讲内容的介绍

2. 代码实现

1) 程序布局文件 activity_main.xml,这里只是定义了几个按钮,就不贴出来了

2) DBOpenHelper.java 用来创建数据库使用

[java] view plain copy
  1. packagecom.android.sqlitedemo.db;
  2. importandroid.content.Context;
  3. importandroid.database.sqlite.SQLiteDatabase;
  4. importandroid.database.sqlite.SQLiteOpenHelper;
  5. publicclassDBOpenHelperextendsSQLiteOpenHelper{
  6. privatestaticStringname="mydb.db";//表示数据库的名称
  7. staticintversion=1;//表示数据库的版本号
  8. publicDBOpenHelper(Contextcontext){
  9. super(context,name,null,version);
  10. //TODOAuto-generatedconstructorstub
  11. }
  12. //当数据库创建的时候,是第一次被执行,完成对数据库的表的创建
  13. @Override
  14. voidonCreate(SQLiteDatabasedb){
  15. //TODOAuto-generatedmethodstub
  16. //SQLite数据创建支持的数据类型:整型数据,字符串类型,日期类型,二进制的数据类型
  17. //数据库这边有一个特点,就是SQLite数据库中文本类型没有过多的约束,也就是可以把布尔类型的数据存储到文本类型中,这样也是可以的
  18. Stringsql="createtableperson(idintegerprimarykeyautoincrement,namevarchar(64),addressvarchar(64),sexvarchar(8))";
  19. db.execSQL(sql);//完成数据库的创建
  20. @Override
  21. voidonUpgrade(SQLiteDatabasedb,153); font-weight:bold; background-color:inherit">intoldVersion,153); font-weight:bold; background-color:inherit">intnewVersion){
  22. //TODOAuto-generatedmethodstub
  23. }
  24. }
3) PersonService2.java 定义操作数据库(增删改查)的接口 copy
    packagecom.android.sqlitedemo.service;
  1. importandroid.content.ContentValues;
  2. importjava.util.List;
  3. importjava.util.Map;
  4. /**
  5. *定义好增删改查接口
  6. *@authorxukunhui
  7. *
  8. */
  9. interfacePersonService2{
  10. booleanaddPersion(ContentValuesvalues);
  11. booleandeletePerson(StringwhereClause,String[]whereArgs);
  12. booleanupdatePerson(ContentValuesvalues,StringwhereClause,0); background-color:inherit">//使用Map<String,String>做一个封装,比如说查询数据库的时候返回的单条记录
  13. publicMap<String,String>viewPerson(Stringselection,String[]selectionArgs);
  14. //使用List<Map<String,String>>做一个封装,比如说查询数据库的时候返回的多条记录
  15. publicList<Map<String,String>>listPersonMaps(Stringselection,String[]selectionArgs);
  16. }
3) PersonDao2.java 实现操作数据库的增删改查的功能 copy
    packagecom.android.sqlitedemo.dao;
  1. importandroid.content.Context;
  2. importandroid.database.Cursor;
  3. importcom.android.sqlitedemo.db.DBOpenHelper;
  4. importcom.android.sqlitedemo.service.PersonService2;
  5. importjava.util.ArrayList;
  6. importjava.util.HashMap;
  7. classPersonDao2implementsPersonService2{
  8. privateDBOpenHelperhelper=null;
  9. publicPersonDao2(Contextcontext){
  10. helper=newDBOpenHelper(context);
  11. booleanaddPersion(ContentValuesvalues){
  12. booleanflag=false;
  13. SQLiteDatabasedatabase=longid=-1;
  14. try{
  15. database=helper.getWritableDatabase();
  16. id=database.insert("person",values);
  17. flag=(id!=-1?true:false);
  18. }catch(Exceptione){
  19. //TODO:handleexception
  20. finally{
  21. if(database!=null){
  22. database.close();
  23. returnflag;
  24. intcount=0;
  25. count=database.delete("person",whereClause,whereArgs);
  26. flag=(count>0?0;//影响数据库的行数
  27. count=database.update("person",values,0); background-color:inherit">//查询单条记录
  28. //select*from
  29. //*表示返回的列的名称(投影查询)from
  30. Cursorcursor=null;
  31. Map<String,String>map=newHashMap<String,String>();
  32. try{
  33. database=helper.getReadableDatabase();
  34. cursor=database.query(true,"person",selection,selectionArgs,
  35. null);//查询单条记录,记录是唯一的,所以第一个参数置为true.
  36. intcols_len=cursor.getColumnCount();//获取游标个数,即查询所得的结果数目
  37. while(cursor.moveToNext()){
  38. for(inti=0;i<cols_len;i++){
  39. Stringcols_name=cursor.getColumnName(i);
  40. Stringcols_values=cursor.getString(cursor.getColumnIndex(cols_name));
  41. if(cols_values==null){
  42. cols_values="";
  43. map.put(cols_name,cols_values);
  44. e.printStackTrace();
  45. }finally{
  46. database.close();
  47. returnmap;
  48. //查询多条记录
  49. SQLiteDatabasedatabase= Cursorcursor= List<Map<String,String>>list=newArrayList<Map<String,String>>();
  50. database=helper.getReadableDatabase();
  51. cursor=database.query(false,
  52. //查询所有记录,所以有重复的数据也要全部检出,所以第一参数置为false.
  53. intcols_len=cursor.getColumnCount();
  54. while(cursor.moveToNext()){
  55. list.add(map);
  56. catch(Exceptione){
  57. //TODO:handleexception
  58. e.printStackTrace();
  59. returnlist;
  60. }
4) MainActivity.java 点击按钮触发操作数据的事件 copy
    packagecom.android.sqlitedemo;
  1. importcom.android.sqlitedemo.dao.PersonDao2;
  2. importcom.android.sqlitedemo.db.DBOpenHelper;
  3. importcom.android.sqlitedemo.service.PersonService2;
  4. importandroid.os.Bundle;
  5. importandroid.app.Activity;
  6. importandroid.content.ContentValues;
  7. importandroid.util.Log;
  8. importandroid.view.Menu;
  9. importandroid.view.View;
  10. importandroid.view.View.OnClickListener;
  11. importandroid.widget.Button;
  12. classMainActivityextendsActivity{
  13. privateButtonbutton1;
  14. privateButtonbutton2;
  15. privateButtonbutton3;
  16. privateButtonbutton4;
  17. privateButtonbutton5;
  18. privateButtonbutton6;
  19. finalStringTAG="MainActivity";
  20. protectedvoidonCreate(BundlesavedInstanceState){
  21. super.onCreate(savedInstanceState);
  22. setContentView(R.layout.activity_main);
  23. initComponent();
  24. button1.setOnClickListener(newOnClickListener(){
  25. voidonClick(Viewv){
  26. DBOpenHelperhelper=newDBOpenHelper(MainActivity.this);
  27. //调用getWritableDatabase()或者getReadableDatabase()其中一个方法将数据库建立
  28. helper.getWritableDatabase();
  29. });
  30. button2.setOnClickListener( PersonService2service2=newPersonDao2(MainActivity. ContentValuesvalues=newContentValues();
  31. values.put("name","AHuier");
  32. values.put("address","XIAMEN");
  33. values.put("sex","male");
  34. booleanflag=service2.addPersion(values);
  35. Log.i(TAG,"----addPersion--->"+flag);
  36. button3.setOnClickListener(voidonClick(Viewv){
  37. //删除的SQL语句:deletefrompersonwhereid=?
  38. //不包含where关键字
  39. booleanflag=service2.deletePerson("id=?",153); font-weight:bold; background-color:inherit">newString[]{
  40. "4"
  41. });
  42. "----deletePerson---->"+flag);
  43. button4.setOnClickListener("female");
  44. booleanflag=service2.updatePerson(values,"id=?",248)"> "1"
  45. "----updatePerson--->"+flag);
  46. button5.setOnClickListener( PersonService2service2=this);
  47. "id=?",153); font-weight:bold; background-color:inherit">newString[]{"2"});
  48. Log.i(TAG,"----viewPerson--->"+map.toString());
  49. button6.setOnClickListener(newOnClickListener(){
  50. //select*fromperson
  51. List<Map<String,String>>list=service2.listPersonMaps(null);
  52. "----viewPerson--->"+list.toString());
  53. booleanonCreateOptionsMenu(Menumenu){
  54. //Inflatethemenu;thisaddsitemstotheactionbarifitispresent.
  55. getMenuInflater().inflate(R.menu.main,menu);
  56. returntrue;
  57. voidinitComponent(){
  58. button1=(Button)findViewById(R.id.button1);
  59. button2=(Button)findViewById(R.id.button2);
  60. button3=(Button)findViewById(R.id.button3);
  61. button4=(Button)findViewById(R.id.button4);
  62. button5=(Button)findViewById(R.id.button5);
  63. button6=(Button)findViewById(R.id.button6);
  64. }

3. 程序执行过程

1) 插入数据


2) 删除ID = 4 的数据


3) 修改ID = 1 的数据


4) 返回查询的单条记录和多条记录




地址:http://download.csdn.net/category

(编辑:李大同)

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

    推荐文章
      热点阅读