1. 程式人生 > >GreenDao 3.x 註解中ToOne和ToMany的個人理解

GreenDao 3.x 註解中ToOne和ToMany的個人理解

GreenDao是什麼東西這個就不用多說了。自從GreenDao升級到3.0之後,編譯的方法發生了改變。當然這個改變是有助於快速開發的。

區別在哪隨便百度一下都可以知道。這裡就不多說了。

這裡主要說的是關於3.0之後實體類通過註解的方式使用。

- @Id :主鍵 long/Long型,可以通過@Id(autoincrement = true)設定自增長 
- @Property:設定一個非預設關係對映所對應的列名,預設是的使用欄位名 舉例:@Property (nameInDb=”name”) 
- @NotNul:設定資料庫表當前列不能為空 
- @Transient :新增次標記之後不會生成資料庫表的列 


1.)索引註解
- @Index:使用@Index作為一個屬性來建立一個索引,通過name設定索引別名,也可以通過unique給索引新增約束 
- @Unique:向資料庫列添加了一個唯一的約束 
2.)關係註解
- @ToOne:定義與另一個實體(一個實體物件)的關係 
- @ToMany:定義與多個實體物件的關係

這裡講的是ToOne和ToMany的用法

原來的ToOne是這樣用的:

Property property = entity.addLongProperty("customerId").getProperty(); <br>entity.addToOne(Customer, property);
3.0之後的用法我借用了別人的程式碼:
@Entity
public class Order {
    @Id private Long id;
  
    private long customerId;
  
    @ToOne(joinProperty = "customerId")
    private Customer customer;
}
  
@Entity
public class Customer {
    @Id private Long id;
}
這裡的意思是 customerId作為外來鍵與Customer中的主鍵(也就是id)相連。

舉個例子一個User類裡面有個關於使用者頭像地址的引數,我們假設為icon,型別為int。

同時,我們也有一個實體類Picture專門儲存icon的資料,id啊,大小啊什麼的。在User類裡面使用了ToOne,在專案執行的時候,獲取User裡面的icon,實際上就是獲取了Picture類裡面的資料。大概是這個意思。

接下來說ToMany,這個有點複雜,先引用一下其他人的程式碼吧:

@Entity
public class User {
    @Id private Long id;
  
    @ToMany(referencedJoinProperty = "ownerId")
    private List<Site> ownedSites;
}
  
@Entity
public class Site {
    @Id private Long id;
    private long ownerId;
}
 
// ----------------------------
 
@Entity
public class User {
    @Id private Long id;
    @Unique private String authorTag;
  
    @ToMany(joinProperties = {
            @JoinProperty(name = "authorTag", referencedName = "ownerTag")
    })
    private List<Site> ownedSites;
}
  
@Entity
public class Site {
    @Id private Long id;
    @NotNull private String ownerTag;
}
 
// ----------------------------
 
@Entity
public class Site {
    @Id private Long id;
  
    @ToMany
    @JoinEntity(
            entity = JoinSiteToUser.class,
            sourceProperty = "siteId",
            targetProperty = "userId"
    )
    private List<User> authors;
}
  
@Entity
public class JoinSiteToUser {
    @Id private Long id;
    private Long siteId;
    private Long userId;
}
  
@Entity
public class User {
    @Id private Long id;
}

這裡根據分割線分成3種的情況

第一種 Site類的ownerId作為外來鍵,與User的主鍵相連。

第二種 Site類的ownerId作為外來鍵,與User的非主鍵不為空的鍵相連。
第三種。還沒理解。

@ToMany的屬性referencedJoinProperty,類似於外來鍵約束。

@JoinProperty 對於更復雜的關係,可以使用這個註解標明目標屬性的源屬性。

@JoinEntity 如果你在做多對多的關係,有其他的表或實體參與,可以給目標屬性新增這個額外的註解


暫時先這樣吧