首先在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. AWK的内置变量

    ARGC: number (2) 在命令行提供的参数的个数,不包括命令awkARGIND: number (0) 当前文件中正在处理的 ARGV 数组的索引值. 文件的位置,从1开始计数.一个文件处在 ...

  2. PHP中一个好玩的性别判断扩展

    今天我们来学习的一个扩展同时它也是非常小众的一个扩展,其实说白了,或许是根本没什么人用过得扩展.当然,我们也只是出于学习的目的来看看这个扩展到底是什么东西,有什么好玩的地方. 扩展说明 Gender ...

  3. update修改某个字段的值

    ---恢复内容开始--- 例:给表名 ecs_article中 content字段 的 /tianyuan 替换成 11  加where条件:UPDATE ecs_article set conten ...

  4. 限制只有VIP会员才能下载Ecshop文章页的附件

    以官方2.7.2默认模板为基础来讲述一下"如何在文章详情页限制只有VIP会员才能下载相关附件"这里假设VIP会员的等级ID为2首先修改 article.php 文件打开 /arti ...

  5. 第三方api接口

    做为一个软件测试工程师,你要学习接口测试,需要练习,那么就要有调用的api,可以参考以下的文章. 国内7款API供应平台功能对比及详细介绍 https://blog.csdn.net/ishxiao/ ...

  6. springboot pom.xml

    Demo project for Spring Boot <?xml version="1.0" encoding="UTF-8"?> <pr ...

  7. P1912-[NOI2009]诗人小G【四边形不等式,单调队列】

    正题 题目链接:https://www.luogu.com.cn/problem/P1912 题目大意 给出\(n\)个字符串,把这些字符串依次用空格(算一个长度)连接分成若干段,若一段长度为\(x\ ...

  8. 这是我见过最简单的博客文只有一张图,Python基础10分钟学完

  9. [源码解析] PyTorch 流水线并行实现 (4)--前向计算

    [源码解析] PyTorch 流水线并行实现 (4)--前向计算 目录 [源码解析] PyTorch 流水线并行实现 (4)--前向计算 0x00 摘要 0x01 论文 1.1 引论 1.1.1 数据 ...

  10. 提问式复习:图文回顾 redo log 相关知识

    原文链接:提问式复习:图文回顾 redo log 相关知识 1.如何提升 redo日志 的写性能? 为了保证 redo日志 不丢失,会在磁盘中开辟一块空间将日志保存起来.但是这样会有一个问题,磁盘的读 ...