3

我正在尝试使用 MvvmCross 4 中的扩展。我想做的很简单:我有两个具有一对多关系的表,并且想要访问它。

我有两个班,BusLineBusLineGroup。每条 BusLine 都有一个 Group 作为外键。我在代码中所做的是运行一个简单的 LINQ-Query 来获取所有总线:

var testQuery = 
    from busLine in this._connection.Table<BusLine>()
    select busLine;

查询本身有效,但如果我检查返回对象的字段,组总是null!。请参阅下面的类和表定义。

调试本地人

我究竟做错了什么?为什么总是组null?谢谢你的帮助。


代码中的类:

    public class BusLine
    {
        [PrimaryKey, AutoIncrement]
        public int Id { get; set; }
        public string Name { get; set; }
        [ForeignKey(typeof(BusLineGroup))]
        public int BusLineGroup { get; set; }
        [ManyToOne]
        public BusLineGroup LineGroup { get; set; }
    }

    public class BusLineGroup
    {
        [PrimaryKey, AutoIncrement]
        public int Id { get; set; }
        public string Name { get; set; }
        public string Color { get; set; }
        public string MainStations { get; set; }
        [OneToMany(CascadeOperations = CascadeOperation.All)]
        public List<BusLine> BusLines { get; set; }

    }

两张表:

CREATE TABLE "BusLineGroup" (
    `Id`    INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT UNIQUE,
    `Name`  TEXT NOT NULL,
    `Color` TEXT NOT NULL,
    `MainStations`  TEXT NOT NULL
);
CREATE TABLE "BusLine" (
    `Id`    INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT UNIQUE,
    `Name`  TEXT NOT NULL,
    `BusLineGroup`  INTEGER NOT NULL,
    FOREIGN KEY(`BusLineGroup`) REFERENCES `BusLineGroup`(`Id`)
);

已安装的 Nuget 包:

  • MvvmCross.Plugin.SQLitePCL
  • SQLiteNetExtensions

注意: MvvmCross 包自动包含 SQLite.Net-PCL。所以这两者都使用相同的PCL。

4

1 回答 1

5

您没有使用任何SQLite-Net Extensions方法,您使用的是对您的关系一无所知的普通 sqlite.net 方法。您必须使用这些WithChildren方法从数据库中读取和写入关系。

例如,您的查询可以替换为以下行:

var testQuery = this._connection.GetAllWithChildren<BusLine>();

这也将从数据库中获取一级关系。

我建议您查看SQLite-Net Extensions文档示例项目以获取更多示例。

于 2016-04-05T16:24:22.620 回答