xUtils中用DbUtils,ViewUtils的用法


一、有關xUtils的簡介

xUtils 包含了很多實用的android工具。
xUtils 最初源於Afinal框架,進行了大量重構,使得xUtils支持大文件上傳,更全面的http請求協議支持(10種謂詞),
擁有更加靈活的ORM,更多的事件注解支持且不受混淆影響...
xUitls最低兼容android 2.2 (api level 8)

二、總共包含4個功能模塊:

(1)DbUtils模塊:
android中的orm框架,一行代碼就可以進行增刪改查;
支持事務,默認關閉;
可通過注解自定義表名,列名,外鍵,唯一性約束,NOT NULL約束,CHECK約束等(需要混淆的時候請注解表名和列名);
支持綁定外鍵,保存實體時外鍵關聯實體自動保存或更新;
自動加載外鍵關聯實體,支持延時加載;
支持鏈式表達查詢,更直觀的查詢語義,參考下面的介紹或sample中的例子。

(2)ViewUtils模塊
android中的ioc框架,完全注解方式就可以進行UI,資源和事件綁定;
新的事件綁定方式,使用混淆工具混淆后仍可正常工作;
目前支持常用的20種事件綁定,參見ViewCommonEventListener類和包com.lidroid.xutils.view.annotation.event。

(3)HttpUtils模塊:

支持同步,異步方式的請求;
支持大文件上傳,上傳大文件不會oom;
支持GET,POST,PUT,MOVE,COPY,DELETE,HEAD,OPTIONS,TRACE,CONNECT請求;
下載支持301/302重定向,支持設置是否根據Content-Disposition重命名下載的文件;
返回文本內容的請求(默認只啟用了GET請求)支持緩存,可設置默認過期時間和針對當前請求的過期時間。

(4)BitmapUtils模塊:

加載bitmap的時候無需考慮bitmap加載過程中出現的oom和android容器快速滑動時候出現的圖片錯位等現象;
支持加載網絡圖片和本地圖片;
內存管理使用lru算法,更好的管理bitmap內存;
可配置線程加載線程數量,緩存大小,緩存路徑,加載顯示動畫等...

三、我目前使用的:

(1)ViewUtils

@ViewInject(R.id.id_name_input)
private EditText nameText;

在onCreate()方法添加:
ViewUtils.inject(this);

減少了很大一部分findViewById操作

(2)DbUtils操作

1)需要的權限
<uses-permissionandroid:name="android.permission.INTERNET"/>
<uses-permissionandroid:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

2)創建數據庫
DaoConfig config = new DaoConfig(context);

//數據庫的名字
config.setDbName("xUtils-demo"); 

//版本號
config.setDbVersion(1); 

//db還有其他的一些構造方法,比如含有更新表版本的監聽器的
DbUtils db = DbUtils.create(config);

3)創建表

//創建一個表Student
db.createTableIfNotExist(Student.class); 

//在表中保存一個student對象。最初執行保存動作時,也會創建Student表
db.save(student);

4)刪除表
db.dropTable(Student.class);
5)開啟事務
db.configAllowTransaction(true);

6)db相關Annotation
@Check check約束
@Column 列名
@Finder 一對多、多對一、多對多關系(見sample的Parent、Child中的使用)
@Foreign 外鍵
@Id 主鍵,當為int類型時,默認自增。 非自增時,需要設置id的值
@NoAutoIncrement 不自增
@NotNull 不為空
@Table 表名
@Transient 不寫入數據庫表結構
@Unique 唯一約束

(3)常見數據庫操作

1)查詢

DbUtils db = DbUtils.create(this);
List<Grade> stus = db.findAll(Selector.from(Grade.class).where("class_name", "=", ""));
List<Student>list = db.findAll(Selector.from(Student.class)
.where("id","<", 34)
.and(WhereBuilder.b("age",">", 15).or("age", " < ", 20))
.orderBy("id")
.limit(pageSize)
.offset(pageSize* pageIndex));

Studenttest = db.findFirst(Selector.from(Student.class).where("id","in", new int[]{1, 2, 3}));
Studenttest = db.findFirst(Selector.from(Student.class).where("id","between", new String[]{"2", "5"}));
DbModeldbModel =db.findDbModelAll(Selector.from(Student.class).select("name"));//select("name")只取出name列
List<DbModel>dbModels =db.findDbModelAll(Selector.from(Student.class).groupBy("name").select("name","count(name)"));

2)自定義查詢(常用到的鏈接查詢可以這樣寫)

SqlInfo sqlInfo = new SqlInfo();
sqlInfo.setSql("select * from tbl_Student a,tbl_class b where a.stu_class_id = b.id and a.id > ?");
sqlInfo.addBindArg(2);
List<DbModel> StudentByInfo = db.findDbModelAll(sqlInfo);

3)刪除,包含三種方法:刪除list集合,根據Id刪除,刪除一個對象

List<Grade> stus = db.findAll(Selector.from(Grade.class).where("class_name", "=", ""));
db.deleteAll(stus);

 db.deleteById(Grade.class, 2);

 db.delete(stus.get(3));

4更新操作和刪除操作類似,這里就一一列舉

四、有關xUtils

開源項目地址以及作者:https://github.com/wyouflf/xUtils

xUtils api地址
http://xutilsapi.oschina.mopaas.com/

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM