oracle多表查询留言人(日志人、日志内容、日志留言人)

题意介绍

有三张表分别是

用户表、aw_usercotrl
日志表、aw_userlog
留言表、aw_userlog_lword

用户表分别是日志表留言表的外键
日志表又是留言表的外键

表结构

--aw_usercotrl

SQL> desc aw_usercotrl;
Name      Type         Nullable Default Comments 
--------- ------------ -------- ------- -------- 
AWUID     NUMBER(10)                             
AWUNAME   VARCHAR2(20)                           
AWUPASSWD VARCHAR2(20)                           
AWUHID    NUMBER(10)   Y                         
AWUNO     NUMBER(10)  

--aw_userlog

SQL> desc aw_userlog;
Name     Type          Nullable Default Comments 
-------- ------------- -------- ------- -------- 
AULID    NUMBER(10)                              
AULHEAD  VARCHAR2(40)                            
AULTEXT  VARCHAR2(200)                           
AULTDATE DATE                                    
AWUID    NUMBER(10)    Y   

--aw_userlog_lword

SQL> desc aw_userlog_lword;
Name     Type          Nullable Default Comments 
-------- ------------- -------- ------- -------- 
AULID    NUMBER(10)                              
FKAULID  NUMBER(10)    Y                         
AULWORD  VARCHAR2(100)                           
FK_AWUID NUMBER(10)    Y 

表信息

SQL> select * from aw_usercotrl;
 
      AWUID AWUNAME              AWUPASSWD                 AWUHID       AWUNO
----------- -------------------- -------------------- ----------- -----------
          1 付政委               123                            1   193094104
          2 奥巴马               123                            1   193094103
          3 小布什               123                            1   193094102
          4 萨达姆               123                            1   193094101
 
SQL> select * from aw_userlog;
 
      AULID AULHEAD                                  AULTEXT                                                                          AULTDATE          AWUID
----------- ---------------------------------------- -------------------------------------------------------------------------------- ----------- -----------
          1 oracle批量删除和恢复                     提出问题:在不写存储过程的情况下drop每次只可以产出一个表                         2012-8-22 1           1
          2 java内存分析                             对于java的内存这个是一个比较有研究性                                             2012-8-23 2           2
 
SQL> select * from aw_userlog_lword;
 
      AULID     FKAULID AULWORD                                                                             FK_AWUID
----------- ----------- -------------------------------------------------------------------------------- -----------
          1           1 这个问题总结的不错,接分啊,楼主                                                           2
          2           1 抢个沙发,嘿嘿                                                                             1
          3           1 我给总结在这里面了http://www.ticmy.com                                                     3
          4           2 这个问题确实不好弄啊                                                                       4
 

多表查询,查询出发日志的人,发的日志,评论人

SQL> select a1.awuname,b.aulhead,a2.awuname from aw_usercotrl a1,aw_usercotrl a2,aw_userlog b,aw_userlog_lword c where b.aulid = c.fkaulid and a1.awuid = b.awuid and a2.awuid = c.fk_awuid;
 
AWUNAME              AULHEAD                                  AWUNAME
-------------------- ---------------------------------------- --------------------
付政委               oracle批量删除和恢复                     奥巴马
付政委               oracle批量删除和恢复                     付政委
付政委               oracle批量删除和恢复                     小布什
奥巴马               java内存分析                             萨达姆

查询原理
一表用两次,分别和二表,三表连接,然后让二表和三表连接

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小傅哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值