2 u014525348 u014525348 于 2016.09.08 15:52 提问

sql联合查询,结果部分出错

表 A
ID(主键)---ver---mk
表 B
ver(主键)----time

要求以B表中相同time, 统计对应的表A的数量以及对应mk,
ps:查询特定年度,time是varchar 格式如 20140101,数据库:sql sever2008
查询得到下表
time-----------mk--------count
20140101 -- 模块A ------15
20140115 -- 模块A ------10
20140201 -- 模块B ------20

 select ZSBDRQ,mk,count(*) as count
from YSDP_DATA inner join YSDP_VER on YSDP_VER.VER_ID=YSDP_VER.VER_ID
where SUBSTRING(ZSBDRQ,1,4)=2015
group by ZSBDRQ,mk

以上语句出错如图,同一mk下的count均相同,求如何修改.
图片说明

3个回答

Fantian_233
Fantian_233   2016.09.08 16:24

1.YSDP_VER on YSDP_VER.VER_ID=YSDP_VER.VER_ID 没看错应该是同样的吧 ==

qq_32929105
qq_32929105   2016.09.08 16:28

count(*)改为count(time)

qq_14894337
qq_14894337   2016.09.08 16:53

select ZSBDRQ,mk,count(*) as count
from YSDP_DATA inner join YSDP_VER on YSDP_VER.VER_ID=YSDP_VER.VER_ID
where SUBSTRING(ZSBDRQ,1,4)=2015
group by ZSBDRQ,mk

你 在 on 上 的表单对应是否有问题

on YSDP_VER.VER_ID=YSDP_VER.VER_ID

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!