1
UPDATE:
我已经把我的XML转换ColdFusion的查询表,所以这可能有助于解决这个问题。的LINQ to XML查询到SQL
所以我的数据是:
[id] | [code] | [desc] | [supplier] | [name] | [price]
------------------------------------------------------
1 | ABCDEF | "Tst0" | "XYZ" | "Test" | 123.00
2 | ABCDXY | "Tst1" | "XYZ" | "Test" | 130.00
3 | DCBAZY | "Tst2" | "XYZ" | "Tst2" | 150.00
现在我需要的是什么的LINQ to XML查询下方输出。输出应该是这样的(我会因此更容易对我来说,输入JSON写)这样的:
[{
"code": "ABCD",
"name": "Test",
"products":
{
"id": 1,
"code": "ABCDEF",
"desc": "Tst0",
"price": 123.00
},
{
"id": 2,
"code": "ABCDXY",
"desc": "Tst1",
"price": 130.00
}
},
{
"code": "DCBA",
"name": "Tst2",
"products":
{
"id": 3,
"code": "DCBAZY",
"desc": "Tst2",
"price": 150.00
}
}]
正如你所看到的,通过“CODE”和第4个字符组“供应商”的代码。
感谢
我会怎么以下LINQ转换为XML查询到SQL?
from q in query
group q by new { Code = q.code.Substring(0, 4), Supplier = q.supplier } into g
select new
{
code = g.Key.Code,
fullcode = g.FirstOrDefault().code,
supplier = g.Key.Supplier,
name = g.FirstOrDefault().name,
products = g.Select(x => new Product { id = x.id, c = x.code, desc = string.IsNullOrEmpty(x.desc) ? "Description" : x.desc, price = x.price })
}
尽我所能想出:
SELECT c, supplier, n
FROM products
GROUP BY C, supplier, n
不知道如何让子查询中存在或获得的代码串。
PS:这是对ColdFusion,所以我想他们的SQL版本可能是MS SQL不同..
LINQ有什么好处,它是一个更高的抽象级别,使得它更容易做到SQL中难以做到的事情。 – Steven
只需附加一个SQL分析器并查看执行的SQL查询。 – Steven
查询实际上是LINQ to XML,而不是数据库。 – jzm