您的位置:首页 > 其它

GreenDao简介

2016-01-11 23:31 309 查看
一、使用步骤

1.导入三个jar包,greendao.jar、greendao-generator.jar、freemarker.jar(链接地址)。

2.新建一个Java类GenerateDao,运行以下代码:
public class GenerateDao {
public static void main(String[] args) throws Exception {
int version = 1; //数据库的版本号,用来更新数据库
String defaultJavaPackage = "com.wen.greendaodemo.db"; //GreenDao生成的类所在包路径,最好写成“包名+目录名”
String outDir = "../GreenDaoDemo/app/src/main/java"; //外部路径
Schema schema = new Schema(version, defaultJavaPackage); //创建Schema
addPerson(schema); //在Schema中添加实体
new DaoGenerator().generateAll(schema, outDir); //outDir+defaultJavaPackage目录下自动生成GreenDao需要的代码DaoMaster、DaoSession、XX实体类以及XXDao。

}

public static void addPerson(Schema schema) {
Entity entity = schema.addEntity("Person"); //此处会生成实体类,所以命名的时候建议使用驼峰规则。并会将其映射成对应的表。
entity.addIdProperty().autoincrement().primaryKey().unique();
entity.addStringProperty("name");
}

}
3.新建数据库并往其中添加数据:

public class MainActivity extends Activity {

private SQLiteDatabase writableDatabase;
private DaoMaster daoMaster;
private DaoSession daoSession;
private PersonDao personDao;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

createDataBase();

initDataBase();

addPerson();

}

/**
* 第一次执行的时候会创建数据库
*/
private void createDataBase() {
DaoMaster.DevOpenHelper devOpenHelper = new DaoMaster.DevOpenHelper(this, "wen", null); //传入数据库的名字
writableDatabase = devOpenHelper.getWritableDatabase(); //第一次执行的时候会在此处创建数据库
}

/**
* 初始化数据库的常用参数 daoMaster、daoSession以及xxxDao
*/
private void initDataBase() {
daoMaster = new DaoMaster(writableDatabase);
daoSession = daoMaster.newSession();
personDao = daoSession.getPersonDao();
}

/**
* 增
*/
private void addPerson() {
for (int i = 0; i < 10; i++) {
Person person = new Person(); //每次都要new一个,否则会报primary key not unique异常
person.setName("zbw" + i);
personDao.insert(person);
}
}

}
4.删、改、查的使用:

/**
* 删
*/
private void deletePerson() {
personDao.deleteByKey(1L); //传入的为Id
}

/**
* 改
*/
private void updatePerson() {
Person person = new Person();
person.setName("zbw update");
person.setId(2L);
personDao.update(person);
}

/**
* 查
*/
private void queryPerson() {
List<Person> personList = personDao.queryBuilder().where(PersonDao.Properties.Name.eq("zbw2")).list();
for(Person person : personList) {
Log.e("zbw",""+person.getId() + person.getName());
}
}
二、数据库升级

由于GreenDao默认升级会删除所有表并重新创建所有表,所以每次升级数据库都需要重新修改upgrade()方法,升级可以按以下步骤进行修改:

1.升级的时候修改版本号;
2.重新生成代码;
3.新建一个数据库升级的辅助类,代码如下:
public class DBUpgradeHelper {
public static void upgradeDB(SQLiteDatabase db, int oldVersion, int newVersion) {
int currentVersion = oldVersion;
while (currentVersion <= newVersion){
upgradeByVersion(db , currentVersion);
currentVersion++;
}
}

private static void upgradeByVersion(SQLiteDatabase db, int currentVersion) {
switch (currentVersion){
case 1:
upgradeDB1To2(db);
break;
case 2:
upgradeDB2To3(db);
break;
}
}

private static void upgradeDB1To2(SQLiteDatabase db) {
//创建新表或者更新表结构
}

private static void upgradeDB2To3(SQLiteDatabase db) {
//创建新表或者更新表结构
}
}


4.在DevOpenHelper的onUpgrade()方法中调用上面代码的upgradeDB()方法,并在对应的位置写下修改数据库的语句。
上面就是使用GreenDao最基本的一些知识,我想大家知道了这些基本方法之后在进行GreenDao其他方面的学习就轻松多了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: