2013-07-04 70 views
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不同..

+0

LINQ有什么好处,它是一个更高的抽象级别,使得它更容易做到SQL中难以做到的事情。 – Steven

+4

只需附加一个SQL分析器并查看执行的SQL查询。 – Steven

+0

查询实际上是LINQ to XML,而不是数据库。 – jzm

回答

0

最简单的方法是武官探查到你的数据库,看看查询由LINQ生成到SQL引擎。