我正在尝试在 SQLite 中执行一些 LINQ 语句,但遇到了一些问题。
首先,我正在尝试加入。这是我的代码:
var query = from client in db.Table<Client>()
join address in db.Table<AddressDetail>()
on client.AddressID equals address.AddressID
select new
{
ClientID = client.ClientID,
AddressID = address.AddressID,
Name = address.Name,
LastSaveDate = client.LastSaveDate
};
这失败了,我收到的错误消息是:不支持加入。
杰出的!!
所以为了解决这个问题,我将我的代码分成 2 个查询,所以这里是更新的代码:
var query = db.Table<Client>();
foreach (var client in query)
{
var subQuery = from address in db.Table<AddressDetail>()
where address.AddressID == client.AddressID
select new
{
ClientID = client.ClientID,
AddressID = address.AddressID,
Name = address.Name,
LastSaveDate = client.LastSaveDate
};
foreach (var fullClient in subQuery)
{
//Do something here
}
}
这一切似乎都有效,直到我尝试循环子查询的结果。我收到以下错误:没有为此对象定义无参数构造函数。
那么这是否意味着我不能在 SQLite 中使用连接和匿名类型?
有什么想法可以解决这个问题。
我正在使用 SQLite、.Net 4.5 并正在创建一个 Windows 8 商店应用程序。