sql server 多次为 'b' 指定了列 'patientid'。

withpas(selectpp.*,s.sectionidfromtb_patientpp,tb_section_flagswherepp.patientid=s.pa... with p as(
select pp.*,s.sectionid
from
tb_patient pp,tb_section_flag s
where pp.patientid=s.patientid and Status='I' and siteid not in('SI0000000554485','SI0000003221423','SIHCSLCS5E945TZ',
'SIHE7UJ13VVXNO0','SIHE9JS19E2GQEW')
) select b.*,QUGO32DSIWNBYOK,QUGO32E85K311F2,QUGO32E85K311F3,QUGO32E85K311FJ,QUGO32EZFRZZCLA,QUGO32F70ENHQRR,QUGO32FE1R6TMK5,updatetime,QUGO32PA77QG0GG,QUGO32Q9S81FU6G,QUGQ from (select *,ROW_NUMBER() over(order by p.PatientId) AS RowNumber from p left join SSGO31S90AHTPRK on p.patientid =SSGO31S90AHTPRK.patientid left join SSGQ1OGK9VYM3V3 on p.patientid =SSGQ1OGK9VYM3V3.patientid where sectionid = 'SEGO31QECEHQMRZ') as b where b.RowNumber Between (1) and (100) order by rownumber

麻烦各位大侠帮忙看看哪儿出问题
展开
 我来答
若以下回答无法解决问题,邀请你更新回答
57049948
2014-07-21 · 超过23用户采纳过TA的回答
知道答主
回答量:112
采纳率:0%
帮助的人:69.4万
展开全部
应该是b.*那个地方有问题,去掉,把列名写全看看呢
更多追问追答
追问
b表里面只有一个patientid  跟这个没关系,改了不行。
追答
那就是里面那个 select *有问题了,你 p,SSGO31S90AHTPRK,SSGQ1OGK9VYM3V3这三个表都有patientid这个字段,你直接select * 会报错吧,就先进于执行b.patientid三次
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式