- 1、本文档共37页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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)在程序的开发维护
您可能关注的文档
- 软件工程导论大作业摘要.doc
- 品牌白皮书标准模版要领.pdf
- 农村留守儿童教育保护之青神模式4要领.doc
- 2016年度公需科目部分试题.docx
- 文件上传攻防解析的知识.doc
- 第十三章 BatchPlot批量打印工具详细使用方法.pdf
- 利用Internet创新高中英语课堂教学的实践及思考.doc
- 美国大学电气工程专业方向介绍指南.doc
- 数据中心建设方案教材.doc
- 嵌入式操作系统发展.pdf
- 大学生职业规划大赛《新闻学专业》生涯发展展示PPT.pptx
- 大学生职业规划大赛《应用统计学专业》生涯发展展示PPT.pptx
- 大学生职业规划大赛《音乐学专业》生涯发展展示PPT.pptx
- 大学生职业规划大赛《中医学专业》生涯发展展示PPT.pptx
- 大学生职业规划大赛《信息管理与信息系统专业》生涯发展展示PPT.pptx
- 大学生职业规划大赛《汽车服务工程专业》生涯发展展示PPT.pptx
- 大学生职业规划大赛《水产养殖学专业》生涯发展展示PPT.pptx
- 大学生职业规划大赛《市场营销专业》生涯发展展示PPT.pptx
- 大学生职业规划大赛《音乐表演专业》生涯发展展示PPT.pptx
- 大学生职业规划大赛《音乐学专业》生涯发展展示PPT.pptx
文档评论(0)