GreenDao数据库框架的配置与增删改查
并非原创,原创地址http://blog.csdn.net/njweiyukun/article/details/51893092
配置----------------------------------
项目的gradle里的配置
apply plugin: 'org.greenrobot.greendao'
buildscript {
    repositories {
        mavenCentral()
    }
    dependencies {
        classpath 'org.greenrobot:greendao-gradle-plugin:3.0.0'
    }
}
在gradle的根模块中加入上述代码后,sync project的时候,gradle会自动去maven仓库下载一个gradle的插件,当然了,这个插件就是为greenDAO服务的,用来生成数据库相关的代码。
greendao {
    schemaVersion 1
    daoPackage 'com.greendao.demo.gen'
    targetGenDir 'src/main/java'
}
schemaVersion---->指定数据库schema版本号,迁移等操作会用到
daoPackage-------->通过gradle插件生成的数据库相关文件的包名,默认为你的entity所在的包名
targetGenDir-------->这就是我们上面说到的自定义生成数据库文件的目录了,可以将生成的文件放到我们的java目录中,而不是build中,这样就不用额外的设置资源目录了
导包
- compile 'org.greenrobot:greendao:3.0.1'
- compile 'org.greenrobot:greendao-generator:3.0.0'
在根目录创建entity包名 定义实体数据库类
@Entity:将我们的java普通类变为一个能够被greenDAO识别的数据库类型的实体类
@Id:通过这个注解标记的字段必须是Long类型的,这个字段在数据库中表示它就是主键,并且它默认就是自增的
@Transient:表明这个字段不会被写入数据库,只是作为一个普通的java类字段,用来临时存储数据的,不会被持久化
重新编译后会生成一些代码以及gen目录
@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() {
}
} 初始化数据库
public class GreenDaoManager {
    private static GreenDaoManager mGreenDaoManager;
    private DaoMaster mMaster;
    private DaoSession mDaosession;
    public GreenDaoManager() {
        DaoMaster.DevOpenHelper devOpenHelper=new DaoMaster.DevOpenHelper(MyLication.getContext(),"user-db",null);
        mMaster=new DaoMaster(devOpenHelper.getWritableDatabase());
        mDaosession=mMaster.newSession();
    }
    public static GreenDaoManager getInstance(){
        if(mGreenDaoManager==null){
            mGreenDaoManager=new GreenDaoManager();
        }
        return mGreenDaoManager;
    }
    public DaoMaster getMaster(){
        return mMaster;
    }
    public DaoSession getDaosession(){
        return mDaosession;
    }
    public DaoSession getNewDasession(){
        mDaosession=mMaster.newSession();
        return mDaosession;
    }
}
出数据库中用的APPlication
public class MyLication extends Application {
    private static Context mContext;
    @Override
    public void onCreate() {
        super.onCreate();
        mContext=getApplicationContext();
        GreenDaoManager.getInstance();
    }
    public static Context getContext(){
        return mContext;
    }
}
自动生成的3个类
activity代码 包涵增删改查
public class MainActivity extends AppCompatActivity 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 initData() {
        mUserList= GreenDaoManager.getInstance().getDaosession().getUserDao().queryBuilder().build().list();
        mUserAdapter = new UserAdapter(this, mUserList);
        mUserLV.setAdapter(mUserAdapter);
    }
    private void initView() {
        mNameET = (EditText) findViewById(R.id.et_name);
        mAddBtn = (Button) findViewById(R.id.btn_add);
        mUserLV = (ListView) findViewById(R.id.lv_user);
        findViewById(R.id.btn_delete).setOnClickListener(this);
        findViewById(R.id.btn_update).setOnClickListener(this);
        mAddBtn.setOnClickListener(this);
    }
    @Override
    public void onClick(View v) {
        int viewId = v.getId();
        switch (viewId){
            case R.id.btn_add:
                insertUser(null, mNameET.getText().toString());
                break;
            case R.id.btn_delete:
                deleteUser("li");
                break;
            case R.id.btn_update:
                updateUser("y","li");
                break;
        }
    }
    private void updateUser(String name,String newName){
        UserDao userDao= GreenDaoManager.getInstance().getDaosession().getUserDao();
        User findUser=userDao.queryBuilder()
                .where(UserDao.Properties.Name.eq(name)).build().unique();
        if(findUser!=null){
            findUser.setName(newName);
            GreenDaoManager.getInstance().getDaosession().getUserDao().update(findUser);
            ToaskUtil.showToast(this,"修改成功");
            updateAdapter(userDao.queryBuilder().list());
            mUserAdapter.notifyDataSetChanged();
        }else{
            ToaskUtil.showToast(this,"没有找到该用户信息");
        }
    }
    private void deleteUser(String name){
        UserDao userDao=GreenDaoManager.getInstance().getDaosession().getUserDao();
       User findUser=userDao .queryBuilder().where(UserDao.Properties.Name.eq(name)).build().unique();
        if(findUser!=null){
            userDao.deleteByKey(findUser.getId());
            ToaskUtil.showToast(this,"删除成功");
            updateAdapter(userDao.queryBuilder().list());
        }else{
            ToaskUtil.showToast(this,"没有找到该用户");
        }
    }
    private void insertUser(Long id,String name){
       UserDao userDao= GreenDaoManager.getInstance().getDaosession().getUserDao();
        User user=new User(id,name);
        userDao.insert(user);
        mNameET.setText("");
        updateAdapter(userDao.queryBuilder().list());
    }
    private void updateAdapter(List<User> list){
        mUserList.clear();
        mUserList.addAll(list);
        mUserAdapter.notifyDataSetChanged();
    }
}
activity的布局文件
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
> <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" />
<Button
android:id="@+id/btn_delete"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="delete one" />
<Button
android:id="@+id/btn_update"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="update one" /> <ListView
android:id="@+id/lv_user"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
</LinearLayout> ListView的Adapter
package com.greendao.demo.Adapter; import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.TextView; import com.greendao.demo.R;
import com.greendao.demo.entity.User; import java.util.List; /**
* Created by Administrator on 2016/10/10.
*/
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;
}
}
Adapter的布局
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<LinearLayout
android:layout_marginTop="5dp"
android:layout_width="match_parent"
android:layout_height="30dp"
android:orientation="horizontal">
<TextView
android:id="@+id/tv_id"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_weight="1"
android:text="1"
android:layout_marginLeft="15dp"
android:textSize="25dp"/>
<TextView
android:id="@+id/tv_name"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_weight="1"
android:text="zhangsan"
android:textSize="25dp"/>
</LinearLayout>
<View
android:layout_marginTop="3dp"
android:layout_width="match_parent"
android:layout_height="2dp"
android:background="@android:color/holo_blue_bright"/>
</LinearLayout>
GreenDao数据库框架的配置与增删改查的更多相关文章
- Django框架之第二篇--app注册、静态文件配置、form表单提交、pycharm连接数据库、django使用mysql数据库、表字段的增删改查、表数据的增删改查
		本节知识点大致为:静态文件配置.form表单提交数据后端如何获取.request方法.pycharm连接数据库,django使用mysql数据库.表字段的增删改查.表数据的增删改查 一.创建app,创 ... 
- [Django框架 - 静态文件配置、request对象方法初识、 pycharm链接数据库、ORM实操增删改查、django请求生命周期]
		[Django框架 - 静态文件配置.request对象方法初识. pycharm链接数据库.ORM实操增删改查.django请求生命周期] 我们将html文件默认都放在templates文件夹下 将 ... 
- 用CI框架向数据库中实现简单的增删改查
		以下代码基于CodeIgniter_2.1.3版 用PHP向数据库中实现简单的增删改查(纯代码)请戳 http://www.cnblogs.com/corvoh/p/4641476.html Code ... 
- golang学习之beego框架配合easyui实现增删改查及图片上传
		golang学习之beego框架配合easyui实现增删改查及图片上传 demo目录: upload文件夹主要放置上传的头像文件,main是主文件,所有效果如下: 主页面: 具体代码: <!DO ... 
- 一、数据库表中字段的增删改查,二、路由基础.三、有名无名分组.四、多app共存的路由分配.五、多app共存时模板冲突问题.六、创建app流程.七、路由分发.八、路由别名,九、名称空间.十、反向解析.十一、2.x新特性.十二、自定义转换器
		一.数据库表中字段的增删改查 ''' 直接在modules中对字段进行增删改查 然后在tools下点击Run manage.py Task执行makemigrations和migrate 注意在执行字 ... 
- python的Web框架,Django的ORM,模型基础,MySQL连接配置及增删改查
		Django中的ORM简介 ORM概念:对象关系映射(Object Relational Mapping,简称ORM): 用面向对象的方式描述数据库,去操作数据库,甚至可以达到不用编写SQL语句就能够 ... 
- django-orm框架表单的增删改查
		08.14自我总结 django-orm框架 一.orm基本配置 1.创建django项目 命令行:cmd先去到django创建目录,然后输入django-admin startproject dja ... 
- IDEA+Maven 整合SSM框架实现简单的增删改查(新手入门,傻瓜操作)
		原博客地址:https://blog.csdn.net/khxu666/article/details/79851070 选用SSM框架的原因在目前的企业级Java应用中,Spring框架是必须的.S ... 
- SSM框架之MyBatis框架实现简单的增删改查
		MyBatis框架介绍 MyBatis是一个优秀的数据持久层框架,在实体类和SQL语句之间建立映射关系是一种半自动化的ORM实现,其封装性要低于Hibernate,性能优越,并且小巧,简单易学,应用也 ... 
随机推荐
- asp  TreeView控件的使用
			相对于之前发过一个TreeView控件的使用方法 本次利用js操作,页面无刷新,性能提高 Css编码可能时我的模板页样式被继承下来,导致页面变乱,不需要的可以去掉 前台 <style> . ... 
- 基于Eclipse+Cordova的Android Hybrid应用开发环境搭建
			环境说明 操作系统:Windows 7 64位 Eclipse版本:4.5.2 Release(eclipse-jee-mars-2) JDK版本:1.8 搭建步骤 1.从http://www.ecl ... 
- MySQL学习记录--分组与聚集
			一.group by 子句 group by 字句可对数据进行分组. 以MySQL5.5的sakila数据库中的film数据表举例:查找出各个电影等级的电影总数 mysql>SELECT rat ... 
- 前端MV*框架的意义
			经常有人质疑,在前端搞MV*有什么意义?也有人提出这样的疑问:以AngularJS,Knockout,BackBone为代表的MV*框架,它跟jQuery这样的框架有什么区别?我jQuery用得好好的 ... 
- 我是如何反编译D-Link路由器固件程序并发现它的后门的
			OK,又是周末晚上,没有约会,只有一大瓶Shasta汽水和全是快节奏的音乐…那就研究一下程序吧. 一时兴起,我下载了D-link无线路由器(型号:DIR-100 revA)的固件程序 v1.13.使用 ... 
- python——django入门篇
			要做一只有自学能力的pythoner,尽管大多数自学都是野生并不规范的,会遇到诸多坑,最后用稀奇古怪的方法解决了,但是先了解一些为以后真正学习道路填坑方便了简直不只一点点...重点来了:感觉以班里同学 ... 
- WinDbg 蓝屏dump分析教程
			一.WinDbg是什么?它能做什么? WinDbg是在windows平台下,强大的用户态和内核态调试工具.它能够通过dmp文件轻松的定位到问题根源,可用于分析蓝屏.程序崩溃(IE崩溃)原因,是我们日常 ... 
- 在windows不能正常使用boost og
			现象: 1. 在两个不同的dll中使用static的boost.log.在一个dll中的设置在另一个dll中没有起作用 原因:core::get()返回的是一个单例.在不同的dll中是不同的对象 解决 ... 
- 用computed返回this.$store.state.count,store更改了,但是computed没有调用
			今天出现了这个问题,store更新了,你computed为啥不调用呢??? 另一个.vue更新了state,这个的computed就监听不到了么? 是用这种格式更新的this.$store.commi ... 
- C++ void*的使用
			void*类型可以存储任何类型的指针,使用的时候强制转化成对应类型的指针便可. #include <iostream> #include <vector> using name ... 
