Android学习培训教程-SQLite数据存储课件.docxVIP

Android学习培训教程-SQLite数据存储课件.docx

  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文档。上传文档
查看更多
一、SQLite保存数据介绍  将数据库保存在数据库对于重复或者结构化数据(比如契约信息)而言是理想之选。SQL数据库的主要原则之一是架构:数据库如何组织正式声明。架构体现于用于创建数据库的SQL语句。它有助于创建伴随类,即契约类,其以一种系统性、自记录的方式明确指定架构布局。  契约类是用于定义URL、表格和列名称的常数的容器。契约类允许跨同一软件包中的所有其他类使用相同的常数。可以在一个位置更改列名称并使其在整个代码中传播。组织契约类的一种良好方法是将对于整个数据库而言是全局性的定义放入类的根级别。然后为枚举其列的每个表格创建内部类。  SQLiteOpenHelper类中有一组有用的API。当使用此类获取对数据库的引用时,系统将只在需要之时而不是应用启动过程中执行可能长期运行的操作:创建和更新数据库。由于它们可能长期运行,因此需要确保在后台线程中调用getWritableDatabase()或getReadableDatabase(),比如使用AsyncTask或IntentService。  SQLite是轻量级嵌入式数据库引擎,它支持SQL语言,并且只利用很少的内存就有很好的性能。此外它还是开源的,任何人都可以使用它。许多开源项目(Mozilla,PHP,Python)都使用了SQLite。SQLite由以下几个组件组成:SQL编译器、内核、后端以及附件。SQLite通过利用虚拟数据库引擎(VDBE)。使调试、修改和扩展SQLite的内核变得更加方便。  特点:面向资源有限的设备,没有服务器进程,所有数据存放在同一文件中跨平台,可自由复制。优点是高效,Android运行时环境包含了完整的SQLite。  SQLite和其他数据库最大的不同就是对数据类型的支持,创建一个表时,可以在CREATE TABLE语句中指定某列的数据类型,但是你可以把任何数据类型放入任何列中。当某个值插入数据库时,SQLite将检查它的类型,如果该类型与关联的列不匹配,则SQLite会尝试将该值转换成该列的类型。如果不能转换,则该值将作为其本身具有的类型存储。比如可以把一个字符串(String)放入INTEGER列。SQLite称这为“弱类型”(manifest typing.)。此外,SQLite不支持一些标准的SQL功能,特别是外键约束(FOREIGN KEY constrains),嵌套 transcaction 和 RIGHT OUTER JOIN 和 FULL OUTER JOIN, 还有一些 ALTER TABLE 功能。除了上述功能外,SQLite 是一个完整的 SQL 系统,拥有完整的触发器,交易等等。Android在运行时集成了SQLite,所有每个Android应用程序都可以使用SQLite数据库。  由于JDBC(Java数据库连接)会消耗太多的系统资源,所以JDBC对于手机这种内存设备来说并不合适。因此,Android提供了一些新的API来使用SQLite数据库。数据库存储在data/项目文件夹/database/下。Android开发中使用SQLite数据库,Activity可以通过Content Provider或者Service访问一个数据库。在Android应用程序中使用SQLite,必须自己创建数据库,然后创建表,索引,填充数据。  Android提供了SQLiteOpenHelper帮助创建一个数据库,只要继承SQLiteOpenHelper类,就可以轻松的创建数据库。SQLiteOpenHelper类根据开发应用程序的需要,封装了创建和更新数据库使用的逻辑。SQLiteOpenHelper的子类,至少需要实现三个方法。  SQLiteOpenHelper的子类,至少需要实现三个方法。  (1)构造函数,调用父类的SQLiteOpenHelper的构造函数。这个方法需要四个参数:上下文环境(例如,一个Activity),数据库名称,一个可选的游标工程(通常为null),一个代表正在使用的数据库模型版本的整数。  (2)onCreate()方法,它需要一个SQLiteDatabase对象作为参数,根据需要对这个对象填充表和初始化数据。  (3)onUpgrage()方法,它需要三个参数,一个SQLiteDatabase,一个旧的版本号和一个新的版本号,这样就可以清楚如何将一个数据库从旧的模型转变到新的模型。  要从数据库执行写入和读取的操作,请分别调用getWriteableDatabase()和getReadableDatabase(),二者都会返回一个表示数据库的SQLiteDatabase对象,并提供用于SQLite操作的方法。当完成了对数据库的操作(加入Activity已经关闭),需要调用SQLiteD

文档评论(0)

xuefei111 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档