亚音速嵌套查询

发布于 2025-01-08 19:26:40 字数 172 浏览 2 评论 0原文

如何使用亚音速形成此查询?

SELECT A.categoryname,
    (SELECT COUNT(*)
     FROM items B
     WHERE a.categoryid = b.categoryid) AS TOT
FROM category A 

How do I form this query using subsonic?

SELECT A.categoryname,
    (SELECT COUNT(*)
     FROM items B
     WHERE a.categoryid = b.categoryid) AS TOT
FROM category A 

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

聊慰 2025-01-15 19:26:40

您可以像这样重写查询:

SELECT A.categoryname, COUNT(B.categoryid) AS TOT
FROM category A LEFT OUTER JOIN items B ON A.categoryid = B.categoryid
GROUP BY A.id, A.categoryname

如果没有类别具有相同的名称,则可以省略 A.id 列。

然后使用与此类似的 SubSonic(确切的语法可能有所不同......):

DAL.DB.Select(
    Aggregate.GroupBy(DAL.A.categorynameColumn),
    Aggregate.GroupBy(DAL.A.idColumn)
    Aggregate.Count(DAL.B.categoryidColumn, "Tot")
    )
.From<DAL.A>().LeftOuterJoin(DAL.B.categoryidColumn, DAL.A.categoryidColumn)

You could rewrite your query like this:

SELECT A.categoryname, COUNT(B.categoryid) AS TOT
FROM category A LEFT OUTER JOIN items B ON A.categoryid = B.categoryid
GROUP BY A.id, A.categoryname

If no categories have the same name, you can omit the A.id column.

Then use SubSonic similar to this (the exact syntax may vary...):

DAL.DB.Select(
    Aggregate.GroupBy(DAL.A.categorynameColumn),
    Aggregate.GroupBy(DAL.A.idColumn)
    Aggregate.Count(DAL.B.categoryidColumn, "Tot")
    )
.From<DAL.A>().LeftOuterJoin(DAL.B.categoryidColumn, DAL.A.categoryidColumn)
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文