iteye_12300 2010-03-22 14:07
浏览 148
已采纳

oracle多表查询问题

共有6个表
urlservice,cbe_subscriber_dyn,ts_productorder,cbe_subscriber,cbe_account_dyn,tc_account_balance

首先根据url条件查询第一个表(urlservice)需要subscriberkey 字段
select subscriberkey from urlservice where url='';

cbe_subscriber_dyn,ts_productorder,cbe_subscriber,cbe_account_dyn,tc_account_balan
上面五个表都有关联表(urlservice)的subscriberkey字段
cbe_subscriber_dyn 查询aaa字段
ts_productorder,查询bbb字段
cbe_subscriber,查询ccc字段
cbe_account_dyn,查询ddd字段
tc_account_balan,查询eee字段

这样的sql语句怎么写啊···因为数据量很多··性能要求好点的
请大家讨论一下写法···谢谢

  • 写回答

3条回答 默认 最新

  • suziwen 2010-03-22 23:33
    关注

    看你是想得到什么结果了,如果是

    cbe_subscriber_dyn,ts_productorder,cbe_subscriber,cbe_account_dyn,tc_account_balan 这几张表的
    subscriberkey 在 urlservice 里都需要有对应subscriberkey的时候(即urlservice里有subscriberkey对应的值时,在其他5张表都必須有才显示出来),相应的SQL语句是:

    [code="sql"]SELECT U.SUBSCRIBERKEY ,U.URL,A.AAA,B.BBB,C.CCC,D.DDD,E.EEE FROM
    CBE_SUBSCRIBER_DYN A,TS_PRODUCTORDER B,
    CBE_SUBSCRIBER C,CBE_ACCOUNT_DYN D,TC_ACCOUNT_BALAN E,
    URLSERVICE U
    WHERE A.SUBSCRIBERKEY = U.SUBSCRIBERKEY AND B.SUBSCRIBERKEY=U.SUBSCRIBERKEY
    AND C.SUBSCRIBERKEY = U.SUBSCRIBERKEY AND D.SUBSCRIBERKEY=U.SUBSCRIBERKEY
    AND E.SUBSCRIBERKEY = U.SUBSCRIBERKEY[/code]

    如果是显示所有主表的值,子表如果存在值,就显示,不存在就当空字段的话,然后再跟据过滤条件过滤的,可以参考下面的SQL语句

    [code="sql"]
    SELECT U.SUBSCRIBERKEY, U.URL,A.AAA,B.BBB,C.CCC,D.DDD,E.EEE

    FROM URLSERVICE U

    LEFT JOIN CBE_SUBSCRIBER_DYN A ON A.SUBSCRIBERKEY = U.SUBSCRIBERKEY
    LEFT JOIN TS_PRODUCTORDER B ON B.SUBSCRIBERKEY=U.SUBSCRIBERKEY
    LEFT JOIN CBE_SUBSCRIBER C ON C.SUBSCRIBERKEY = U.SUBSCRIBERKEY
    LEFT JOIN CBE_ACCOUNT_DYN D ON D.SUBSCRIBERKEY=U.SUBSCRIBERKEY
    LEFT JOIN TC_ACCOUNT_BALAN E ON E.SUBSCRIBERKEY = U.SUBSCRIBERKEY

    WHERE U.URL =?
    [/code]

    具体还得看你这几张几表跟主表这间的关系。。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作