设为首页 收藏本站
查看: 2067|回复: 0

[经验分享] Android SQLite 开发教程(4): 读写数据库操作

[复制链接]

尚未签到

发表于 2016-12-1 09:32:10 | 显示全部楼层 |阅读模式
  有了数据库对象之后,可以使用execSQL 提供SQL语言来添加,删除,修改或查询数据库。除了通用的execSQL 之外,SQLiteDatabase 提供了 insert, update, delete ,query 方法来简化数据库的添加,删除,修改或查询操作。
  此外SQLite不强制检测数据库的数据类型,通过DBAdapter 可以使用强数据类型来修改,删除数据等,这也是使用DBAdapter的一个好处:
  这里我们先定义了一个TodoItem 类,表示一个Todo 项:
public class TodoItem {private String mTask;private Date mCreated;public String getTask(){return mTask;}public Date getCreated(){return mCreated;}public TodoItem(String task){this(task,new Date(System.currentTimeMillis()));}public TodoItem(String task,Date created){mTask=task;mCreated=created;}@Overridepublic String toString(){SimpleDateFormat sdf=new SimpleDateFormat("dd/mm/yy");String dateString= sdf.format(mCreated);return "("+ dateString+ ")" + mTask;}}  
下面的方法提供使用TodoItem类型做参数使用添加,删除和修改TodoItem
//insert a new taskpublic long insertTask(TodoItem task){ContentValues newTaskValues=new ContentValues();//assign values for each rownewTaskValues.put(KEY_TASK, task.getTask());newTaskValues.put(KEY_CREATION_DATE, task.getCreated().getTime());//insert rowreturn mDb.insert(DATABASE_TABLE,null,newTaskValues);}public boolean removeTask(long rowIndex){return mDb.delete(DATABASE_TABLE,KEY_ID+"="+rowIndex, null)>0;}public boolean updateTask(long rowIndex,String task){ContentValues newValue=new ContentValues();newValue.put(KEY_TASK, task);return mDb.update(DATABASE_TABLE, newValue,KEY_ID+"="+rowIndex, null)>0;}  其中ContentValues 定义了列名到列值的映射,类似于Hashtable。
  SQLiteDatabase 的Query方法的一个定义如下:
  public Cursorquery(String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy)

  • table : 数据库名称
  • columns: 需要返回的列名称,
  • selection: 查询条件,为WHERE语句(不含WHERE)。
  • selectionArgs: 如果selection 中带有? ,这里可以给出? 的替代值。
  • groupBy: Group 语句除去GROUP BY。
  • having: Having语句除去Having
  • OrderBy: Order by 语句。
  下面代码给出查询某个todoItem 项:
public Cursor getAllToDoItemsCursor(){return mDb.query(DATABASE_TABLE,new String[]{KEY_ID,KEY_TASK,KEY_CREATION_DATE},null, null, null, null, null);}public Cursor setCursorToToDoItem(long rowIndex)throws SQLException {Cursor result=mDb.query(DATABASE_TABLE,new String[]{KEY_ID,KEY_TASK},KEY_ID+"="+rowIndex, null, null, null, null);if(result.getCount()==0 || !result.moveToFirst()){throw new SQLException ("No to do item found for row:"+ rowIndex);}return result;}public TodoItem getToDoItem(long rowIndex)throws SQLException {Cursor cursor=mDb.query(DATABASE_TABLE,new String[]{KEY_ID,KEY_TASK,KEY_CREATION_DATE},KEY_ID+"="+rowIndex, null, null, null, null);if(cursor.getCount()==0 || !cursor.moveToFirst()){throw new SQLException ("No to do item found for row:"+ rowIndex);}String task=cursor.getString(TASK_COLUMN);long created=cursor.getLong(CREATION_DATE_COLUMN);TodoItem result=new TodoItem(task,new Date(created));return result;}  Query方法还有几个重载的方法,具体可以参见Android文档

  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-308027-1-1.html 上篇帖子: Android[高级教程] Android数据库SQLite表内设置外键 下篇帖子: Android 之 SQLite数据库 查询数据库
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表