SQL语句问题,MS SQL中测试通过但在ACCESS数库中通不过的,哪儿要改?(50分)

  • 主题发起人 主题发起人 del520
  • 开始时间 开始时间
D

del520

Unregistered / Unconfirmed
GUEST, unregistred user!
Update 考勤表
set 次数=(select sum(次数) from 加班表 where 考勤表.编号=加班表.编号 )
from 考勤表,加班表

有一个考勤表,表中有所有员工,里面记录员工一月的考勤信息
有一个加班表,表中记录员工在这个月内加班情况,同一个员工可能加班多次!
(有个次数字段,因为如果某个加班时间太长就会记作两次加班)

现在要将这个加班表中的员工加班次数统计之后放入到考勤表中以便计算工资。
上面这个语句在MS SQL中调试是正确的,但移值到ACCESS 中就通不过!

谁帮我改一下以适应ACCESS
 
你上面的那句真的能在SQL测试通过吗?
 
Update 考勤表 AAA,(select 编号,sum(次数) as 次数 from 加班表 group by 编号) BBB
set AAA.次数=BBB.次数
where AAA.编号=BBB.编号

参考
http://www.delphibbs.com/delphibbs/dispq.asp?lid=1250151
 
Update 考勤表
set 次数=(select sum(次数) from 加班表 where 考勤表.编号=加班表.编号 )

//SQL server中update是没有from 的

 
>> //SQL server中update是没有from 的
这个在SQLSERVER中是有的,它是T-SQL的语法。我感觉ACCESS中的SQL语法可能不支持。
 
To Quickslver 试了不行啊
使用AdoQuery调试报 操作必须使用一个可更新的查询
Update 考勤表 AAA,(select 编号,sum(次数) as 次数 from 加班表 group by 编号) BBB
set AAA.次数=BBB.次数
where AAA.编号=BBB.编号
 
仔细了一下,硬是不该再报错了。

可就ACCESS就是不给面子。TNND

无解了。
 
UPDATE 考勤表 AS AAA, 加班表 AS BBB
SET AAA.次数 = AAA.次数+BBB.次数
WHERE AAA.编号=BBB.编号

不过在执行这句前得先设初始值,设初始次数为0
UPDATE 考勤表
SET 次数 = 0
 
Access并不全部支持Ansi SQL 92标准,
可以使用DSum,Dmin,DMax,DAvg函数来实现这类问题,
推荐你去M$的英文知识库查答案。

 
把最后的from子句去掉。
 
接受答案了.
 

Similar threads

回复
0
查看
978
不得闲
S
回复
0
查看
3K
SUNSTONE的Delphi笔记
S
S
回复
0
查看
2K
SUNSTONE的Delphi笔记
S
D
回复
0
查看
867
DelphiTeacher的专栏
D
后退
顶部