请教一个mysql高级查询语句:跨表关联的

zairwolfi 2004-11-29 04:03:28
1、a和b两个表。其中字段为name、counter。想遍历更新a,让它的counter增加同name的b的counter的值。这样写对不对?
"update a set a.counter=a.counter+b.counter where a.name=b.name"

2、a和c1/c2/c3……/cn等n个表(n=[a-z0-9])。内有字段为name、counter。其中name的关系为a.name=c1.name+c2.name+……+cn.name等所有分表的name量。想遍历更新a,使a.counter=a.counter+cn.counter where a.name=cn.name 。是否只能如是更新:
定义一个数组$arr=array("0","1","2",…,"9","a",…,"z"),然后for循环,运行语句为
"update a set a.counter=a.counter+c".$arr[$i].".counter where a.name=c".$arr[$i].".name

...全文
114 点赞 收藏 7
写回复
7 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
zairwolfi 2004-11-30
2、a和c1/c2/c3……/cn等n个表(n=[a-z0-9])。每个表内都有字段name、counter。其中name的关系为a.name=c1.name+c2.name+……+cn.name等所有分表的name并集。

想遍历更新a,使a.counter=a.counter+cn.counter where a.name=cn.name 。是否只能如是更新:

定义一个数组$arr=array("0","1","2",…,"9","a",…,"z"),然后for循环,运行语句为
"update a set a.counter=a.counter+c".$arr[$i].".counter where a.name=c".$arr[$i].".name
回复
carter880 2004-11-30
有点难度,支持一下!
回复
cloudchen 2004-11-29
1.
update a set a.counter=a.counter+b.counter from a,b where a.name=b.name
回复
zairwolfi 2004-11-29
1的?为什么还要update b?
回复
死胖子 2004-11-29
update a,b set a.counter=a.counter+b.counter where a.name=b.name
回复
cloudchen 2004-11-29
2说的不清楚
回复
zairwolfi 2004-11-29
2呢?、
回复
相关推荐
发帖
基础编程
创建于2007-09-28

2.1w+

社区成员

从PHP安装配置,PHP入门,PHP基础到PHP应用
申请成为版主
帖子事件
创建了帖子
2004-11-29 04:03
社区公告
暂无公告