db2 sql 报错,非高手勿进!!!!!!!!!!!!!!!!!!!!!!!

tarena5525 2012-03-26 10:41:02
有四张表T06_AUDIT_PROJECT_00,T06_AUDIT_PROJECT_02,t06_audit_project,t06_project_flow,表中的数据分别如下:
SELECT AUDITTARGET FROM T06_AUDIT_PROJECT_00;
AUDITTARGET
昆山农村商业银行电子银行部
昆山农村商业银行电子银行部
昆山农村商业银行电子银行部
昆山农村商业银行铜山支行,昆山农村商业银行昆山分行清算中心,昆山农村商业银行电子银行部 昆山农村商业银行铜山支行,昆山农村商业银行昆山分行清算中心,昆山农村商业银行电子银行部 昆山农村商业银行铜山支行,昆山农村商业银行昆山分行清算中心,昆山农村商业银行电子银行部

SELECT AUDITTARGET FROM T06_AUDIT_PROJECT_02;
AUDITTARGET
昆山农村商业银行电子银行部
昆山农村商业银行电子银行部
昆山农村商业银行电子银行部
昆山农村商业银行电子银行部
昆山农村商业银行电子银行部
昆山农村商业银行昆山分行清算中心
昆山农村商业银行昆山分行清算中心
昆山农村商业银行电子银行部
昆山农村商业银行电子银行部
昆山农村商业银行电子银行部
NULL
NULL

SELECT * FROM t06_os_wfentry;
ID NAME STATE
571 T06_AUDIT_PROJECT_00 4
572 T06_AUDIT_PROJECT_08 4
573 T06_AUDIT_PROJECT_06 4
574 T06_AUDIT_PROJECT_06 4
575 T06_AUDIT_PROJECT_02 4
576 T06_AUDIT_PROJECT_04 4
577 T06_AUDIT_PROJECT_11 4
578 T06_AUDIT_PROJECT_02 4
579 T06_AUDIT_PROJECT_05 4
580 T06_AUDIT_PROJECT_00 4
581 T06_AUDIT_PROJECT_08 4
582 T06_AUDIT_PROJECT_06 4
583 T06_AUDIT_PROJECT_06 4
584 T06_AUDIT_PROJECT_06 4
585 T06_AUDIT_PROJECT_02 4
586 T06_AUDIT_PROJECT_02 4
587 T06_AUDIT_PROJECT_02 4
588 T06_AUDIT_PROJECT_02 4

SELECT * FROM t06_audit_project;
PROJECTID PROJECTNAME AUDITTARGET
A20120001 立项测试222 昆山农村商业银行铜山支行,昆山农村商业银行昆山分行清算中心,昆山农村商业银行电子银行部
C20120001 立项测试111 昆山农村商业银行电子银行部

SELECT * FROM t06_project_flow;
ID PROJECTID
571 C20120001
572 C20120001
573 C20120001
574 C20120001
575 C20120001
576 C20120001
577 C20120001
578 C20120001
579 C20120001
580 A20120001
581 A20120001
582 A20120001
583 A20120001
584 A20120001
585 A20120001
586 A20120001
587 A20120001
588 A20120001

由于每个表只拿出个别字段的值,所以会有很多的重复值,这个大家不用纠结.
下面是写的sql,这段sql会报错:
select distinct e.projectid, e.projectname,
case when c.name = 'T06_AUDIT_PROJECT_00'
then (select distinct d.audittarget from T06_AUDIT_PROJECT_00 d where d.projectid = e.projectid and d.entryid = c.id)
when c.name = 'T06_AUDIT_PROJECT_02'
then (select distinct d.audittarget from T06_AUDIT_PROJECT_02 d where d.projectid = d.projectid and d.entryid = c.id)
else e.audittarget
end audittarget,
c.id,c.name,c.state as status
from t06_os_wfentry c
left join (select DISTINCT a.projectid,a.projectname,b.id,a.audittarget
from t06_audit_project a, t06_project_flow b
where a.projectid=b.projectid) e
on c.id=e.id
where 1>0

报错信息:
SQL0811N 标量全查询、SELECT INTO 语句或 VALUES INTO 语句的结果有多行。 SQLSTATE=21000

请各位DB2大神帮忙解决下,急需解决,小弟这里先谢谢了!!!!!!!!!!!!!!!!!!!!!!
...全文
141 点赞 收藏 6
写回复
6 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
iihero 2012-03-29
你两个then中的select,其中肯定有一个返回的是多行记录,导致出错。
回复
tarena5525 2012-03-28
[Quote=引用 1 楼 的回复:]

then的后面返回的不只是一行记录吧。
[/Quote]
我改成
select distinct e.projectid, e.projectname,
case when c.name = 'T06_AUDIT_PROJECT_00'
then (select distinct d.audittarget from T06_AUDIT_PROJECT_00 d where d.projectid = e.projectid and d.entryid = c.id)
else e.audittarget
end audittarget,
c.id,c.name,c.state as status
from t06_os_wfentry c
left join (select DISTINCT a.projectid,a.projectname,b.id,a.audittarget
from t06_audit_project a, t06_project_flow b
where a.projectid=b.projectid) e
on c.id=e.id
where 1>0
就不会报错了,为什么写两个以上的when就会报错?
回复
JH5221314 2012-03-27
路过。DB2的sql语句格式是否要求太高了啊!@
回复
yangxiao_jiang 2012-03-27
[Quote=引用 3 楼 jh5221314 的回复:]

路过。DB2的sql语句格式是否要求太高了啊!@
[/Quote]
这个是正常的要求啊。
回复
zhaojianmi1 2012-03-26
then后面这个select语句返回了多行
回复
yangxiao_jiang 2012-03-26
then的后面返回的不只是一行记录吧。
回复
相关推荐
发帖
DB2
创建于2007-08-27

5856

社区成员

IBM DB2 是美国IBM公司开发的一套关系型数据库管理系统,它主要的运行环境为UNIX(包括IBM自家的AIX)、Linux、IBM i(旧称OS/400)、z/OS,以及Windows服务器版本
申请成为版主
帖子事件
创建了帖子
2012-03-26 10:41
社区公告
暂无公告