首页 > 数据库技术 > 详细

sql 一条记录多个字段 对应另外一个表 取描述的写法

时间:2015-06-17 23:08:16      阅读:295      评论:0      收藏:0      [点我收藏+]

Users表:

技术分享

订单表:

技术分享

现在订单表中,创建人和更新人都是对应于Users表的主键UserID,查询订单时,想显示用户名称

1.先给出自己平时的写法

select o.OrderID,
  isnull((select top 1 UserName from Users where UserID=o.CreatePeople),‘‘) CreatePeople,--创建人
  isnull((select top 1 UserName from Users where UserID=o.UpdatePeople),‘‘) UpdatePeople,--更新人
  o.Amount
from Orders o

 

效果图

技术分享

 

2.另外一种写法

select
o.OrderID,
  u1.UserName CreatePeople,--创建人
  u2.UserName UpdatePeople,--更新人
o.Amount
from Orders o
left join Users u1 on o.CreatePeople=u1.UserID
left join Users u2 on o.UpdatePeople=u2.UserID
order by o.OrderID

执行效果图如下

技术分享

 

如上,效果一模一样(最后一行不一致,是因为第一种写法的isnull函数处理过了,不用isnull()完全一样的)

先到这里

 

sql 一条记录多个字段 对应另外一个表 取描述的写法

原文:http://www.cnblogs.com/zwdxcc/p/4584544.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!