当前位置: 代码迷 >> ASP >> 急帮小弟我写个SQL语句
  详细解决方案

急帮小弟我写个SQL语句

热度:132   发布时间:2013-03-13 10:56:58.0
急急急,帮我写个SQL语句


上面分别是人员表和值班表,

我想得到这样的格式如何做?
id daibanzhang  zhibanyuan  jishuyuan fayi riqi
1   姓名1         姓名2     姓名2    姓名3  2012-3-6

------解决方案--------------------
用子查询的方法

select id,(select xingming from [user] where userid=a.daibanzhang) as daibanzhang,
(select xingming from [user] where userid=a.zhibanyuan) as zhibanyuan,
(select xingming from [user] where userid=a.jishuyuan) as jishuyuan,
(select xingming from [user] where userid=a.fayi) as fayi,
riqi
from zhiban a

------解决方案--------------------
或者使用表连接
SELECT
T1.ID
,T2.XINGMING AS DAIBANZHANG
,T3.XINGMING AS ZHIBANYUAN
,T4.XINGMING AS JISHUYUAN
,T1.RIQI
FROM ZHIBAN T1 INNER JOIN USER T2 ON T1.DAIBANZHANG = T2.USERID
INNER JOIN USER T3 ON T1.ZHIBANYUAN = T3.USERID
INNER JOIN USER T4 ON T1.JISHUYUAN = T4.USERID
WHERE T1.ID = 1

------解决方案--------------------
sql="select A.id xid,B.xingming daibanzhang,C.xingming zhibanyuan,D.xingming jishuyuan,E.xingming fayi,A.riqi riqi"
sql=sql&" from zhiban A,user B,user C,user D,user E"
sql=sql&" where B.id=A.daibanzhang and C.id=A.zhibanyuan and D.id=A.jishuyuan and E.id=fayi"
sql=sql&" order by A.id"

这样写出的时候就可以这样:
<td>rs("xid")</td>
<td>rs("daibanzhang")</td>
<td>rs("zhibanyuan")</td>
<td>rs("jishuyuan")</td>
<td>rs("fayi")</td>
<td>rs("riqi")</td>

  相关解决方案