ITPub博客

首页 > 数据库 > SQL Server > 一条sql语句实现一维表生成二维表格

一条sql语句实现一维表生成二维表格

SQL Server 作者:qiuwuhen 时间:2015-06-16 22:48:16 0 删除 编辑
我再工作中遇到一个问题,就是一维表如何转换为二维表格。例如有如下数据库表
----------------------
表名:item
id int --主键自动增长
itemName varchar(50)--名称
表名:itemUse
id int --主键自动增长
otherID --其他外键
itemID --item表的外键
value --值
------------------------
itemUse一维表的格式转换为二维表且列出可以通过一条sql语句进行整理

点击(此处)折叠或打开

  1. select a.otherID,b.id as ItemID from 
  2.  itemUse a left join item b on 1=
  3. --这条语句的作用就是每条otherID都生成一条itemID 

  4. --在上边的基础上 
  5. select a.otherID,a.itemName,b.value from 
  6. (select a.otherID,b.id as ItemID,b.itemName from 
  7.  itemUse a left join item b on 1=1) a 
  8. left join itemUse b on b.otherID=a.otherID and b.itemID=a.ItemID
此时每条otherID的itemName都会列出来,并且还没有某个itemID的otherID也会列出来,但是value值为null,这时就可以通过程序很容易的列出来

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/39424/viewspace-1701945/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2013-09-23

  • 博文量
    52
  • 访问量
    221404