数据库

1导入依赖

//根gradle

classpath 'org.greenrobot:greendao-gradle-plugin:3.2.2'

//项目gradle

implementation 'org.greenrobot:greendao:3.2.2'
greendao { schemaVersion 1
           daoPackage'包名.database'//设置时生成代码的目录    
            targetGenDir'src/main/java'//设置DaoMaster、DaoSession、Dao目录
 }
apply plugin: 'org.greenrobot.greendao'

2.定会一个app ,并在清单文件中配置

package com.example.thinkpad.wsjshuju;

import android.app.Application;

import com.example.thinkpad.wsjshuju.database.DaoMaster;

public class App extends Application{

    private DaoManager d;

    @Override
    public void onCreate() {
        super.onCreate();
        d = DaoManager.instance(this);

    }
}
还要定义一个bean类
@Entity(nameInDb = "person", active = true)
public class person {
    @Id(autoincrement = true)
    //自增长
    private  Long id;
    //在数据库中定义名字   就是想定义的名字和数据库中不一样时用
    @Property(nameInDb = "name")
    private  String name1;
    private  int age;
    //不想在数据库中存放该变量
    @Transient
    private  int  gonder;
  
    }j
建一个
DaoManager类

package com.example.thinkpad.wsjshuju;

import android.content.Context;

import com.example.thinkpad.wsjshuju.database.DaoMaster;
import com.example.thinkpad.wsjshuju.database.DaoSession;

import java.util.concurrent.atomic.AtomicIntegerArray;

public class DaoManager {
    private static DaoManager daoManager;
    private final DaoSession daoSession;

    private  DaoManager(Context context){
        daoSession = DaoMaster.newDevSession(context, "my.db");

    }
    public  static  DaoManager instance(Context context){
       if (daoManager==null){
           synchronized (DaoManager.class){
               if (daoManager==null){
                   daoManager= new DaoManager(context);
               }
           }
       }
       return  daoManager;
    }

    public DaoSession getDaoSession() {
        return daoSession;
    }
}
package com.example.thinkpad.wsjshuju;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;

import com.example.thinkpad.wsjshuju.database.DaoSession;
import com.example.thinkpad.wsjshuju.database.personDao;

import java.util.List;

public class MainActivity extends AppCompatActivity {

    private DaoSession daoSession;
    private personDao personDao;
    private  int index;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        daoSession = DaoManager.instance(this).getDaoSession();
        personDao = daoSession.getPersonDao();

    }


    public void add(View view) {
        index++;
      personDao.insert(new person(null,"wang"+index,index));
    }

    public void upate(View view) {
        person person = personDao.queryBuilder()
                .where(com.example.thinkpad.wsjshuju.database.personDao.Properties.Id.eq(1))
                .build().unique();
        person.setAge(1000);
        personDao.update(person);
    }

    public void delete(View view) {
        person person = personDao.queryBuilder()
                .where(com.example.thinkpad.wsjshuju.database.personDao.Properties.Id.eq(1))
                .build().unique();
        personDao.delete(person);
    }
    public void query(View view) {
        List<person> list = personDao.queryBuilder()
                .where(com.example.thinkpad.wsjshuju.database.personDao.Properties.Id.ge(5))
                .build().list();
        Log.e("tag","query"+list.get(0).getId());
    }

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值