1

我有一个表格,其中列出了来自特定站点的评论数量,如下所示:

Date                        Site         Comments         Total
---------------------------------------------------------------
2010-04-01 00:00:00.000      1              5               5
2010-04-01 00:00:00.000      2              8               13
2010-04-01 00:00:00.000      4              2               7
2010-04-01 00:00:00.000      7              13              13
2010-04-01 00:00:00.000      9              1               2

我有另一个表格列出了所有站点,例如从 1 到 10

Site
-----
1
2
...
9
10

使用以下代码,我可以找出哪些网站缺少上个月的条目:

SELECT s.site
from tbl_Sites s
EXCEPT
SELECT c.site
from tbl_Comments c
WHERE c.[Date] = DATEADD(mm, DATEDIFF(mm, 0, GetDate()) -1,0)

生产:

site
-----
3
5
6
8
10

我希望能够将我的查询中列出的缺失站点插入到带有一些默认值的评论表中,即'0's

Date                        Site         Comments         Total
---------------------------------------------------------------
2010-04-01 00:00:00.000      3              0               0
2010-04-01 00:00:00.000      5              0               0
2010-04-01 00:00:00.000      6              0               0
2010-04-01 00:00:00.000      8              0               0
2010-04-01 00:00:00.000      10             0               0

问题是,我是如何更新/插入表/值的?

干杯,

4

2 回答 2

2
INSERT INTO CommentTable (Date, Site, Comments, Total)
SELECT '2010-04-01 00:00:00.000', Site, 0, 0
FROM SiteTable
WHERE Site NOT IN
    (SELECT DISTINCT Site FROM CommmentTable
     WHERE [Date] = DATEADD(mm, DATEDIFF(mm, 0, GetDate()) -1,0))
于 2010-05-10T15:30:12.293 回答
0

我猜从站点到您的评论表的左连接应该可以完成工作

至少如果我确实理解你的意图

编辑:Sry 认为你想选择所有有这些评论的网站

于 2010-05-10T15:25:19.083 回答