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

黄瓜黄瓜 2011-10-13 11:26:23

第一张表
----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关联,
用第二张表的进出记录 更新第一张表的 进出记录,批量一次将第一张表的所有数据全部更新...

...全文
118 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
蝈蝈(GuoGuo) 2011-10-13
  • 打赏
  • 举报
回复
你用的是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的结果。要更新要信你会的。
黄瓜黄瓜 2011-10-13
  • 打赏
  • 举报
回复

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

删除 top1的数据

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

--小F-- 2011-10-13
  • 打赏
  • 举报
回复
in1,in2..这个是怎么判定的?对应下面表的哪里?难道是依次更新?
pengxuan 2011-10-13
  • 打赏
  • 举报
回复
怎么更新
NBDBA 2011-10-13
  • 打赏
  • 举报
回复
结果?
这么多字段,说下更新就更新了?
一套操作数据库(*.db,DBF) 的工具,功能非常的强大。 2000版功能: 包括建立数据、删除数据、索引、排序、打印、预览、数据转换、数据备份、修改数据结构、输出文本、输出HTML文件、统计查询、字段求合、生成决策图等功能。 2002版新增功能: 1、多窗口(MDI)与单窗口两种模式 2、提供最近使用路径 3、提供BDE版本检查 4、设置进入口令 5、给数据填加口令 5、设置启动目录 6、复制记录、复制当前字段名称、复制字段名列、复制选择区域数据 7、改进SQL执行功能 8、改进数据转换功能 9、记录查找功能 10、自动生成创建SQL语句 11、设置数据移动位数 12、改进了建立索引功能,现可以建立主重索引(多个字段) 13、自动显示当前字段类型/宽度/字段总数/索引字段 Xp版新增功能: 1、加入了功能强大的报设计、报打印功能。可自己根据数据库设计报,还可以把设计好的报另存为报文件,也可输出如Html格式等。 2、加入了BDE数据库驱动程序,解决了以前下载后没有驱动程序不能正常运行的问题。 Xp 2002.11 版新增功能:(右击菜单) 1、加入对数据的剪切、复制、粘贴、删除功能。可直接把一张内的数据复制到另一张内,也可以把一张的某字段的数据复制到另一张的某字段。功能非常实用。(选择区域内数据) 2、加入输出Excel、Html、rtf、csv、txt文件格式。(选择区域内数据)

34,872

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧