Сообщество MVVMCross SqLite — связь между таблицами

У меня есть две простые таблицы:

public class MediaPartner
{
    [PrimaryKey, AutoIncrement]
    public int Id { get; set; }
    public string PhoneNumber { get; set; }
    public string CompanyName { get; set; }
    public double Lat { get; set; }
    public double Lng { get; set; }
    public DateTime InsertedUtc { get; set; }
}    

public class ImageGroup
{
    [PrimaryKey, AutoIncrement]
    public int Id { get; set; }
    public List<MediaPartner> IdMediaPartner { get; set; }
    public string ImagePath { get; set; }
    public bool IsSent { get; set; }
    public DateTime InsertedUtc { get; set; }
}

Проблема:

общедоступный список‹ MediaPartner > IdMediaPartner { get; задавать; }
ИЛИ
public MediaPartner IdMediaPartner { get; задавать; }
не компилируется.

Мой вопрос: есть ли способ построить отношения "один ко многим" между этими двумя таблицами?

Спасибо!


person stephnx    schedule 12.01.2014    source источник


Ответы (1)


SQLite-net обеспечивает только перекрестные ссылки с использованием индексации, например:

public class Stock
{
    [PrimaryKey, AutoIncrement]
    public int Id { get; set; }
    [MaxLength(8)]
    public string Symbol { get; set; }
}

public class Valuation
{
    [PrimaryKey, AutoIncrement]
    public int Id { get; set; }
    [Indexed]
    public int StockId { get; set; }
    public DateTime Time { get; set; }
    public decimal Price { get; set; }
}

Существует как минимум одно расширение для sqlite-net, которое позволяет объявлять атрибуты OneToMany — см. https://bitbucket.org/twincoders/sqlite-net-extensions, который позволяет использовать такой код:

public class Stock
{
    [PrimaryKey, AutoIncrement]
    public int Id { get; set; }
    [MaxLength(8)]
    public string Symbol { get; set; }

    [OneToMany]      // 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 int StockId { get; set; }
    public DateTime Time { get; set; }
    public decimal Price { get; set; }

    [ManyToOne]      // Many to one relationship with Stock
    public Stock Stock { get; set; }
}

Я не уверен в точной реализации этого - например. Я не знаю, использует ли это настоящие ограничения FOREIGN KEY, но код с открытым исходным кодом, находится в активной разработке, имеет встроенную поддержку плагинов mvvmcross, является кроссплатформенным и доступен для разветвления и внесения вклада.

person Stuart    schedule 12.01.2014
comment
Спасибо за ваш ответ и за MVVMCross! - person stephnx; 12.01.2014