标签:
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()完全一样的)
先到这里
标签:
原文地址:http://www.cnblogs.com/zwdxcc/p/4584544.html