在DbUtils中,只支持4中数据类型:

  1. public enum ColumnDbType {
  2. INTEGER("INTEGER"), REAL("REAL"), TEXT("TEXT"), BLOB("BLOB");
  3. private String value;
  4. ColumnDbType(String value) {
  5. this.value = value;
  6. }
  7. @Override
  8. public String toString() {
  9. return value;
  10. }
  11. }

而在Java中,我们有8种基本类型,但是我们在使用DbUtils时,都能正确的对这些数据类型进行存取,
这是怎么做到的呢?

第一步,先创建数据库

创建数据库

DaoConfig config = new DaoConfig(context);

config.setDbName("xUtils-demo"); //数据库名

config.setDbVersion(1);  //数据库版本号

DbUtils db = DbUtils.create(config);//db还有其他的一些构造方法,比如含有更新表版本的监听器的 假如不设置监听器默认在升级的时候会将旧版本的表删掉

第二步,根据需求创建实体类,然后进行注解,注解方式如下图

下面这是常用到的一些Annotation(注解)    //注解可不等同于注释,不要混为一谈

@Check    check约束
  @Column   列名
  @Finder   一对多、多对一、多对多关系(见sample的Parent、Child中的使用)
  @Foreign  外键
  @Id       主键,当为int类型时,默认自增。 非自增时,需要设置id的值
  @NoAutoIncrement  不自增
  @NotNull  不为空
  @Table    表名
  @Transient  不写入数据库表结构
  @Unique   唯一约束

查询

  1. try {
  2. db.saveAll(list);
  3. db.findAll(Child.class);
  4. db.findAll(Selector.from(Child.class).where("id", ">", 2));
  5. db.findById(Child.class, 1);
  6. db.findFirst(Child.class);
  7. db.findFirst(Selector.from(Child.class).where("id", ">", 2));
  8. db.findDbModelAll(DbModelSelector.from(Child.class).groupBy("hobby").having(WhereBuilder.b("id", ">", 2)));
  9. db.findDbModelFirst(DbModelSelector.from(Child.class).groupBy("hobby").having(WhereBuilder.b("id", ">", 2)));
  10. Cursor c = db.execQuery(new SqlInfo("select * from child;"));
  11. //findDbModelFirst和findDbModelAll相当是对execQuery做了再次封装,
  12. //返回的DbModel中,封装了通过列名获取value的方法,如:String getString(String columnName)等等.
  13. DbModel model = db.findDbModelFirst(new SqlInfo("select * from child;")); //采取原生sql语句,可以做多表查询操作
  14. List<DbModel> modellist = db.findDbModelAll(new SqlInfo("select * from child;"));
  15. } catch (DbException e) {
  16. // TODO Auto-generated catch block
  17. e.printStackTrace();
  18. }
用于更新表结构的数据,保存原来的数据
public static void updateTable(DbUtils dbUtils, Class<?> tClass) {
try {
if (dbUtils.tableIsExist(tClass)) {
String tableName = tClass.getName();
tableName = tableName.replace(".", "_");
String sql = "select * from " + tableName;
//声名一个map用来保存原有表中的字段
 Map<String, String> filedMap = new HashMap<>();
//执行自定义的sql语句
  Cursor cursor = dbUtils.execQuery(sql);
int count = cursor.getColumnCount();
for (int i = 0; i < count; i++) {
filedMap.put(cursor.getColumnName(i), cursor.getColumnName(i));
}
//cursor在用完之后一定要close
 cursor.close();
//下面用到了一些反射知识,下面是获取实体类的所有私有属性(即我们更改表结构后的所有字段名)
 Field[] fields = UserInfo.class.getDeclaredFields(); for (int i = 0; i < fields.length; i++) {
if (filedMap.containsKey(fields[i].getName())) {
//假如字段名已存在就进行下次循环
 continue;
} else {
//不存在,就放到map中,并且给表添加字段
 filedMap.put(fields[i].getName(), fields[i].getName());
//根据属性的类型给表增加字段
if (fields[i].getType().toString().equals("class java.lang.String")) { dbUtils.execNonQuery("alter table " + tableName + " add " + fields[i].getName() + " TEXT ");
} else if (fields[i].getType().equals("int") || fields[i].getType().equals("long") || fields[i].getType().equals("boolean")) {
dbUtils.execNonQuery("alter table " + tableName + " add " + fields[i].getName() + " INTEGER ");
}
}
} }
} catch (DbException e) {
e.printStackTrace();
}
} 注意事项:
1.当类中有id或_id时,可以省略Id的注解 2.当id,_id或@Id注解Field为integer型时,primary key默认为autoincrement
此时,可以用@NoAutoIncrement注解该字段,使其不自增 3.@NoAutoIncrement注解仅用于primary key. 4.一个类中,只可以使用一个@Id注解,当使用多个@Id注解时,primary key未知 5.一个类中,如果同时存在id,_id,@Id时,primary key优先级为 @Id > id > _id 6.@Id如果使用Column参数,则primary key列名为Column值 7.@Id如果不指明参数,则primary key列名为字段名  

xUtils系列之DbUtils-Check注解

Check注解定义:

  1. @Target(ElementType.FIELD)
  2. @Retention(RetentionPolicy.RUNTIME)
  3. public @interface Check {
  4. String value();
  5. }

DbUtils解析代码:

  1. String check = ColumnUtils.getCheck(column.getColumnField());
  2. if (check != null) {
  3. sqlBuffer.append(" CHECK(").append(check).append(")");
  4. }

用法:

  1. @Column(column="age")
  2. @Check("age > 18")
  3. private int age;

xUtils系列之DbUtils-增,删,更新,替换操作

http://blog.csdn.net/androidresearch/article/details/45704337

Android xUtils框架(一) DbUtils的更多相关文章

  1. Android Xutils 框架(转)

    Android Xutils 框架 (转) 目录(?)[-] xUtils简介 目前xUtils主要有四大模块 使用xUtils快速开发框架需要有以下权限 混淆时注意事项 DbUtils使用方法 Vi ...

  2. Android Xutils框架使用问题及解决办法

    刚刚写了篇博客,提了下在使用XUtils时遇到的一个问题Android Xutils框架HttpUtil Get请求缓存问题 ,既然已经提起来这个问题,那我想了下,就把之前使用Xutils时遇到的几个 ...

  3. Android Xutils框架HttpUtil Get请求缓存问题

    话说,今天和服务器开发人员小小的逗逼了一下,为啥呢? 话说今天有个"收藏产品"的请求接口,是get request的哦,我客户端写好接口后,点击"收藏按钮",返 ...

  4. Android Xutils 框架

    XUtils是git上比较活跃 功能比较完善的一个框架,是基于afinal开发的,比afinal稳定性提高了不少,下面是介绍: 鉴于大家的热情,我又写了一篇Android 最火框架XUtils之注解机 ...

  5. android xUtils get post

    使用android xUtils框架,进行http的get和post验证. 参考链接: https://github.com/wyouflf/xUtils3 http://blog.csdn.net/ ...

  6. xUTils框架的学习(二)

    这章讲的是框架的DbUtils模块的学习 三 xUtils框架的DButils模块 最开始接触这个框架就是从数据库模块开始的.当时的需求是需要记录用户的登录数据,保存在本地以便进行离线登录.首先想到的 ...

  7. Android使用XUtils框架上传照片(一张或多张)和文本,server接收照片和文字(无乱码)

    Android上传图片,这里我使用了如今比較流行的XUtils框架.该框架能够实现文件上传.文件下载.图片缓存等等,有待研究. 以下是Android端上传的代码: xUtils.jar下载 Strin ...

  8. xUtils框架的使用

    xUtils简介 xUtils 包含了很多实用的android工具,xUtils 源于Afinal框架,对Afinal进行了大量重构,使得xUtils支持大文件上传,更全面的http请求协议支持,拥有 ...

  9. 值得推荐的android开源框架

    1.volley 项目地址https://github.com/smanikandan14/Volley-demo (1) JSON,图像等的异步下载: (2) 网络请求的排序(scheduling) ...

随机推荐

  1. Linux上网设置

    ifconfig 命令查看网络设置 步骤1.配置/etc/sysconfig/network-scripts/ifcfg-eth0 里的文件.有的是(ifcfg-ens33) 文件 CentOS下的i ...

  2. castle windsor学习-----Fluent Registration API 注册

    使用xml配置和fluent注册两种搭配使用需要注意的是: 如果先在WindsorContainer构造函数指明用xml配置进行注册,如下设置 IWindsorContainer container ...

  3. Entity Framework 学习笔记(二)之数据模型 Model 使用过程

    Entity Framework  数据模型 Model 创建的使用: 开发环境:VS2012 数据库:SQL Server 2008 Entity Framework  版本:6.12 下面是新建的 ...

  4. Codeforces 429B Working out:dp【枚举交点】

    题目链接:http://codeforces.com/problemset/problem/429/B 题意: 给你一个n*m的网格,每个格子上有一个数字a[i][j]. 一个人从左上角走到右下角,一 ...

  5. 英语发音规则---L字母

    英语发音规则---L字母 一.总结 一句话总结:[l]音在词首和词尾的发音不同,/l/+其它音节./l/+元音./l/+/j/称它为清晰/l/,发清晰/l/音时,在下一个音即将出出时舌头离开上齿龈,迅 ...

  6. Appium-关于appium的原生控件的 xpath 定位问题及常用方法

    最近遇到的项目,发现很多元素,都没有标明id.text.content-desc,classname中又有很多是相同,导致无法定位 第一,appium1.5及之后的版本废弃了name属性(如name= ...

  7. cocos2dx & cocostudio 实现模态对话框

    用cocos2dx实现模态对话框 http://www.cnblogs.com/mrblue/(转自于) ui部分使用了cocoStudio,注意这里没有实现怎么屏蔽其他的输入事件,其他的文档已经太多 ...

  8. 关于Windows与Linux下32位与64位开发中的数据类型长度的一点汇总

    32位与64位的数据类型长度是不一样的,而且windows和linux也有些许区别,下面把64位下的数据长度列表如下(无符号unsigned和有符号的长度一样): linux64            ...

  9. 基于v4l2 ffmpeg x264的视频远程监控(附上编译好的库文件)

    说明:主要是基于ghostyu网友整理的< arm mini2440 基于v4l2 ffmpeg x264的视频远程监控>.自己做了一遍,遇到不少问题,就整理记录下来. 1.平台 硬件:a ...

  10. Hive安装配置要点

    官网下载安装包: 在Profile下面定义HIVE_HOME以及HADOOP_HOME,然后在PATH下面添加HOME/bin目录,用于在命令行直接敲beeline,hive即可执行命令: 需要在ha ...