[英]Single update statement to update multiple rows mysql
我当时正在为在线大学管理系统生成自定义报告,但结果很糟糕,
我有一个名为say report
的主表,该表有10行,即学生的cs101
卷号为1到10。属性是roll
, name
和cs101
[这是主题代码,默认值为0创建]。
我有另一个表说each_subject_cs101
与字段roll
, name
和marks
。 但是它可能没有全部10名学生都在这里注册,比如说8名学生在那里(从1到8)。
现在,我想要的是更新report
集cs101
= marks
从each_subject_cs101
那些谁是存在于学生的each_subject_cs101
。 这是单个更新语句中的全部内容。
注意:roll no字段是两个表的主键
MySQL中的查询将是什么?
[PS:实际上,上述所有结构都更为复杂,并且是动态创建的。 我在这里使用别名使其更简单]
UPDATE report r, each_subject_cs101 escs
SET r.cs101 = escs.marks
WHERE r.roll = escs.roll
UPDATE report r
JOIN each_subject_cs101 escs
ON escs.roll = r.roll
SET r.cs101 = escs.marks;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.