第十一章 Android数据存取之Databases.doc

  1. 1、本文档共37页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Android数据存取之Databases 在Android平台上可以操作数据库,这是第一次接触Android时的惊艳之一。在Android平台上,绑定了SQLite数据库,这个数据库系统也是极具性格的,它的最大的应用场景是嵌入式系统,进一步了解可以参看这里。 如果有JDBC的经验,那么在这里会容易的多。Android中操作数据库首先要通过一个 类:android.database.sqlite.SQLiteOpenHelper。它封装了如何打开一个数据库,其中当然也包含如果数据库不存在 就创建这样的逻辑。看一个例子: view plaincopy to clipboardprint? pubilc?class?DatabaseHelper?extends?SQLiteOpenHelper?{ ? private?static?final?String?DATABASE_NAME?=?com.roiding.simple.note; ? private?static?final?int?DATABASE_VERSION?=?1; ? private?static?final?String?NOTES_TABLE_NAME?=?notes; ? ? DatabaseHelper(Context?context)?{ ? super(context,?DATABASE_NAME,?null,?DATABASE_VERSION); ? } ? ? @Override? public?void?onCreate(SQLiteDatabase?db)?{ ? db.execSQL(CREATE?TABLE??+?NOTES_TABLE_NAME ? +??(id?integer?primary?key?autoincrement,?name?text);); ? } ? ? @Override? public?void?onUpgrade(SQLiteDatabase?db,?int?oldVersion,?int?newVersion)?{ ? db.execSQL(DROP?TABLE?IF?EXISTS?notes); ? onCreate(db); ? } ? }? pubilc class DatabaseHelper extends SQLiteOpenHelper { private static final String DATABASE_NAME = com.roiding.simple.note; private static final int DATABASE_VERSION = 1; private static final String NOTES_TABLE_NAME = notes; DatabaseHelper(Context context) { super(context, DATABASE_NAME, null, DATABASE_VERSION); } @Override public void onCreate(SQLiteDatabase db) { db.execSQL(CREATE TABLE + NOTES_TABLE_NAME + (id integer primary key autoincrement, name text);); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { db.execSQL(DROP TABLE IF EXISTS notes); onCreate(db); } } 这里面,如下的语句需要解释: super(context, DATABASE_NAME, null, DATABASE_VERSION) 数据库连接的初始化,中间的那个null,是一个CursorFactory参数,没有仔细研究这个参数,暂时置空吧。 public void onCreate(SQLiteDatabase db) 这里面的onCreate是指数据库onCreate时,而不是DatabaseHelper的onCreate。也就是说,如果已经指定 database已经存在,那么在重新运行程序的时候,就不会执行这个方法了。要不然,岂不是每次重新启动程序都要重新创建一次数据库了!在这个方法中,完成了数据库的创建工作。也就是那个execSQL()方法。 public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) 在程序的开发维护

文档评论(0)

xiaofei2001129 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档