Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2004.04.04;
Скачать: CL | DM;

Вниз

Ошибка: "<Table> was not locked with LOCK TABLES".   Найти похожие ветки 

 
Aldor ©   (2004-03-08 16:44) [0]

Сервер БД - MySQL.
Выполняются следующие запросы:

LOCK TABLES <Table1> LOW_PRIORITY WRITE
INSERT INTO <Table2> SELECT <some fields> FROM <Table1>

На попытке выполнить последний запрос вылетает вышеописанная ошибка:
 Error 1100: Table <Table2> was not locked with LOCK TABLES

Если заблокировать обе таблицы, то все в порядке. Почему нужно блокировать обе таблицы?


 
Nikolay M. ©   (2004-03-08 17:43) [1]

Из мануала:

При использовании команды LOCK TABLES необходимо блокировать все таблицы, которые предполагается использовать в последующих запросах, употребляя при этом те же самые псевдонимы, которые будут в запросах! Если таблица упоминается в запросе несколько раз (с псевдонимами), необходимо заблокировать каждый псевдоним!
Поскольку блокировки - это некая эмуляция транзакций, логично, что нужно блокировать все таблицы, над которыми производятся какие-то операции.


 
Aldor ©   (2004-03-08 19:23) [2]

Спасибо, у меня мануал MySQL 3.23. Там я подобного не нашел. Не подскажите, из какого мануала взяли?


 
Nikolay M. ©   (2004-03-08 21:11) [3]

http://www.mysql.com/doc/
в частности,
http://www.mysql.com/doc/ru/LOCK_TABLES.html
правда, я не в курсе, насколько перевод поспевает за оригиналом, раньше по первой ссылке выдавался англоязычный текст. Но вроде о 4.0.2 по-русски написано.



Страницы: 1 вся ветка

Текущий архив: 2004.04.04;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.047 c
1-1079359013
лопух5345
2004-03-15 16:56
2004.04.04
Почему не закрывается форма?


7-1074609579
Application
2004-01-20 17:39
2004.04.04
Минимизация в Tray ри старте с Windows


1-1079620489
Erik
2004-03-18 17:34
2004.04.04
Как определить масив констант?


1-1079172401
PiratA
2004-03-13 13:06
2004.04.04
TTreeView


1-1079691160
ashnurov
2004-03-19 13:12
2004.04.04
ListBox