0

我有这两张表:

tbl_courses
id  user_id  course_name
3   5        First Course
4   5        Second Course


tbl_notes
id  user_id  course_id
1   5        3
2   5        4

我正在尝试编写一个简单的合并脚本,该脚本正在接收更新的课程标题:course_name

例如,用户更改First CourseSecond Course并已请求将具有此新标题的所有便笺合并到此中。

所以我试图找到一种方法来更新tbl_notescourse_id中的所有条目First Course以匹配 idSecond Course

我发送$user_id, $course_id, 和$course_name作为参数

4

2 回答 2

1

如果我正确理解有查询您需要什么:

SQLFiddle示例

    UPDATE `tbl_notes`
    LEFT JOIN `tbl_courses` 
      ON `tbl_courses`.`user_id`  =`tbl_notes`.`user_id`
        AND `tbl_courses`.id  = `tbl_notes`.`course_id`
    SET `tbl_notes`.`course_id` = 4
    WHERE `tbl_courses`.`course_name` ='First Course'
      AND `tbl_courses`.`user_id` = 5

用PHP代码SQL查询:

$sql = "UPDATE `tbl_notes`
LEFT JOIN `tbl_courses` 
  ON `tbl_courses`.`user_id`  =`tbl_notes`.`user_id`
    AND `tbl_courses`.id  = `tbl_notes`.`course_id`
SET `tbl_notes`.`course_id` = $course_id
WHERE `tbl_courses`.`course_name` ='First Course'
AND `tbl_courses`.`user_id` =$user_id ";
于 2012-11-09T08:01:38.487 回答
0
update tbl_notes set course_id=(select id  
from tbl_courses where course_name='First Course' limit 1)
于 2012-11-09T05:49:51.413 回答