Android xUtils框架(一) DbUtils
2024-09-01 08:52:46
在DbUtils中,只支持4中数据类型:
- public enum ColumnDbType {
- INTEGER("INTEGER"), REAL("REAL"), TEXT("TEXT"), BLOB("BLOB");
- private String value;
- ColumnDbType(String value) {
- this.value = value;
- }
- @Override
- public String toString() {
- return value;
- }
- }
而在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 唯一约束
查询
- try {
- db.saveAll(list);
- db.findAll(Child.class);
- db.findAll(Selector.from(Child.class).where("id", ">", 2));
- db.findById(Child.class, 1);
- db.findFirst(Child.class);
- db.findFirst(Selector.from(Child.class).where("id", ">", 2));
- db.findDbModelAll(DbModelSelector.from(Child.class).groupBy("hobby").having(WhereBuilder.b("id", ">", 2)));
- db.findDbModelFirst(DbModelSelector.from(Child.class).groupBy("hobby").having(WhereBuilder.b("id", ">", 2)));
- Cursor c = db.execQuery(new SqlInfo("select * from child;"));
- //findDbModelFirst和findDbModelAll相当是对execQuery做了再次封装,
- //返回的DbModel中,封装了通过列名获取value的方法,如:String getString(String columnName)等等.
- DbModel model = db.findDbModelFirst(new SqlInfo("select * from child;")); //采取原生sql语句,可以做多表查询操作
- List<DbModel> modellist = db.findDbModelAll(new SqlInfo("select * from child;"));
- } catch (DbException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
用于更新表结构的数据,保存原来的数据
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注解定义:
- @Target(ElementType.FIELD)
- @Retention(RetentionPolicy.RUNTIME)
- public @interface Check {
- String value();
- }
DbUtils解析代码:
- String check = ColumnUtils.getCheck(column.getColumnField());
- if (check != null) {
- sqlBuffer.append(" CHECK(").append(check).append(")");
- }
用法:
- @Column(column="age")
- @Check("age > 18")
- private int age;
xUtils系列之DbUtils-增,删,更新,替换操作
http://blog.csdn.net/androidresearch/article/details/45704337
最新文章
- centos无法正常启动,报chown: invalid user:&#39;root:root&#39;
- The guard was taken to hospital in a critical condition.
- OC对象的动态和静态构造区别
- DEDECMS中直接通过数据库插入文章
- [Bhatia.Matrix Analysis.Solutions to Exercises and Problems]ExI.3.6
- vagrant 使用方法
- 201521123048《Java程序设计》第6周学习总结
- 理解滑动平均(exponential moving average)
- 机器学习总结(一) Adaboost,GBDT和XGboost算法
- bootstrapvalidator的简单校验【必填校验、长度校验、是否存在校验(remote)】
- 下载频道--IT资源关东煮第二期[申明:来源于网络]
- zookeeper报错: org.I0Itec.zkclient.exception.ZkMarshallingError: java.io.EOFException
- 第二章(java程序设计)第三章(语言基础)
- java框架篇---struts开发
- Maven最佳实践-distributionManagement
- Synycovery 7.18f 一个优秀的同步软件
- fiddler配置及使用教程
- 根据img的url 判断img的图片大小
- ant design pro (三)路由和菜单
- ASP.NET MVC中的控制器激活与反射之间的联系(帮助理解)