首先在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. golang中的闭包_closure

    闭包_Closure: 1.一般情况下,第一类对象都是独立的封闭的存在的,独立的封闭的起作用; 2.第一类对象可以被创建; 3.第一类对象可以作为参数传递给其他函数; 4.第一类对象可以赋值给变量实体 ...

  2. excel中快速删除空白行/区域

    选中要删除的空白所在的列 按Ctrl+G 选择空值 右键->删除->整行

  3. 解决sofaboot项目右键入口方法没有run sofa application

    选中入口方法名,右键出现run sofa application

  4. 深入学习Composer原理(二)

    本系列的第二篇文章,这次我们聊聊:spl_autoload_register()函数 PHP的SPL库作为扩展库,已经于5.3.0版本后默认保持开启,成为PHP的一组强大的核心扩展库.大家有时间可以多 ...

  5. PHP的OpenSSL加密扩展学习(二):非对称加密

    上篇文章,我们了解了关于对称和非对称加密的一些相关的理论知识,也学习了使用 OpenSSL 来进行对称加密的操作.今天,我们就更进一步,学习 OpenSSL 中的非对称加密是如何实现的. 生成私钥 通 ...

  6. SQLSTATE[HY000]: General error: 1366 Incorrect string value: '\xF0\x9F\x90\xA3\xF0\x9F...' for column

    在做微信公众号保存用户数据时出现这种错误,一直不知道是哪里的原因,后来发现那个用户昵称带着一只兔子表情,由于数据库编码限制不能保存数据,所有需要先编码, 用PHP的函数就是base64_encode, ...

  7. Linux下Nodejs安装(完整详细)转

    Linux下安装有两种方式,一个是下载源码make编译安装. 另外一种是比较推荐的,直接下载编译好的二进制,官方比较推荐后者. //Linux 64bit version wget --no-chec ...

  8. http报文常见的请求头、响应头

    http报文常见的请求头 1.Accept Accept: text/html  浏览器可以接受服务器回发的类型为 text/html. Accept: /   代表浏览器可以处理所有类型,(一般浏览 ...

  9. 当你创建了一个 Deployment 时,Kubernetes 内部发生了什么?

    我们通常使用 kubectl 来管理我们的 Kubernetes 集群. 当我们需要一个 Nginx 服务时,可以使用以下命令来创建: kubectl create deployment nginx ...

  10. P4630-[APIO2018]Duathlon铁人两项【圆方树】

    正题 题目链接:https://www.luogu.com.cn/problem/P4630 题目大意 \(n\)个点\(m\)条边的一张无向图,求有多少对三元组\((s,c,f)\)满足\(s\ne ...