富利娱乐平台注册网址:
易彩娱乐平台注册注册:
TigerDB是一个简单的Android ORM框架,它能让你一句话实现数据库的增删改查,同时支持实体对象的持久化和自动映射,同时你也不必关心表结构的变化,因为它会自动检测新增字段来更新你的表结构。
该库主要包括如下几个要点:
根据实体对象自动建表、新增字段(SQLite不支持删除字段列)
支持注解配置表名、字段名、字段默认值、主键是否自增长以及哪些字段不作为数据表中的映射字段
直接映射实体对象到SQLite数据库,实现一行代码对SQLite数据库增删改查
支持在SDCard中新建数据库db
解决在onCreate,onUpgrade中执行数据库其他操作时出现的异常(java.lang.IllegalStateException: getDatabase called recursively)
支持原生SQL语句操作数据库
该ORM库使用过程中的主要类说明:
SQLiteDBConfig:主要用于设置数据库的名字、创建路径、版本号、数据创建更新时的监听
SQLiteDB:创建完数据库之后,主要通过此类来操作数据库的增删改查
SQLiteDBFactory:该类主要用于创建SQLite数据库,同时缓存当前创建的SQLiteDB对象
CursorUtil:查询数据库时,检测游标对象Cursor是否正常,解析Cursor数据为实体对象
IDBListener:数据库创建、升级时的监听类,提供了空实现SimpleDBListener
Column:该注解用来设置字段名、字段默认值
PrimaryKey:该注解用来设置主键、主键字段名、以及主键是否为自增长
Table:该注解用来设置表名,不设置的话默认类名为表名
NotDBColumn:该注解用来设置哪些实体属性不映射到数据表中
主要用法如下:
//新建实体,可以通过注解@Table设置表名,如果不设置默认以类名User作为表名
publicclassUser{
//设置主键id为自增长,也可以通过注解@Column设置字段名或字段默认值
@PrimaryKey(isAutoGenerate=true)
privatelongid;
privateStringname;
//设置age字段默认值为1
@Column(defaultValue="1")
privateintage;
//该字段不作为数据表中的字段
@NotDBColumn
privateStringbz;
//必须实现无参构造
publicUser(){
}
publicUser(Stringname){
super();
this.name=name;
}
publiclonggetId(){
returnid;
}
publicvoidsetId(longid){
this.id=id;
}
publicStringgetName(){
returnname;
}
publicvoidsetName(Stringname){
this.name=name;
}
@Override
publicStringtoString(){
return"{id="+id+",name="+name+"}";
}
}
//SQLite相关配置,包括数据库名字、创建路径、版本号、数据创建和升级时的监听
SQLiteDBConfigconfig=newSQLiteDBConfig(this);
//设置数据库创建更新时的监听,有提供空实现:SimpleDBListener
config.setDbListener(newIDBListener(){
@Override
publicvoidonUpgradeHandler(SQLiteDatabasedb,intoldVersion,intnewVersion){
}
@Override
publicvoidonDbCreateHandler(SQLiteDatabasedb){
showLongToast("数据库创建成功");
}
});
//创建db,在创建数据库的时候,不需要在onDbCreateHandler手动去创建相关的数据表,在对实体对象进行数据操作的时候,会自动判断表是否存在,不存在的话会自动创建,同时如果有新增的字段也会自动更新表结构
SQLiteDBdb=SQLiteDBFactory.createSQLiteDB(config);
//保存单个实体对象
Useruser=newUser("添加单个对象");
intrtn=db.save(user)
//保存集合对象
Listlist=newArrayList();
intrtn=db.save(list)
//查询User表中的所有数据
Listlist=db.queryAll(User.class);
//根据实体id(主键)查询User
Useruser=db.query(User.class,"1");
//查询User表中的数据总数
longtotal=db.queryTotal(User.class);
//删除指定实体对象
db.delete(user);
//更新实体对象
db.update(user);
//分页查询
db.queryPage(claxx,curPage,pageSize);
//根据SQL查询
Cursorcursor=db.query(sql,bindArgs);
源码及Demo地址:https://github.com/huyongli/TigerDB,大家可以自行下载查看
mg注册送白菜网彩金自动
电子游戏注册会员送体验金
免费彩金棋牌娱乐城
注册送58体验金小平果