0

在我使用的查询中,我正在创建一个临时表。这是查询:

SELECT u1.url,u1.id,u1.domain FROM urls u1 JOIN 
(create new table here) u2 ON u1.id = u2.url_id 
GROUP BY u1.domain;

在此查询之前,我锁定了两个表:

LOCK TABLES urls WRITE, ips WRITE;

但是,当我运行我的脚本时,mysql 给了我这个错误:

Table 'u1' was not locked with LOCK TABLES

那么有人可以帮我理解我在这里做错了什么吗?我不认为我可以提前声明 u2,因为它还没有真正完成。

4

1 回答 1

0

我在这里找到了解决方案:

LOCK TABLES urls WRITE, urls as u1 WRITE, ips WRITE;

本质上,如果您要在锁定语句之后使用别名引用表,则需要使用别名锁定它。

于 2012-06-09T04:29:27.027 回答