将两张没有关联字段的表进行横向连接,在工作中,对于一些报表的显示,需要展示两张没有关联字段的表中的数据,并且横向连接,比如下面两张表的数据:
<代码> SELECT *从学生T; 代码>
<代码>从课程选择* C; 代码>
现在需要显示成如下图所示样式:
此时这两张表之间并没有相关联的字段,我们经常用的左连接、右连接,完整的加入都是需要相关联的字段的,所以我们就找一个相同关联的字段——rownum,唯一且能关联,再使用全连接满加入就能解决了问题了,SQL语句如下:
<代码>选择一个。*、b * 从 (选择。*,ROWNUM RN从学生年代) 全部加入 (选择C。*,ROWNUM RN从课程B C) 在一个。RN=B.RN; 代码>
查询结果如下:
可以看出通过rownum和完整的加入就能轻松的实现良两张表的横向连接展示了。
如果不想显示RN这一列的话,就不要用*就好了,需要什么字段显示什么字段:
<代码>选择一个。ID,一个。名字,一个。类,B。ID, B.C_NAME 从 (选择。*,ROWNUM RN从学生年代) 全部加入 (选择C。*,ROWNUM RN从课程B C) 在一个。RN=B.RN; 代码>