一次性看不完,留个网址备下次看
http://blog.youkuaiyun.com/guolin_blog/article/details/38556989
二、LitePal 没听过
LitePal是一款开源的Android数据库框架,它采用了对象关系映射(ORM)的模式,并将我们平时开发时最常用到的一些数据库功能进行了封装,使得不用编写一行SQL语句就可以完成各种建表、増删改查的操作。并且LitePal很“轻”,jar包只有100k不到,而且近乎零配置,这一点和Hibernate这类的框架有很大区别。
传统的建表方式
其实为了方便我们对数据库表进行管理,Android本身就提供了一个帮助类:SQLiteOpenHelper。这个类集创建和升级数据库于一身,并且自动管理了数据库版本,算是一个非常好用的工具。 首先你要知道SQLiteOpenHelper是一个抽象类,这意味着如果我们想要使用它的话,就需要创建一个自己的帮助类去继承它。SQLiteOpenHelper中有两个抽象方法,分别是onCreate()和onUpgrade(),我们必须在自己的帮助类里面重写这两个方法,然后分别在这两个方法中去实现创建、升级数据库的逻辑。以上是传统教材里的做法。
LitePal的基本用法
1. 引入Jar包或源码
首先我们需要将LitePal的jar包引入到项目当中,下载好了jar包之后,把它复制到项目的libs目录中就算是引入成功了,如下图所示:
如果你不想用jar包的话,也可以把LitePal的源码下载下来,然后作为一个library库导入到Eclipse当中,再让我们的项目去引用这个library库就可以了。
2. 配置litepal.xml
接着在项目的assets目录下面新建一个litepal.xml文件,并将以下代码拷贝进去:
- <?xml version="1.0" encoding="utf-8"?>
- <litepal>
- <dbname value="demo" ></dbname>
- <version value="1" ></version>
- <list>
- </list>
- </litepal>
3. 配置LitePalApplication
由于操作数据库时需要用到Context,而我们显然不希望在每个接口中都去传一遍这个参数,那样操作数据库就显得太繁琐了。因此,LitePal使用了一个方法来简化掉Context这个参数,只需要在AndroidManifest.xml中配置一下LitePalApplication,所有的数据库操作就都不用再传Context了,如下所示:
- <manifest>
- <application
- android:name="org.litepal.LitePalApplication"
- ...
- >
- ...
- </application>
- </manifest>
- <manifest>
- <application
- android:name="com.example.MyApplication"
- ...
- >
- ...
- </application>
- </manifest>
没有关系,这时只需要修改一下MyApplication的继承结构,让它不要直接继承Application类,而是继承LitePalApplication类,就可以使用一切都能正常工作了,代码如下所示:
- public class MyApplication extends LitePalApplication {
- ..
(自动匹配以上格式真麻烦~这里屏蔽它)
- public class MyApplication extends LitePalApplication {
- ..
开始建表
前面在介绍的时候已经说了,LitePal采取的是对象关系映射(ORM)的模式,那么什么是对象关系映射呢?简单点说,我们使用的编程语言是面向对象语言,而我们使用的数据库则是关系型数据库,那么将面向对象的语言和面向关系的数据库之间建立一种映射关系,这就是对象关系映射了。
- public class MyApplication extends LitePalApplication {
- ..
据对象关系映射模式的理念,每一张表都应该对应一个模型(Model),也就是说,如果我们想要建一张news表,就应该有一个对应的News模型类。新建一个News类,如下所示:
- package com.example.databasetest.model;
- public class News {
- }
- public class News {
- private int id;
- private String title;
- private String content;
- private Date publishDate;
- private int commentCount;
- // 自动生成get、set方法
- ...
- }
- public class MyApplication extends LitePalApplication {
- ..
现在模型类已经建好了,我们还差最后一步,就是将它配置到映射列表当中。编辑assets目录下的litepal.xml文件,在<list>标签中加入News模型类的声明:
- <?xml version="1.0" encoding="utf-8"?>
- <litepal>
- <dbname value="demo" ></dbname>
- <version value="1" ></version>
- <list>
- <mapping class="com.example.databasetest.model.News"></mapping>
- </list>
- </litepal>
OK,这样所有的工作就都已经完成了,现在只要你对数据库有任何的操作,news表就会被自动创建出来。比如说LitePal提供了一个便捷的方法来获取到SQLiteDatabase的实例,如下所示:
- SQLiteDatabase db = Connector.getDatabase();
- public class MyApplication extends LitePalApplication {
- ..