android Xutils dbutils 注解


xUtils DbUtils 關於實體類注解 匯總

RockyZhang 發布於 1年前,共有 0 條評論

先來官方demo

DbUtils db = DbUtils.create(this);
    	User user = new User(); //這里需要注意的是User對象必須有id屬性,或者有通過@ID注解的屬性
    	user.setEmail("wyouflf@qq.com");
    	user.setName("wyouflf");
    	db.save(user); // 使用saveBindingId保存實體時會為實體的id賦值

    	...
    	// 查找
    	Parent entity = db.findById(Parent.class, parent.getId());
    	List<Parent> list = db.findAll(Parent.class);//通過類型查找

    	Parent Parent = db.findFirst(Selector.from(Parent.class).where("name","=","test"));

    	// IS NULL
    	Parent Parent = db.findFirst(Selector.from(Parent.class).where("name","=", null));
    	// IS NOT NULL
    	Parent Parent = db.findFirst(Selector.from(Parent.class).where("name","!=", null));

    	// WHERE id<54 AND (age>20 OR age<30) ORDER BY id LIMIT pageSize OFFSET pageOffset
    	List<Parent> list = db.findAll(Selector.from(Parent.class)
    	                                   .where("id" ,"<", 54)
    	                                   .and(WhereBuilder.b("age", ">", 20).or("age", " < ", 30))
    	                                   .orderBy("id")
    	                                   .limit(pageSize)
    	                                   .offset(pageSize * pageIndex));

    	// op為"in"時,最后一個參數必須是數組或Iterable的實現類(例如List等)
    	Parent test = db.findFirst(Selector.from(Parent.class).where("id", "in", new int[]{1, 2, 3}));
    	// op為"between"時,最后一個參數必須是數組或Iterable的實現類(例如List等)
    	Parent test = db.findFirst(Selector.from(Parent.class).where("id", "between", new String[]{"1", "5"}));

    	DbModel dbModel = db.findDbModelAll(Selector.from(Parent.class).select("name"));//select("name")只取出name列
    	List<DbModel> dbModels = db.findDbModelAll(Selector.from(Parent.class).groupBy("name").select("name", "count(name)"));
    	...

    	List<DbModel> dbModels = db.findDbModelAll(sql); // 自定義sql查詢
    	db.execNonQuery(sql) // 執行自定義sql
    	...

 

注解總結

1 .主鍵

    @Id // 如果主鍵沒有命名名為id或_id的時,需要為主鍵添加此注解
    @NoAutoIncrement // int,long類型的id默認自增,不想使用自增時添加此注解
    private int id;

2. 忽略字段

  // Transient使這個列被忽略,不存入數據庫
    @Transient
    public String willIgnore;
    /** ---------------------------------*/
    public static String staticFieldWillIgnore; // 靜態字段也不會存入數據庫

3.表名

@Table(name = "parent", execAfterTableCreated = "CREATE UNIQUE INDEX index_name ON parent(name,email)") 
//name即表名, 
//execAfterTableCreated  自定義表創建之后要執行的sql。為parent表創建(name,email)索引 -->在表上創建一個唯一的索引。唯一的索引意味着兩個行不能擁有相同的索引值。

4.列名

@Column(column = "name") //為列名加上注解 可以針對命名不統一和防止混淆
public String name;

5.外鍵

  延遲加載

    @Finder(valueColumn = "id", targetColumn = "parentId")
    public FinderLazyLoader<Child> children; // 關聯對象多時建議使用這種方式,延遲加載效率較高。
    
    @Foreign(column = "parentId", foreign = "id")
    public ForeignLazyLoader<Parent> parent;

  非延遲加載

    @Finder(valueColumn = "id",targetColumn = "parentId")
    public Child children;
    
    @Foreign(column = "parentId", foreign = "isVIP")
    public List<Parent> parent;

 1對多

    @Finder(valueColumn = "id", targetColumn = "parentId")
    private List<Child> children;
    
    @Foreign(column = "parentId", foreign = "id")
    public Parent parent;

代碼

        Parent parent = new Parent();
        parent.name = "測試" + System.currentTimeMillis();
        parent.setAdmin(true);
        parent.setEmail("wyouflf@gmail.com");
        
        DbUtils db = DbUtils.create(this.getActivity());
        db.configAllowTransaction(true);
        db.configDebug(true);

        Child child = new Child();
        child.name = "child' name";
        child.parent = parent;
        db.saveBindingId(child);//保存對象關聯數據庫生成的id

6.其他

    @NotNull  //不能為空
    @Check(value = "age>0") //age必須大於0  創建表時調用"
    @Unique    //唯一
    public int age;

 


免責聲明!

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



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