免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4022 | 回复: 3
打印 上一主题 下一主题

请教一个4表混合连接的SQL [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-08-21 20:14 |只看该作者 |倒序浏览
表:t1,t2,t3,t4
t1与t2做等值连接,t3,t4做等值连接,然后对两个连接的结果做全连接

select t1.c1, t2.c2, t3.c3, t4.c4
  from t1, t2, FULL OUTER JOIN( t3,t4)
where t1.c1 = t2.c1
   and t3.c1 = t4.c1
   and t1.c2 = t3.c2

我在10.0上测试,总是报语法错,达人们帮俺看看

另,10.0的手册上说支持在结果集上进行查询,即: select * from ( select * from t );
但是俺测试了一下,也报语法错,有试过的没?请告诉一下,到底这个sql能不能在10.0上运行啊

论坛徽章:
0
2 [报告]
发表于 2011-08-22 14:51 |只看该作者
表:t1,t2,t3,t4
t1与t2做等值连接,t3,t4做等值连接,然后对两个连接的结果做全连接

select t1.c1, t2 ...
novemberrain 发表于 2011-08-21 20:14



    select t1.c1, t2.c2, t3.c3, t4.c4
from t1,t2 full outer join t3 on t3.c2=t1.c2
full outer join t4 on t4.c1=t3.c1
where t1.c1=t2.c1

select t1.c1, t2.c2, t3.c3, t4.c4
  from t1, t2, OUTER ( t3,outer t4)
where t1.c1 = t2.c1
   and t3.c1 = t4.c1
   and t1.c2 = t3.c2

select * from (select * from t)在V11能执行,说是DBACCESS的问题,不认识这种语法,需要升级。用ISQL或CSDK试试?

论坛徽章:
0
3 [报告]
发表于 2011-08-27 18:51 |只看该作者
select t1.c1, t2.c2, t3.c3, t4.c4
from t1,t2 full outer join t3 on t3.c2=t1.c2
full oute ...
3sane 发表于 2011-08-22 14:51



谢谢3sane!

前几天没顾上回,今天说一下测试的情况

第二种方式可以执行,但是结果不对,相当于只做了左连接。按照informix的手册一直没测试成功informix语法的全连接该怎么写,哪位达人知道告诉下,谢谢哈

第一种方式报语法错,我的是informix10.0,不知道是不是版本的原因,改成如下方式,通过,而且结果是全连接
select t1.c1, t2.c2, t3.c3, t4.c4
from t1 inner join t2 on t1.c1 = t2.c1
full outer join ( t3 inner join t4 on t3.c1 = t4.c1 )
on t1.c2 = t3.c2

另,用CSDK3.0 在 informix10.0 上试了一下 select * from (select * from t) 这个语法,还是抱语法错, 估计是10.0的问题了吧
再次感谢 3sane!

还用,好像informix版越来越冷清了....

论坛徽章:
59
2015七夕节徽章
日期:2015-08-24 11:17:25ChinaUnix专家徽章
日期:2015-07-20 09:19:30每周论坛发贴之星
日期:2015-07-20 09:19:42ChinaUnix元老
日期:2015-07-20 11:04:38荣誉版主
日期:2015-07-20 11:05:19巳蛇
日期:2015-07-20 11:05:26CU十二周年纪念徽章
日期:2015-07-20 11:05:27IT运维版块每日发帖之星
日期:2015-07-20 11:05:34操作系统版块每日发帖之星
日期:2015-07-20 11:05:36程序设计版块每日发帖之星
日期:2015-07-20 11:05:40数据库技术版块每日发帖之星
日期:2015-07-20 11:05:432015年辞旧岁徽章
日期:2015-07-20 11:05:44
4 [报告]
发表于 2011-08-27 22:44 |只看该作者
这个写法比较怪。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP