首先在build.gradle下的dependencies下添加引用。

implementation 'org.xutils:xutils:3.3.36'

然后创建一个表实体。

package com.kiba.learn;

import org.xutils.db.annotation.Column;
import org.xutils.db.annotation.Table;


@Table(name = "Cache_User", onCreated = "CREATE UNIQUE INDEX index_name ON Cache_User(id)")
public class Cache_User {

@Column(name = "id", isId = true)
private int id;

@Column(name = "realId")
public int realId;

@Column(name = "name")
public String name;

@Column(name = "loginName")
public String loginName;

@Column(name = "password")
public String password;


public String getLoginName() {
return loginName;
}

public void setLoginName(String loginName) {
this.loginName = loginName;
}

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}

public int getId() {
return id;
}

public void setId(int id) {
this.id = id;
}

public int getRealId() {
return realId;
}

public void setRealId(int realId) {
this.realId = realId;
}

public String getPassword() {
return password;
}

public void setPassword(String password) {
this.password = password;
}
}

然后使用InitDatabaseConfig函数配置daoConfig。

然后使用db = x.getDb(daoConfig)获取数据库管理对象。

然后编写CacheLoginInfo()函数,里面可以写一些测试数据库的新建,更新,查询。

DbManager db;
public DbManager.DaoConfig daoConfig;
//返回值【/storage/emulated/0/Android/data/com.kiba.learn/files】
public String FilesPath_External;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
FilesPath_External = getExternalFilesDir("").getAbsolutePath();
InitDatabaseConfig();
db = x.getDb(daoConfig);
CacheLoginInfo();
}
public void InitDatabaseConfig(){
File file=new File(FilesPath_External,"database");

daoConfig = new DbManager.DaoConfig()
.setDbName("kiba.db")
.setDbDir(file) // 不设置dbDir时, 默认存储在app的私有目录.
.setDbVersion(1)
.setDbOpenListener(new DbManager.DbOpenListener() {
@Override
public void onDbOpened(DbManager db) {
// 开启WAL, 对写入加速提升巨大
db.getDatabase().enableWriteAheadLogging();
}
})
.setDbUpgradeListener(new DbManager.DbUpgradeListener() {
@Override
public void onUpgrade(DbManager db, int oldVersion, int newVersion) {
// TODO: ...
// db.addColumn(...);
// db.dropTable(...);
// ...
// or
// db.dropDb();
}
});
}

这里因为我们只使用xUtils3的数据库,所以不用对视图进行注入,即不用写下面这个代码。

x.view().inject(this);
x.Ext.setDebug(false); //输出debug日志,开启会影响性能

如果要触发dbUpgradeListener升级数据库,可以使用下面代码。

InitDatabaseConfig();
DbManager db = x.getDb(daoConfig);
// 升级数据库从版本3到版本4,并触发setDbUpgradeListener
daoConfig.getDbUpgradeListener().onUpgrade(db,3,4);

也可以直接删除数据,后面使用时会重新创建。

 try {
db.dropDb();
} catch (DbException e) {
e.printStackTrace();
}

更多数据库测试:

 public void TestDatabase() {
try {
DbManager db = x.getDb(daoConfig);
Cache_User sqliteUser = new Cache_User();
sqliteUser.name = "测试" + System.currentTimeMillis();

//db.save(parent);
db.saveBindingId(sqliteUser);//保存对象关联数据库生成的id Calendar calendar = Calendar.getInstance();
calendar.add(Calendar.DATE, -1);
calendar.add(Calendar.HOUR, 3);

List<Cache_User> list = db.selector(Cache_User.class)
.where("id", "<", 54)
.and("time", ">", calendar.getTime())
.orderBy("id")
.limit(10).findAll();

if (list.size() > 0) { }

// test update
sqliteUser.name = "hahaha123" + System.currentTimeMillis();

db.update(sqliteUser);
db.update(sqliteUser, "name", "email");
db.update(Cache_User.class,
WhereBuilder.b("id", "=", 1).and("isAdmin", "=", true),
new KeyValue("name", "test_name"), new KeyValue("isAdmin", false));

List<DbModel> dbModels = db.selector(Cache_User.class)
.groupBy("name")
.select("name", "count(name) as count").findAll();
} catch (Throwable e) {

}
}

PS:获取Activity中的fragment使用如下代码:

Fragment currentFragment = FragmentManager.findFragment(this.findViewById(R.id.fragment_content_main));

----------------------------------------------------------------------------------------------------

注:此文章为原创,任何形式的转载都请联系作者获得授权并注明出处!
若您觉得这篇文章还不错,请点击下方的【推荐】,非常感谢!

xUtils3的使用教程的更多相关文章

  1. 一个C#开发搭建Android框架的心路历程

    前言 Java框架实在是太多了,因为是初学乍练,所以,只好以百度为标准选择框架了. Java的框架文章太难写了,因为他引用了太多框架,而没一个框架都有很繁琐的配置,把每个框架都写一遍,就等于写书了:所 ...

  2. Angular2入门系列教程7-HTTP(一)-使用Angular2自带的http进行网络请求

    上一篇:Angular2入门系列教程6-路由(二)-使用多层级路由并在在路由中传递复杂参数 感觉这篇不是很好写,因为涉及到网络请求,如果采用真实的网络请求,这个例子大家拿到手估计还要自己写一个web ...

  3. Angular2入门系列教程6-路由(二)-使用多层级路由并在在路由中传递复杂参数

    上一篇:Angular2入门系列教程5-路由(一)-使用简单的路由并在在路由中传递参数 之前介绍了简单的路由以及传参,这篇文章我们将要学习复杂一些的路由以及传递其他附加参数.一个好的路由系统可以使我们 ...

  4. Angular2入门系列教程5-路由(一)-使用简单的路由并在在路由中传递参数

    上一篇:Angular2入门系列教程-服务 上一篇文章我们将Angular2的数据服务分离出来,学习了Angular2的依赖注入,这篇文章我们将要学习Angualr2的路由 为了编写样式方便,我们这篇 ...

  5. Angular2入门系列教程4-服务

    上一篇文章 Angular2入门系列教程-多个组件,主从关系 在编程中,我们通常会将数据提供单独分离出来,以免在编写程序的过程中反复复制粘贴数据请求的代码 Angular2中提供了依赖注入的概念,使得 ...

  6. Angular2入门系列教程1-使用Angular-cli搭建Angular2开发环境

    一直在学Angular2,百忙之中抽点时间来写个简单的教程. 2016年是前端飞速发展的一年,前端越来越形成了(web component)组件化的编程模式:以前Jquery通吃一切的田园时代一去不复 ...

  7. wepack+sass+vue 入门教程(三)

    十一.安装sass文件转换为css需要的相关依赖包 npm install --save-dev sass-loader style-loader css-loader loader的作用是辅助web ...

  8. wepack+sass+vue 入门教程(二)

    六.新建webpack配置文件 webpack.config.js 文件整体框架内容如下,后续会详细说明每个配置项的配置 webpack.config.js直接放在项目demo目录下 module.e ...

  9. wepack+sass+vue 入门教程(一)

    一.安装node.js node.js是基础,必须先安装.而且最新版的node.js,已经集成了npm. 下载地址 node安装,一路按默认即可. 二.全局安装webpack npm install ...

随机推荐

  1. eclipes常见操作总结及项目2和3经验总结

    eclipes常见操作总结及项目2经验总结 eclipes提示: 打开eclipes 选择window->perference->java->editor->content a ...

  2. 使用 elementUI 的表单进行查询,表单中只有一个文本框时,回车会自动触发表单的提交事件,导致页面的刷新。

    使用elementUI的el-form组件进行查询时,当输入框仅有一项时,回车自动提交表单,浏览器会刷新页面: 原因:由于当表单只有一个文本框时,按下回车将会触发表单的提交事件, 从而导致页面刷新. ...

  3. vue-cli 项目中使用 v-chart 及导出 chart 图片

    安装: npm i v-charts echarts -S 组件中使用: 1 <template> 2 <div class="app-chart"> 3 ...

  4. CodeForce-812C Sagheer and Nubian Market(二分)

    Sagheer and Nubian Market CodeForces - 812C 题意:n个货物,每个货物基础价格是ai. 当你一共购买k个货物时,每个货物的价格为a[i]+k*i. 每个货物只 ...

  5. CF11D-A Simple Task【状压dp】

    正题 题目链接:https://www.luogu.com.cn/problem/CF11D 题目大意 给出\(n\)个点\(m\)条边的一张简单无向图,求它的简单环的个数. \(1\leq n\le ...

  6. P3273-[SCOI2011]棘手的操作【线段树,并查集】

    正题 题目链接:https://www.luogu.com.cn/problem/P3273 题目大意 \(n\)个点有权值,要求支持操作 连接两个点 单点加权 联通块加权 全图加权 单点询问 联通块 ...

  7. Pycharm软件学生和老师可申请免费专业版激活码

    有一种邮箱,叫做教育邮箱,这东西在这个互联网的世界有很大的优惠及特权,在 Jetbrain 这里, 如果你有教育邮箱(没有教育邮箱怎么办?.edu.cn后缀的邮箱)但很多学生.甚至老师都未必有. 你只 ...

  8. 腾讯的表妹告诉我怎么学Python,今天就教我搭建Python环境和基本语法,我【码上开始】

    本文首发公众号:码上开始 环境准备 Pycharm Python3 window10/win7 安装 Python 打开Python官网地址 下载 executable installer,x86 表 ...

  9. Python爬虫:通过做项目,小编了解了酷狗音乐的加密过程

    1.前言 小编在这里讲一下,下面的内容仅供学习参考,切莫用于商业活动,一经被相关人员发现,本小编概不负责!读者切记切记. 2.获取音乐播放列表 其实,这就是小编要讲的重点,因为就是这部分用到了加密. ...

  10. Java字符串的初始化与比较

    Java字符串的初始化与比较 简单的总结:直接赋值而不是使用new关键字给字符串初始化,在编译时就将String对象放进字符串常量池中:使用new关键字初始化字符串时,是在堆栈区存放变量名和内容:字符 ...