根据一张表的数据更新另一张表数据

时间:2020-12-08 00:49:29

第一张表
----id----in1----out1----in2---out2---in3---ou3---in4---out4---in5---out5--
----1----null----null----null---null---null---null---null---null---null---null--
----2----null----null----null---null---null---null---null---null---null---null--
----3----null----null----null---null---null---null---null---null---null---null--
----4----null----null----null---null---null---null---null---null---null---null--
----5----null----null----null---null---null---null---null---null---null---null--
----6----null----null----null---null---null---null---null---null---null---null--
----7----null----null----null---null---null---null---null---null---null---null--
第二张表
----id----att_date-----InOrOut-
----1----2011-09-09-----in-
----2----2011-09-09-----out-
----3----2011-09-09-----out-
----4----2011-09-09-----out-



第一张表和第二张表的ID关联,
用第二张表的进出记录 更新第一张表的 进出记录,批量一次将第一张表的所有数据全部更新...

5 个解决方案

#1


结果?
这么多字段,说下更新就更新了?

#2


怎么更新

#3


in1,in2..这个是怎么判定的?对应下面表的哪里?难道是依次更新?

#4



第一张表存的是每个人的每一天的进出,比如OUT4 代表进出两次..打卡时间在第二张表中..
比如一天有8次进出 
while(@index<=8)
begin
更新第一张表的in1 根据第二张表的ID和时间还有InOrOut='in'(进出标示)top 1 更新in1

删除 top1的数据

然后在更新out1 继续top 1
删除 top1数据
直到更新到第8对 结束
end

#5


你用的是SQL2005还是?如果用SQL2005有一个行转列的。
如果不是自己写一个就行了。
看你这个记录应该是考勤的。你那个日期应该有时分秒的。
----id----att_date-----InOrOut-
----1----2011-09-09-----in-
----2----2011-09-09-----out-
----3----2011-09-09-----out-
----4----2011-09-09-----out-
可以用以下语句
select  id,att_date,inorout,idd=identity(int,1,1)
into #t
from t2

select t1.id,
in1=Max(case when t1.idd-t2.idd+1=1 and t1.inorout='in' then t1.att_date else null end)
out1=Max(case when t1.idd-t2.idd+1=1 and t1.inorout='Out' then t1.att_date else null end),
in2=Max(case when t1.idd-t2.idd+1=2 and t1.inorout='in' then t1.att_date else null end)
out2=Max(case when t1.idd-t2.idd+1=2 and t1.inorout='Out' then t1.att_date else null end)
......
from #t t1 inner join 

  (select id,idd=min(idd)
   from #t group by id
   group by id) t2 on t1.id=t2.id
group by t1.id

看你最多显示多少列了。按这个就可以得到表1的结果。要更新要信你会的。

#1


结果?
这么多字段,说下更新就更新了?

#2


怎么更新

#3


in1,in2..这个是怎么判定的?对应下面表的哪里?难道是依次更新?

#4



第一张表存的是每个人的每一天的进出,比如OUT4 代表进出两次..打卡时间在第二张表中..
比如一天有8次进出 
while(@index<=8)
begin
更新第一张表的in1 根据第二张表的ID和时间还有InOrOut='in'(进出标示)top 1 更新in1

删除 top1的数据

然后在更新out1 继续top 1
删除 top1数据
直到更新到第8对 结束
end

#5


你用的是SQL2005还是?如果用SQL2005有一个行转列的。
如果不是自己写一个就行了。
看你这个记录应该是考勤的。你那个日期应该有时分秒的。
----id----att_date-----InOrOut-
----1----2011-09-09-----in-
----2----2011-09-09-----out-
----3----2011-09-09-----out-
----4----2011-09-09-----out-
可以用以下语句
select  id,att_date,inorout,idd=identity(int,1,1)
into #t
from t2

select t1.id,
in1=Max(case when t1.idd-t2.idd+1=1 and t1.inorout='in' then t1.att_date else null end)
out1=Max(case when t1.idd-t2.idd+1=1 and t1.inorout='Out' then t1.att_date else null end),
in2=Max(case when t1.idd-t2.idd+1=2 and t1.inorout='in' then t1.att_date else null end)
out2=Max(case when t1.idd-t2.idd+1=2 and t1.inorout='Out' then t1.att_date else null end)
......
from #t t1 inner join 

  (select id,idd=min(idd)
   from #t group by id
   group by id) t2 on t1.id=t2.id
group by t1.id

看你最多显示多少列了。按这个就可以得到表1的结果。要更新要信你会的。