【问题标题】:How to specify a foreign key property in SQLite-Net Extensions如何在 SQLite-Net 扩展中指定外键属性
【发布时间】:2026-01-26 01:50:01
【问题描述】:

如何指定引用特定属性而不是主键的外键?

例如 Stock 类有一个 uuid 属性。我想在 Valuation 类中创建一个使用此属性引用它的外键。

在以下示例中,行 [ForeignKey(typeof(Stock))] 引用 Stock 类的 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; }
}

【问题讨论】:

  • 您面临或存入什么错误?
  • [ForeignKey(typeof(Stock))] 这引用了 ID 属性,但我需要让它引用 UUID 属性。
  • 看看这可能会帮助你link
  • 谢谢,这不是我所需要的,但它是有用的信息。

标签: c# sqlite-net-extensions


【解决方案1】:

ForeignKey 总是引用另一个类的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; }
}

【讨论】:

  • 谢谢!使 UUID 属性主键似乎工作正常。我希望我不必这样做,因为我不想更改现有架构。