百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

android使用greendao来保存数据

csdh11 2025-03-11 14:51 4 浏览

有时我们的数据属于保存到数据库,对于Android应用和IOS应用,我们一般都会使用SQLite这个嵌入式的数据库作为我们保存数据的工具。由于我们直接操作数据库比较麻烦,而且管理起来也非常的麻烦,所以我今天结束用greendao来保存数据。如果对我的文章感兴趣,欢迎订阅我的头条号:一点热,yeehot.com.

1、我们创建一个Android工程,这里就不着重结束了。

2、使用gradle导入greendao包和greendao-generator包并配置我们的路径。

其中greendao用于我们操作数据库的类。而greendao-generator是用来产生我们的的数据库的数据类。包含了Bean、DAO、DaoMaster、DaoSession 。

我们在项目中添加如下的代码

compile 'org.greenrobot:greendao:3.0.1'

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

3、在src/main下创建一个java-gen的包,用于生成我们的bean类文件

4、创建Dao的生成类文件YeehotGeneratorDao.java,用于生成上面说的几个类。这里我直接在项目里面创建了。

public class YeehotGeneratorDao {

public static void main(String[] args) throws Exception {

//DB_VESION,BEAN 版本号与 包路径

Schema schema = new Schema(1, "com.yeehot.greendao");

addTable(schema);

//第二个参数是我们刚刚的包db的路径。

new DaoGenerator().generateAll(schema, "/Users/yeehot/Desktop/a/GreendaoInfo/app/src/main/java-gen");

}

/**

* @param schema

*/

/**

* @param schema

*/

private static void addTable(Schema schema) {

// 创建一个实体,其实就是表名

Entity User = schema.addEntity("User");

//添加表的属性。

User.addIdProperty();

//添加字符串的属性

User.addStringProperty("email").notNull();

User.addStringProperty("passwd");

User.addStringProperty("userid");

}

}

5、运行一下YeehotGeneratorDao

大概过了一会就生成我们需要的类文件了,如图

6、有了上面的几个类后,我们就基本可以操作我们的数据库了。

我们在创建的登陆页面里面测试看看

首先,我们需要创建一个创建数据库的方法,这样里面的表才能存放进去

package com.yeehot.greendaoinfo;

import android.database.Cursor;

import android.database.sqlite.SQLiteDatabase;

import android.support.v7.app.AppCompatActivity;

import android.os.Bundle;

import android.util.Log;

import android.view.View;

import android.widget.Button;

import android.widget.EditText;

import com.yeehot.greendaoinfo.db.DaoMaster;

import com.yeehot.greendaoinfo.db.DaoSession;

import com.yeehot.greendaoinfo.db.User;

import com.yeehot.greendaoinfo.db.UserDao;

import org.greenrobot.greendao.generator.Query;

import org.greenrobot.greendao.query.QueryBuilder;

import java.text.DateFormat;

import java.util.Date;

import java.util.List;

public class MainActivity extends AppCompatActivity {

private SQLiteDatabase db;

private DaoMaster daoMaster;

private DaoSession daoSession;

private Cursor cursor;

private EditText email;

private Button add;

private Button search;

private Button delete;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

email= (EditText) findViewById(R.id.email);

add= (Button) findViewById(R.id.add);

search= (Button) findViewById(R.id.search);

delete= (Button) findViewById(R.id.delete);

CreateDB();

add.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View v) {

addEmail();

}

});

search.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View v) {

FindEmail();

}

});

delete.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View v) {

DeleteEmail();

}

});

}

private void CreateDB() {

// DevOpenHelper

DaoMaster.DevOpenHelper helper = new DaoMaster.DevOpenHelper(this, "yeehotdb", null);

db = helper.getWritableDatabase();

daoMaster = new DaoMaster(db);

daoSession = daoMaster.newSession();

}

private void addEmail() {

String emailinfo = email.getText().toString();

// 插入操作,简单到只要你创建一个 Java 对象

User note = new User(null,emailinfo,"1234","0001");

daoSession.getUserDao().insert(note);

}

private void FindEmail() {

Query query = daoSession.getUserDao().queryBuilder()

.where(UserDao.Properties.Email.eq(email.getText().toString()))

.orderAsc(UserDao.Properties.Id)

.build();

List list=query.list();

QueryBuilder.LOG_SQL = true;

QueryBuilder.LOG_VALUES = true;

}

private void DeleteEmail() {

// daoSession.getUserDao().deleteByKey(id);

daoSession.getUserDao().deleteAll();

}

}

相关推荐

如何在HeidiSQL工具中查看SQL的执行时间

在HeidiSQL工具中,可以通过两种方式查看SQL语句的执行时间:1.SQL日志(SQLLog)窗口HeidiSQL的SQL日志窗口会记录所有执行的SQL语句及其执行时间。specifical...

SQL学习:实例讲解SQL必会的12个高频语句

在数据库查询中,总结了12个高频常用SQL语句,供大家参考学习:1、复制表结构,不包括数据(用于建立同一个表结构)...

Android注解使用之使用Support Annotations注解优化代码

前言:前面学习总结了Java注解的使用,博客地址详见Java学习之注解Annotation实现原理,从本质上了解到什么注解,以及注解怎么使用?不要看见使用注解就想到反射会影响性能之类,今天我们就来学习...

Android多任务并行下载、断点续传

多任务并行下载,断点续传,要做起来其实还是很麻烦的,所以推荐一个开源库,这个开源库叫Aria,刚好是我前一久搞断点续传时发现的,仔细了解后发现,真香!!!它简单易用,是个稳当高效的下载框架,不仅可以...

微信8.0.19安卓内测版怎么升级 微信8.0.19内测版下载与更新一览

昨天夜间,安卓版微信8.0.19再次迎来了更新!距离正式版间发布隔了一周,经过短暂体验同样带来不少新功能。在此前已经上线了iOS版微信中的语音消息断续播放和批量删除好友功能,也在本次微信8.0.19内...

android使用greendao来保存数据

有时我们的数据属于保存到数据库,对于Android应用和IOS应用,我们一般都会使用SQLite这个嵌入式的数据库作为我们保存数据的工具。由于我们直接操作数据库比较麻烦,而且管理起来也非常的麻烦,所以...

AndroidStudio_安卓原生开发_FileProvider使用

在制作apk在线升级的功能的时候,需要首先去,请求后台接口,去获取是否有需要更新的版本,有的话需要先去下载对应版本的文件,保存在手机上,然后再去,获取这个版本文件,获取的时候,需要用到文件共享.这个时...

详解安卓的FileProvider是如何提升文件共享安全的

自Android7.0开始,Android框架开启了严格模式(StrictMode),禁止应用将file:///开头的Uri共享给其他的应用读写文件,否则会收到...

咋回事?第一代摩托Moto X 还没吃上安卓5.0

IT之家讯2月11日消息,想必第一代MotoX用户感觉自己身处“噩梦”中。摩托罗拉家所有手机,甚至是档次比较低的MotoG和MotoE都已经吃上或正准备开吃Android5.0。那么为何第一...

推理帝的胜利:Android L 官方正式版代号叫柠檬蛋白派?

按照Android版本命名法则,在Android4.4被命名为KitKat之后,接下来的Android版本命名应该与L有关,所以在AndroidL测试版被公布之后,我们几乎...

「图」iOS端Outlook正测试共享邮箱功能 Android端随后开放

iOS端Outlook正在测试共享邮箱(SharedMailboxes)功能。微软iOS平台产品线的负责人MichaelPalermiti今天宣布已启动测试工作,该功能允许多个用户从公共邮箱(例如...

用上它,你就能体验到 MIUI 12 最令人惊艳的功能

MIUI12前天发布会上推出的全局自由小窗功能,完善程度着实令人惊喜。厂商为提升用户体验各显其能,作为用户当然举双手欢迎。但一想到我卑微的原生安卓用户身份,以及目前Android8.0才是安...

安卓微信8.0内测下载地址分享:安卓机升级微信8.0动态表情试用

安卓微信8.0内测哪里下载?相信很多用户在寻找微信8.0的安卓内测包,现在小编给大家带来了微信8.0安卓内测邀请链接,感兴趣的小伙伴赶紧试试吧!安卓微信8.0内测版本:点击进入链接在浏览器打开后,复制...

您所请求的网址(URL)无法获取

发生了下列的错误:Unabletoforwardthisrequestatthistime.目前无法将您的请求进行转送操作Thisrequestcouldnotbefor...

深入浅出SlidingMenu

如果想直接查看源码的话可以从我的Github上下载查看:https://github.com/zhanghuijun0/demo-for-android/tree/master/SlidingMenu...