Android ORM 框架之 greenDAO 使用

1、在 .src/main 目录下新建一个与 java 同层级的「java-gen」目录,用于存放由 greenDAO 生成的 Bean、DAO、DaoMaster、DaoSession 等类。

2.配置 Android 工程(app)的 build.gradle,分别添加 sourceSets 与dependencies。 

sourceSets {
    main {
        java.srcDirs = ['src/main/java', 'src/main/java-gen']
    }
}

//greendao
compile 'de.greenrobot:greendao:2.1.0'
compile 'de.greenrobot:greendao-generator:2.1.0'

3、通过 File -> New -> New Module -> Java Library -> 填写相应的包名与类名greendao -> Finish.

4、配置 greendao 工程的 build.gradle,添加 dependencies.

compile 'de.greenrobot:greendao:2.1.0'
compile 'de.greenrobot:greendao-generator:2.1.0'
5、编辑greendao中的类CommuteWork

按照步骤1设置的路径,

com.example.commutingtime.db.greenBean应改成greenBean,
com.example.commutingtime.db.greenDao应改成greenDao,
app/src/main/java应改成app/src/main/java-gen
可以自由更改greenDao的输出目录,但在实际使用中为了方便我还是将greenBean和greenDao等生成在java目录下。

public class CommutingWork {
    public static void main(String[] args) throws Exception{
        // 正如你所见的,你创建了一个用于添加实体(Entity)的模式(Schema)对象。
        // 两个参数分别代表:数据库版本号与自动生成代码的包路径。
        Schema schema = new Schema(1,"com.example.commutingtime.db.greenBean");//bean生成目录
        schema.setDefaultJavaPackageDao("com.example.commutingtime.db.greenDao");
        schema.setDefaultJavaPackageTest("com.example.commutingtime.db.greenDao");
        schema.enableKeepSectionsByDefault();

        addCommuting(schema);

        new DaoGenerator().generateAll(schema,"app/src/main/java");
    }

    private static void addCommuting(Schema schema){
        // 一个实体(类)就关联到数据库中的一张表,此处表名为「Commuting」(既类名)
        Entity bean = schema.addEntity("Commuting");
        // 你也可以重新给表命名
        // bean.setTableName("COMMUTING");
        bean.addIdProperty().primaryKey().autoincrement();
        bean.addStringProperty("date");//日期
        bean.addStringProperty("workDate");//上班时间
        bean.addStringProperty("outDate");//下班时间
        bean.addStringProperty("commuting");//工作时间
        bean.addStringProperty("overtime");//加班时间
        bean.addIntProperty("month");//所属月份
    }
}
 
6.执行 generator 工程,如一切正常,你将会在控制台看到如下日志,并且在主工程「java-gen」或自定义的目录下会发现生成了DaoMaster、DaoSession、CommutingDao、Commuting共4个类文件。
7、官方推荐将取得DaoMaster对象的方法放到Application层这样避免多次创建生成Session对象,在Application实现得到DaoMaster和DaoSession的方法
public class MyAplication extends Application {
    private static DaoMaster daoMaster;
    private static DaoSession daoSession;
    public static SQLiteDatabase db;
    public static final String DB_NAME="commute.db";
    private static Context mContext;
    public static MyAplication instance;

    public static MyAplication getInstance(){
        if(null == instance){
            instance = new MyAplication();
        }
        return instance;
    }

    @Override
    public void onCreate(){
        super.onCreate();
        mContext = getApplicationContext();
        getDaoMaster();
    }

    // **********greenDao相关****************start*******
    /*
    * 获取daoMaster
    * */
    private static DaoMaster getDaoMaster(){
        if(daoMaster == null){
            DaoMaster.OpenHelper helper = new DaoMaster.DevOpenHelper(mContext,DB_NAME,null);
            daoMaster = new DaoMaster(helper.getWritableDatabase());
        }
        return daoMaster;
    }

    /*
    * 获取DaoSession
    * */
    public static DaoSession getDaoSession(){
        if(daoSession == null){
            if (daoMaster == null){
                daoMaster = getDaoMaster();
            }
            daoSession = daoMaster.newSession();
        }
        return daoSession;
    }
    // **********greenDao相关****************end*******
}
通过 DaoMaster 的内部类 DevOpenHelper,你可以得到一个便利的 SQLiteOpenHelper 对象,并不需要去编写「CREATE TABLE」这样的 SQL 语句,因为 greenDAO 已经帮你做了。
注意:默认的 DaoMaster.DevOpenHelper 会在数据库升级时,删除所有的表,意味着这将导致数据的丢失。所以,在正式的项目中,你还应该做一层封装,来实现数据库的安全升级。
 
在operateDao.java中的使用:
public long insert(Commuting commuting){
        return MyAplication.getDaoSession().getCommutingDao().insert(commuting);
//        ContentValues newValues = new ContentValues();
//        newValues.put(DBOpenHelper.KEY_DATE,commuting.getDate());
//        newValues.put(DBOpenHelper.KEY_WORK_DATE,commuting.getWorkDate());
//        newValues.put(DBOpenHelper.KEY_OUT_DATE,commuting.getOutDate());
//        newValues.put(DBOpenHelper.KEY_COMMUTING,commuting.getCommuting());
//        newValues.put(DBOpenHelper.KEY_OVERTIME,commuting.getOvertime());
//        return db.insert(DBOpenHelper.DB_TABLE,null,newValues);
    }


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值