Android移动应用设计与开发--第08章.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
项目名:com.androidbook.client 案例:话题表数据的获取方法 源代码位置:com.androidbook.client.database.table.Topic // 以HashMapString, Object键值对的形式,根据_id参数获取一条对应话题的信息 public static HashMapString, Object getTopic( DatabaseHelper dbHepler, int _id ){ SQLiteDatabase db = dbHepler.getReadableDatabase(); HashMapString, Object topicMap = new HashMapString, Object(); // 此处要求查询Topic._id为传入参数_id的对应记录,使游标指向此记录 Cursor cursor = db.query( Topic.tableName, null, Topic._id + =? , new String[]{ _id + }, null, null, null); 8.2.2 SQLite使用 // 移动到第一个结果上 cursor.moveToFirst(); //获得每个字段的值 topicMap.put( Topic.ID, cursor.getLong(cursor.getColumnIndex(Topic.ID))); topicMap.put( Topic.content, cursor.getString(cursor.getColumnIndex(Topic.content))); topicMap.put( Topic.time, cursor.getInt(cursor.getColumnIndex(Topic.time))); topicMap.put( T, cursor.getString(cursor.getColumnIndex(T))); topicMap.put( Topic.photo, cursor.getString(cursor.getColumnIndex(Topic.photo))); cursor.close(); db.close(); return topicMap; } 8.2.2 SQLite使用 getTopic方法可以根据_id获得一条对应话题记录的信息。首先用query方法得到指向对应记录的cursor游标,然后通过cursor从数据表中取出对应字段的数据,保存到HashMap后返回。注意,每次使用cursor读取数据都必须执行cursor.moveToFirst()方法,使其正确指向所需记录的开始位置,才能保证读取数据的正确性。当返回的结果有多条,并且需要获得多条的时候需要从cursor中循环取数据。 for(cursor.moveToFirst();cursor.isAfterLast();cursor.moveToNext() ){ ... } 8.2.2 SQLite使用 综合案例中一共有三个表,话题表(Topic)、私信表(PrivateLetter)、好友表(Friend)。私信表(PrivateLetter)、好友表(Friend)的创建与增删改查的操作与话题表(Topic)相似,在此不再赘述。所有表创建完成后,client.db数据库的表结构如下图: 从这个图中我们能够看到所建立的三个表——私信表(PrivateLetter)、好友表(Friend)与话题表(Topic),其余的表是SQLite自动生成的。 8.2.2 SQLite使用 话题表(Topic)结构及其中所包含的字段与对应的值如下图: 好友表(Friend)结构和所包含的字段与对应的值如下图: 8.2.2 SQLite使用 私信表(PrivateLetter)结构和所包含的字段与对应的值如下图: 8.2.2 SQLite使用 第三部分 ContentProvider存储 8.3 ContentProvider存储 ContentProvider是Android平台中,在不同应用程序之间实现数据共享的唯一机制。一个应用程序如果需要让别的应用程序能够操作自己的数据,即可采用这种机制。 一个程序可以通过实现一个ContentProvider的抽象接口将自己的数据完全暴露出去,而且ContentProvider是以类似数据库中表的方式将数据暴露。那么外界获取其提供的数据,也就与从数据库中获取数据的操作基本一样。 这时就可以用到另外一个类(Co

文档评论(0)

132****9295 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档