1

Xamarin プロジェクトでSQL-NET 拡張機能を使用しています。where句を使用して、モデルの子エメルメントを返そうとしています。Web サイトのサンプル モデルを使用する:

public class Stock
{
    [PrimaryKey, AutoIncrement]
    public int Id { 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 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; }
}

以下を使用して、子が取り込まれた特定のアイテムを正常に返すことができます。

var storedValuation = db.GetWithChildren<Valuation>(valuation.Id);

Whereただし、の代わりに句を使用してそれを行う方法がわかりませんGet。私が試してみました:

var results = db.Table<Valuation>().Where(x=>x.Price > 5.0m).ToList();

これは、すべての Stock パラメーターが null で返されます。次に、各結果をループして設定できますが、元のクエリでそれを行うためのより良い方法があるに違いないと思いますか?

4

1 に答える 1

2

GetChildrenメソッドを呼び出す任意のオブジェクトの関係を取得できます。

var results = db.Table<Valuation>().Where(x=>x.Price > 5.0m).ToList();
foreach (var element in results) {
    conn.GetChildren(element);
}

GetAllWithChildrenあまり冗長でない方法で同じ操作を実行する、呼び出されたデータベースを照会するための便利なメソッドもあります。

var results = conn.GetAllWithChildren<Valuation>(x => x.Price > 5.0m).ToList();

実行されていない が必要になるため、このクエリでは関係にアクセスできないことに注意してくださいJOIN。このような単純なクエリの場合、期待どおりに機能するはずです。

于 2014-09-15T15:13:56.977 に答える