GreenDao简介
2016-01-11 23:31
309 查看
一、使用步骤
1.导入三个jar包,greendao.jar、greendao-generator.jar、freemarker.jar(链接地址)。
2.新建一个Java类GenerateDao,运行以下代码:
由于GreenDao默认升级会删除所有表并重新创建所有表,所以每次升级数据库都需要重新修改upgrade()方法,升级可以按以下步骤进行修改:
1.升级的时候修改版本号;
2.重新生成代码;
3.新建一个数据库升级的辅助类,代码如下:
4.在DevOpenHelper的onUpgrade()方法中调用上面代码的upgradeDB()方法,并在对应的位置写下修改数据库的语句。
上面就是使用GreenDao最基本的一些知识,我想大家知道了这些基本方法之后在进行GreenDao其他方面的学习就轻松多了。
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其他方面的学习就轻松多了。
相关文章推荐
- WPF样式
- 判断密码有效性
- Strategy模式
- android异步加载之Handler、AsyncTask(二)
- 一些ecplise 快捷键
- Wish圈出品:最新wish商户平台基础运营学习高清视频教程全集 免费下载
- 基本控件
- Node.js_路由
- HDU【2066】一个人的旅行
- java 自定annotation
- 有效的括号序列
- Android之动画解析
- zeromq源码分析笔记之准备(0)
- socket和webservice区别,他们各自有什么优缺点
- Ajax学习
- AngularJS Injector和Service的工作机制
- zend解析ini的流程(下)
- 那些年的面试总结2015-07-29
- hadoop单机版搭建过程
- ffmpeg精简