数据库将两张表进行横向连接(拼接成一张表的形式显示)

  

将两张没有关联字段的表进行横向连接,在工作中,对于一些报表的显示,需要展示两张没有关联字段的表中的数据,并且横向连接,比如下面两张表的数据:

  
 <代码> 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;  
  

数据库将两张表进行横向连接(拼接成一张表的形式显示)

数据库将两张表进行横向连接(拼接成一张表的形式显示)