34,594
社区成员
发帖
与我相关
我的任务
分享
tab1
id myname laststat
1 jod
2 mike
3 kid
4 sea
tab2
id tab1id mystat
1 1 未到
2 2 到
3 3 到
4 4 未到
5 1 到
6 2 到
7 3 未到
8 4 到
9 1 未到
10 2 到
11 3 未到
12 4 到
mssql2000中,通过SQL语句更新tab1的laststat:当超过2次“未到”,则laststat更新为“退出”,其他的为“正常”。该更新sql语句怎么写?
id myname laststat
1 jod 退出
2 mike 正常
3 kid 退出
4 sea 正常
UPDATE tab1
SET tab1.myname = ( SELECT CASE WHEN COUNT(1) > 1 THEN '退出'
ELSE '正常'
END
FROM tab2
WHERE tab2.tab1id = tab1.id
AND tab2.mystat = '未到'
)
WITH tab1(id,myname,laststat)AS(
select 1,'jod','' union all
select 2,'mike','' union all
select 3,'kid','' union all
select 4,'sea',''
),
tab2 (id ,tab1id,mystat)
as
(
select 1,1,'未到' union all
select 2,2,'到' union all
select 3,3,'到' union all
select 4,4,'未到' union all
select 5,1,'到' union all
select 6,2,'到' union all
select 7,3,'未到' union all
select 8,4,'到' union all
select 9,1,'未到' union all
select 10,2,'到' union all
select 11,3,'未到' union all
select 12,4,'到'
)
SELECT tab1.id ,
tab1.myname ,
( SELECT CASE WHEN COUNT(1) > 1 THEN '退出'
ELSE '正常'
END
FROM tab2
WHERE tab2.tab1id = tab1.id
AND tab2.mystat = '未到'
)AS laststat
FROM tab1;