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...
- 一周热门
- 最近发表
- 标签列表
-
- mydisktest_v298 (34)
- document.appendchild (35)
- 头像打包下载 (61)
- acmecadconverter_8.52绿色版 (39)
- word文档批量处理大师破解版 (36)
- server2016安装密钥 (33)
- mysql 昨天的日期 (37)
- parsevideo (33)
- 个人网站源码 (37)
- centos7.4下载 (33)
- mysql 查询今天的数据 (34)
- intouch2014r2sp1永久授权 (36)
- 先锋影音源资2019 (35)
- jdk1.8.0_191下载 (33)
- axure9注册码 (33)
- pts/1 (33)
- spire.pdf 破解版 (35)
- shiro jwt (35)
- sklearn中文手册pdf (35)
- itextsharp使用手册 (33)
- 凯立德2012夏季版懒人包 (34)
- 反恐24小时电话铃声 (33)
- 冒险岛代码查询器 (34)
- 128*128png图片 (34)
- jdk1.8.0_131下载 (34)