ACCESS数据库中如何利用SQL语句实现循环修改表的目的? 20
ACCESS数据库中如何利用SQL语句实现循环修改表的目的?有两个表tblAID,CNAME,NEWSCORE1A001802B002713C003924E004805D...
ACCESS数据库中如何利用SQL语句实现循环修改表的目的?
有两个表
tblA
ID, CNAME, NEWSCORE
1 A001 80
2 B002 71
3 C003 92
4 E004 80
5 D005 85
-------------------
tblB
ID, CNAME, SCORE
1 C003 42
2 E004 71
3 F005 92
-----------------------
把B表中的所有CNAME与A表中CAME对比,如果相等则将B表的SCORE数值修改为A的NEWSCORE值。
问:
1,可以直接用ACCESS数据库中的SQL语句实现吗,不借助其他东西,
2,SQL语句应该怎么写? 展开
有两个表
tblA
ID, CNAME, NEWSCORE
1 A001 80
2 B002 71
3 C003 92
4 E004 80
5 D005 85
-------------------
tblB
ID, CNAME, SCORE
1 C003 42
2 E004 71
3 F005 92
-----------------------
把B表中的所有CNAME与A表中CAME对比,如果相等则将B表的SCORE数值修改为A的NEWSCORE值。
问:
1,可以直接用ACCESS数据库中的SQL语句实现吗,不借助其他东西,
2,SQL语句应该怎么写? 展开
展开全部
ACCESS JET引擎不支持循环。如果一定要循环,可以利用ACCESS内置的VBA语言编程予以实现,但是这已经不属于数据库解决问题的方式了(数据库解决问题的方式是面向记录集合的,碰到需要面向单笔记录解决问题时它很无力)。
下面是纯SQL的解决方案,供参考
update tblB b,tblA a set b.SCORE=a.NEWSCORE
where a.CNAME=b.CNAME;
请留意tblA中的CNAME应该是唯一的,否则系统会选取同CNAME其中一条记录的NEWSCORE去更新tblB中的SCORE。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询