如何在 SQLite-Net Extensions 中指定外键 属性
How to specify a foreign key property in SQLite-Net Extensions
如何指定引用特定 属性 而不是主键的外键?
例如股票 class 有一个 uuid 属性。我想在 Valuation class 中创建一个使用此 属性.
引用它的外键
在下面的示例中,[ForeignKey(typeof(Stock))] 行引用了股票 class 的 ID 属性,但我需要它来引用 UUID 属性 .
我该怎么做?
public class Stock
{
[PrimaryKey, AutoIncrement]
public int Id { get; set; }
public string UUID { get; set; }
[MaxLength(8)]
public string Symbol { get; set; }
[OneToMany(CascadeOperations = CascadeOperation.All)] // One to many relationship with Valuation
public List<Valuation> Valuations { get; set; }
}
public class Valuation
{
[PrimaryKey, AutoIncrement]
public int Id { get; set; }
[ForeignKey(typeof(Stock))] // Specify the foreign key
public string StockUUID { get; set; }
public DateTime Time { get; set; }
public decimal Price { get; set; }
[ManyToOne] // Many to one relationship with Stock
public Stock Stock { get; set; }
}
A ForeignKey
总是引用另一个 class 的 PrimaryKey
。在这种情况下,您的 PrimaryKey
是一个整数,但您正试图引用另一个 属性 类型的字符串。这不受支持,因此您要么引用主键,要么将 UUID
属性 设为主键。
public class Stock
{
[PrimaryKey]
public string UUID { get; set; }
[MaxLength(8)]
public string Symbol { get; set; }
[OneToMany(CascadeOperations = CascadeOperation.All)] // One to many relationship with Valuation
public List<Valuation> Valuations { get; set; }
}
如何指定引用特定 属性 而不是主键的外键?
例如股票 class 有一个 uuid 属性。我想在 Valuation class 中创建一个使用此 属性.
引用它的外键在下面的示例中,[ForeignKey(typeof(Stock))] 行引用了股票 class 的 ID 属性,但我需要它来引用 UUID 属性 .
我该怎么做?
public class Stock
{
[PrimaryKey, AutoIncrement]
public int Id { get; set; }
public string UUID { get; set; }
[MaxLength(8)]
public string Symbol { get; set; }
[OneToMany(CascadeOperations = CascadeOperation.All)] // One to many relationship with Valuation
public List<Valuation> Valuations { get; set; }
}
public class Valuation
{
[PrimaryKey, AutoIncrement]
public int Id { get; set; }
[ForeignKey(typeof(Stock))] // Specify the foreign key
public string StockUUID { get; set; }
public DateTime Time { get; set; }
public decimal Price { get; set; }
[ManyToOne] // Many to one relationship with Stock
public Stock Stock { get; set; }
}
A ForeignKey
总是引用另一个 class 的 PrimaryKey
。在这种情况下,您的 PrimaryKey
是一个整数,但您正试图引用另一个 属性 类型的字符串。这不受支持,因此您要么引用主键,要么将 UUID
属性 设为主键。
public class Stock
{
[PrimaryKey]
public string UUID { get; set; }
[MaxLength(8)]
public string Symbol { get; set; }
[OneToMany(CascadeOperations = CascadeOperation.All)] // One to many relationship with Valuation
public List<Valuation> Valuations { get; set; }
}