从视图的基础表中删除行是否可行?

时间:2018-01-04 21:07:36

标签: mysql

我有一个包含2个表和1个视图的数据库。其中一个表是查找表,我使用视图在一个表中显示数据。

CREATE TABLE places (
 place_id INT NOT NULL AUTO_INCREMENT,
 place VARCHAR(20) NOT NULL,
 PRIMARY KEY (place_id)
);

CREATE TABLE tasks (
 task_id INT NOT NULL AUTO_INCREMENT,
 task VARCHAR(20) NOT NULL,
 place_id INT NOT NULL,
 PRIMARY KEY (task_id),
 FOREIGN KEY (place_id) REFERENCES places(place_id)
);

为了减少选择查询的大小,我创建了一个显示两个表信息的视图。

CREATE VIEW view_planning AS
 SELECT tasks.task_id, tasks.task, places.place
 FROM tasks
 LEFT JOIN places ON places.place_id = tasks.place_id;

如果我想从任务表中删除一行,我必须执行以下操作:

DELETE FROM tasks WHERE 
 task_id = (SELECT task_id FROM tasks WHERE 
             task="some task" AND 
             place_id= (SELECT place_id FROM places WHERE place = "some place"));

我想使用这样的视图,因此查询更短:

DELETE FROM tasks WHERE 
 task_id = (SELECT task_id FROM view_planning WHERE 
             task="some task" AND place= "some place");

但是我得到了

  

错误代码:1443。“view_planning”表的定义阻止了对表“tasks”的操作DELETE。

有没有解决此错误的方法?

谢谢。

1 个答案:

答案 0 :(得分:1)

JOIN子句中使用WHERE而不是子查询。

DELETE t FROM tasks AS t
JOIN view_planning AS vp ON t.task_id = vp.task_id
WHERE vp.task = "some_task" AND vp.place = "some_place";