简介

greenDAO是一个开源的Android ORM,使SQLite数据库的开发再次变得有趣。 它减轻了开发人员处理底层的数据库需求,同时节省开发时间。 SQLite是一个很不错的关系型数据库。 尽管如此,编写SQL和解析查询结果仍然是相当乏味和耗时的任务。 greenDAO通过将Java对象映射到数据库表(称为ORM,“对象/关系映射”)来解决这些问题。 这样,您可以使用简单的面向对象的API来存储,更新,删除和查询Java对象。

特性

  • 最高性能(可能是Android中最快的ORM); 我们的benchmarks 也是开源的
  • 涵盖关系和连接且易用的强大API
  • 最小的内存开销
  • 迷你开源库(<100KB,降低工程构建时间同时避免65k方法限制
  • 数据库加密:greenDAO支持SQLCipher以保证用户的数据安全
  • 强大的社区:超过5000 GitHub星星表明我们拥有一个强大而活跃的社区

导入相关的包

compile 'org.greenrobot:greendao:3.0.1'  
compile 'org.greenrobot:greendao-generator:3.0.0'

配置gradle

module 级别

apply plugin: 'org.greenrobot.greendao'
compile 'org.greenrobot:greendao-generator:3.2.2'
compile 'org.greenrobot:greendao:3.2.2'
//扫描项目中所有的@Entity文件(greenDAO中数据库的实体类),根据实体类生成DaoSession、DaoMaster以及所有实体类的dao类,
//生成的文件默认目录为:build/generated/source/greendao,若不想修改生成的路径,可以将此路径设置为资源目录。
//我们也可以自定义这个路径,如下

greendao {
    schemaVersion 1
    daoPackage 'com.zuestel.tv.greendao.gen'
    targetGenDir 'src/main/java'
}

//schemaVersion---->指定数据库schema版本号。 这由* OpenHelpers类用于在模式版本之间迁移。 如果更改实体/数据库模式,
//则必须增加此值。默认值为1

//daoPackage-------->通过gradle插件生成的DAO,DaoMaster和DaoSession的包名称。 默认为源实体(entity所在的包名)的包名称。

//targetGenDir-------->这就是我们上面说到的自定义生成数据库文件的目录了,可以将生成的文件放到我们的java目录中,
//而不是build中,这样就不用额外的设置资源目录了

//generateTests:设置为true以自动生成单元测试。

//targetGenDirTests:生成的单元测试应存储在的基本目录。 默认为src / androidTest / java。

application级别

buildscript {

    repositories {
        jcenter()
    }

    dependencies {
        classpath 'com.android.tools.build:gradle:2.3.3'
        classpath 'org.greenrobot:greendao-gradle-plugin:3.2.2'
    }
}

编写entity类

@Entity  
public class User {  
    @Id  
    private Long id;  
    private String name;  
    @Transient  
    private int tempUsageCount; // not persisted  
}

@Entity:将我们的java普通类变为一个能够被greenDAO识别的数据库类型的实体类

@Id:通过这个注解标记的字段必须是Long类型的,这个字段在数据库中表示它就是主键,并且它默认就是自增的

@Transient:表明这个字段不会被写入数据库,只是作为一个普通的java类字段,用来临时存储数据的,不会被持久化

接下来让我们点击as中Build菜单栏中的Make Project,make完成之后会发现我们的User类中突然多了好多代码,这就是greenDAO自动为你生成的了,代码如下

@Entity(
        // If you have more than one schema, you can tell greenDAO
        // to which schema an entity belongs (pick any string as a name).
        schema = "myschema",

        // Flag to make an entity "active": Active entities have update,
        // delete, and refresh methods.
        active = true,

        // Specifies the name of the table in the database.
        // By default, the name is based on the entities class name.
        nameInDb = "AWESOME_USERS",

        // Define indexes spanning multiple columns here.
        indexes = {
                @Index(value = "name DESC", unique = true)
        },

        // Flag if the DAO should create the database table (default is true).
        // Set this to false, if you have multiple entities mapping to one table,
        // or the table creation is done outside of greenDAO.
        createInDb = false,

        // Whether an all properties constructor should be generated.
        // A no-args constructor is always required.
        generateConstructors = true,

        // Whether getters and setters for properties should be generated if missing.
        generateGettersSetters = true
)
public class User {  
    @Id(autoincrement = true)
    private Long id;  

    @Property(nameInDb = "USERNAME")
    private String name;  

    @Transient  
    private int tempUsageCount; // not persisted  
    public String getName() {  
        return this.name;  
    }  
    public void setName(String name) {  
        this.name = name;  
    }  
    public Long getId() {  
        return this.id;  
    }  
    public void setId(Long id) {  
        this.id = id;  
    }  
    @Generated(hash = 873297011)  
    public User(Long id, String name) {  
        this.id = id;  
        this.name = name;  
    }  
    @Generated(hash = 586692638)  
    public User() {  
    }  
}

@Id注解选择long / Long属性作为实体ID。 在数据库术语中,它是主键。 参数autoincrement是一个标志,使ID值不断增加(不重用旧值)。

@Property允许你定义一个当前属性映射到的数据库列的非默认名称。 如果为空,greenDAO将以SQL-ish方式使用字段名(大写字母,下划线代替驼峰,例如customName将成为CUSTOM_NAME)。 注意:当前只能使用内联常量来指定列名称。

@NotNull使属性在数据库端为“NOT NULL”列。 通常,使用@NotNull标记原始类型(long,int,short,byte),同时使用封装类(Long,Integer,Short,Byte)可以使用空值。

@Transient标记要从持久性中排除的属性。 将它们用于临时状态等。或者,也可以使用Java中的transient关键字。

上述生成的代码中包含了构造方法以及每个属性的getter setter方法。除了这个变化,还会发现在我们之前设置的targetGenDir这个目录中多了三个文件,之后所有相关的数据库操作都依靠这三个文件:

DaoMaster
DaoSession
UserDao

增删改查操作

第一步肯定是初始化数据库

DaoMaster.DevOpenHelper devOpenHelper = new DaoMaster.DevOpenHelper(MyApplication.getContext(), "notes-db", null);  
DaoMaster daoMaster = new DaoMaster(devOpenHelper.getWritableDatabase());  
DaoSession daoSession = daoMaster.newSession();  
UserDao userDao = daoSession.getUserDao();

“notes-db”是我们自定的数据库名字,应为我们之前创建了一个Entity叫做User,所以greenDAO自定帮我们生成的UserDao,拿到了这个UserDao,我们就可以操作User这张表了。

一个DaoMaster就代表着一个数据库的连接;DaoSession可以让我们使用一些Entity的基本操作和获取Dao操作类,DaoSession可以创建多个,每一个都是属于同一个数据库连接的。

插入数据

User user = new User(null, "name");  
userDao.insert(user);

非常简单,实例化一个User对象,然后调用userDao的insert方法就可以了。将User对象的id设置为null的时候,数据库会自动为其分配自增的id。

查找数据

List<User> userList = userDao.queryBuilder()  
       .where(UserDao.Properties.Id.notEq(999))  
       .orderAsc(UserDao.Properties.Id)  
       .limit(5)  
       .build().list();

通过userDao的queryBuilder()方法,生成一个查找构造器,可以给构造器添加where条件判断、按照某某字段排序以及查询的条数等基本的数据库操作。list()方法表示查询的结果为一个集合.

修改数据

User findUser = userDao.queryBuilder().where(UserDao.Properties.Name.eq("wyk")).build().unique();  
if(findUser != null) {  
    findUser.setName(newName);  
    userDao.update(findUser);  
    Toast.makeText(MyApplication.getContext(), "修改成功", Toast.LENGTH_SHORT).show();  
} else {  
    Toast.makeText(MyApplication.getContext(), "用户不存在", Toast.LENGTH_SHORT).show();  
}

修改数据的第一步是把需要修改的条目给查询出来,然后修改该条目,最后调用userDao的update方法即可。unique()表示查询结果为一条数据,若数据不存在,findUser为null。

删除数据

User findUser = userDao.queryBuilder().where(UserDao.Properties.Name.eq("wyk")).build().unique();  
if(findUser != null){  
    userDao.deleteByKey(findUser.getId());  
}

删除数据和更新数据基本相似,先查询出需要删除的条目,然后调用userDao的deleteByKey将该条目的主键传入即可删除。

【结尾】greenDAO还有很多高级的功能,比如说给表设置一对一、一对多、多对多的关系以及复用查询语句等等等太多功能,本片文章仅仅做一个入门教学,其余的功能小伙伴们可以去官网教程中自行查阅

最后贴上整个demo的主要代码


build.gradle

apply plugin: 'com.android.application'  
apply plugin: 'org.greenrobot.greendao'  

buildscript {  
    repositories {  
        mavenCentral()  
    }  
    dependencies {  
        classpath 'org.greenrobot:greendao-gradle-plugin:3.2.2'  
    }  
}  

greendao {  
    schemaVersion 1  
    daoPackage 'com.wyk.greendaodemo.greendao.gen'  
    targetGenDir 'src/main/java'  
}  

android {  
    compileSdkVersion 25  
    buildToolsVersion "25.0.1"  

    defaultConfig {  
        applicationId "com.study.greendaodemo"  
        minSdkVersion 14  
        targetSdkVersion 25  
        versionCode 1  
        versionName "1.0"  
    }  
    buildTypes {  
        release {  
            minifyEnabled false  
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'  
        }  
    }  
}  

dependencies {  
    compile fileTree(dir: 'libs', include: ['*.jar'])  
    testCompile 'junit:junit:4.12'  
    compile 'com.android.support:appcompat-v7:25.0.1'  
    compile 'org.greenrobot:greendao:3.2.2'  
    compile 'org.greenrobot:greendao-generator:3.2.2'  
}

User.java

@Entity  
public class User {  
    @Id  
    private Long id;  
    private String name;  
    @Transient  
    private int tempUsageCount; // not persisted  
    public String getName() {  
        return this.name;  
    }  
    public void setName(String name) {  
        this.name = name;  
    }  
    public Long getId() {  
        return this.id;  
    }  
    public void setId(Long id) {  
        this.id = id;  
    }  
    @Generated(hash = 873297011)  
    public User(Long id, String name) {  
        this.id = id;  
        this.name = name;  
    }  
    @Generated(hash = 586692638)  
    public User() {  
    }  
}

MainActivity.java

public class MainActivity extends Activity implements View.OnClickListener {  
    private EditText mNameET;  
    private Button mAddBtn;  
    private ListView mUserLV;  

    private UserAdapter mUserAdapter;  
    private List<User> mUserList = new ArrayList<>();  

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

    private void initView() {  
        mNameET = (EditText) findViewById(R.id.et_name);  
        mAddBtn = (Button) findViewById(R.id.btn_add);  
        mUserLV = (ListView) findViewById(R.id.lv_user);  

        mAddBtn.setOnClickListener(this);  
    }  

    private void initData() {  
        mUserList = GreenDaoManager.getInstance().getSession().getUserDao().queryBuilder().build().list();  
        mUserAdapter = new UserAdapter(this, mUserList);  
        mUserLV.setAdapter(mUserAdapter);  
    }  

    /** 
     * 根据名字更新某条数据的名字 
     * @param prevName  原名字 
     * @param newName  新名字 
     */  
    private void updateUser(String prevName,String newName){  
        User findUser = GreenDaoManager.getInstance().getSession().getUserDao().queryBuilder()  
                .where(UserDao.Properties.Name.eq(prevName)).build().unique();  
        if(findUser != null) {  
            findUser.setName(newName);  
            GreenDaoManager.getInstance().getSession().getUserDao().update(findUser);  
            Toast.makeText(MyApplication.getContext(), "修改成功", Toast.LENGTH_SHORT).show();  
        } else {  
            Toast.makeText(MyApplication.getContext(), "用户不存在", Toast.LENGTH_SHORT).show();  
        }  
    }  

    /** 
     * 根据名字删除某用户 
     * @param name 
     */  
    private void deleteUser(String name){  
        UserDao userDao = GreenDaoManager.getInstance().getSession().getUserDao();  
        User findUser = userDao.queryBuilder().where(UserDao.Properties.Name.eq(name)).build().unique();  
        if(findUser != null){  
            userDao.deleteByKey(findUser.getId());  
        }  
    }  

    /** 
     * 本地数据里添加一个User 
     * @param id  id 
     * @param name  名字 
     */  
    private void insertUser(Long id, String name) {  
        UserDao userDao = GreenDaoManager.getInstance().getSession().getUserDao();  
        User user = new User(id, name);  
        userDao.insert(user);  
        mNameET.setText("");  

        mUserList.clear();  
        mUserList.addAll(userDao.queryBuilder().build().list());  
        mUserAdapter.notifyDataSetChanged();  
    }  

    @Override  
    public void onClick(View v) {  
        int viewId = v.getId();  
        switch (viewId){  
            case R.id.btn_add:  
                insertUser(null, mNameET.getText().toString());  
                break;  
            default:  
                break;  
        }  
    }  
}

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>  
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    xmlns:tools="http://schemas.android.com/tools"  
    android:layout_width="match_parent"  
    android:layout_height="match_parent"  
    android:orientation="vertical"  
    tools:context="com.wyk.greendaodemo.MainActivity">  

    <EditText  
        android:id="@+id/et_name"  
        android:layout_width="match_parent"  
        android:layout_height="wrap_content" />  

    <Button  
        android:id="@+id/btn_add"  
        android:layout_width="wrap_content"  
        android:layout_height="wrap_content"  
        android:text="add one" />  


    <ListView  
        android:id="@+id/lv_user"  
        android:layout_width="match_parent"  
        android:layout_height="match_parent"/>  
</LinearLayout>

GreenDaoManager.java(greenDao管理类)

public class GreenDaoManager {  
    private static GreenDaoManager mInstance;  
    private DaoMaster mDaoMaster;  
    private DaoSession mDaoSession;  


    private GreenDaoManager() {  
        DaoMaster.DevOpenHelper devOpenHelper = new DaoMaster
                                                .DevOpenHelper(MyApplication.getContext(), "notes-db", null);  
        DaoMaster mDaoMaster = new DaoMaster(devOpenHelper.getWritableDatabase());  
        mDaoSession = mDaoMaster.newSession();  
    }  

    public static GreenDaoManager getInstance() {  
        if (mInstance == null) {  
            mInstance = new GreenDaoManager();  
        }  
        return mInstance;  
    }  

    public DaoMaster getMaster() {  
        return mDaoMaster;  
    }  

    public DaoSession getSession() {  
        return mDaoSession;  
    }  

    public DaoSession getNewSession() {  
        mDaoSession = mDaoMaster.newSession();  
        return mDaoSession;  
    }  
}

MyApplication.java

public class MyApplication extends Application {  
    private static Context mContext;  

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

    public static Context getContext() {  
        return mContext;  
    }  
}

UserAdapter.java

public class UserAdapter extends BaseAdapter {  
    private List<User> mUserList;  
    private Context mContext;  

    public UserAdapter(Context mContext, List<User> mUserList) {  
        this.mUserList = mUserList;  
        this.mContext = mContext;  
    }  

    @Override  
    public int getCount() {  
        return mUserList == null ? 0 : mUserList.size();  
    }  

    @Override  
    public Object getItem(int position) {  
        return position;  
    }  

    @Override  
    public long getItemId(int position) {  
        return position;  
    }  

    @Override  
    public View getView(int position, View convertView, ViewGroup parent) {  
        ViewHolder viewHolder = null;  
        if (convertView == null) {  
            convertView = LayoutInflater.from(mContext).inflate(R.layout.item_user, null);  
            viewHolder = new ViewHolder();  
            viewHolder.tv_id = (TextView) convertView.findViewById(R.id.tv_id);  
            viewHolder.tv_name = (TextView) convertView.findViewById(R.id.tv_name);  
            convertView.setTag(viewHolder);  
        } else {  
            viewHolder = (ViewHolder) convertView.getTag();  
        }  

        User user = mUserList.get(position);  
        viewHolder.tv_id.setText(String.valueOf(user.getId()));  
        viewHolder.tv_name.setText(user.getName());  

        return convertView;  
    }  

    class ViewHolder {  
        TextView tv_id;  
        TextView tv_name;  
    }  
}

results matching ""

    No results matching ""