请教一个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

...全文
141 7 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
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呢?、

21,893

社区成员

发帖
与我相关
我的任务
社区描述
从PHP安装配置,PHP入门,PHP基础到PHP应用
社区管理员
  • 基础编程社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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