Дата: 25.10.2013
Автор: Василий Лукьянчиков , vl (at) sqlinfo (dot) ru
В статье рассмотрены ошибки, возникающие из-за ограничений сервера MySQL на выполнение некоторых видов подзапросов. Даны рекомендации по их исправлению с примерами. Материал ориентирован на новичков.
MySQL error 1093
В MySQL нельзя изменять данные и одновременно делать выборку из той же таблицы в подзапросе. Запросы вида
DELETE FROM t WHERE col = (SELECT … FROM t …);
UPDATE t … WHERE col = (SELECT … FROM t …);
{INSERT|REPLACE} INTO t (SELECT … FROM t …);
приведут к ошибке
ERROR 1093 (HY000): You can‘t specify target table ‘t‘ for update in FROM clause.
Есть два варианта решения проблемы:
1. Универсальный способ, рекомендуемый в документации, — использовать вложенный подзапрос.
DELETE FROM t WHERE col = (SELECT * FROM (SELECT … FROM t…) AS t1);
UPDATE t … WHERE col = (SELECT * FROM (SELECT … FROM t…) AS t1);
{INSERT|REPLACE} INTO t (SELECT * FROM (SELECT … FROM t…) AS t1);
В этом случае подзапрос к изменяемой таблице оказывается в части FROM и материализуется во временную таблицу в начале выполнения запроса. Т.о. при обновлении чтение данных будет идти из временной таблицы, а не из той, которая обновляется.
2. Для запросов UPDATE и DELETE можно использовать многотабличную форму. Например, для UPDATE запрос выше примет вид:
UPDATE t, (SELECT … FROM t …) t1 … WHERE t.col=t1.col;
По сути это тот же метод, что и предыдущий — подзапрос переносится в часть перечисления таблиц. Но кроме чуть более компактной записи многотабличная форма операторов UPDATE/DELETE в некоторых случаях позволяет вообще обойтись без подзапроса.
Примеры:
- мы хотим удалить из первой таблицы строки, не имеющие соответствия (по id) во второй.
DELETE t1 FROM t1 LEFT JOIN t2 ON t1.id=t2.id WHERE t2.id IS NULL;
Для сравнения через подзапрос:
DELETE FROM t1 WHERE id IN (SELECT * FROM (SELECT t1.id FROM t1 LEFT JOIN t2 ON t1.id=t2.id WHERE t2.id IS NULL) as t_x);
- удалить из таблицы дубликаты (строки с одинаковыми значениями поля col) с меньшим id
DELETE t1 FROM t t1 JOIN t t2
ON t1.col = t2.col AND t1.id < t2.id;через подзапрос
DELETE t FROM t LEFT JOIN (SELECT max(id) as id, col FROM t GROUP BY col) t1 USING(id) WHERE t1.id IS NULL;
- а вот задача пометить важными статьи авторов, имеющих более 10 публикаций, без подзапроса не решается:
UPDATE articles SET important=1 WHERE author IN (SELECT * FROM (SELECT author FROM articles GROUP BY 1 HAVING count(*)>10) t);
или
UPDATE articles, (SELECT author FROM articles GROUP BY 1 HAVING count(*)>10) t SET important=1 WHERE author = t.author;
- в завершение рассмотрим пример, когда подзапрос находится в части SET. Например, для строк с id>10 мы хотим установить значение поля col равное значению этого поля для строки с id равным 2.
UPDATE t as t1 JOIN t as t2 ON t2.id=2 SET t1.col = t2.col WHERE t1.id > 10;
через подзапрос
UPDATE t
SET col = (SELECT * FROM (SELECT col FROM t WHERE id = 2) AS t1)
WHERE id = >10;
MySQL error 1235
В MySQL не реализована возможность использования IN/ALL/ANY/SOME вместе с подзапросом, содержащим LIMIT. Попытка выполнить такой запрос приведет к ошибке:
mysql> SELECT * FROM t1
-> WHERE s1 IN (SELECT s2 FROM t2 ORDER BY s1 LIMIT 1);
ERROR 1235 (42000): This version of MySQL doesn‘t yet support
‘LIMIT & IN/ALL/ANY/SOME subquery‘
Данное ограничение обходится путем переписывания запроса через JOIN с нужным подзапросом. Например:
SELECT * FROM t1 WHERE t1.col1 IN (SELECT col2 FROM t2 WHERE x);
можно переписать как
SELECT * FROM t1 JOIN (SELECT DISTINCT col2 FROM t2 WHERE x) t ON t1.col1=t.col2;
Если t2.col2 — уникальный ключ, то DISTINCT не потребуется и от подзапроса можно избавиться:
SELECT * FROM t1 JOIN t2 ON t1.col1=t.col2 WHERE t2.x;
На практике IN подзапросы более распространены и в большинстве случаев указанного правила будет достаточно. Некоторые виды ALL/ANY подзапросов могут потребовать более сложных преобразований, но переписать через JOIN можно любой их них.
Например, мы хотим найти страны в Европе, у которых каждый из трех самых крупных городов имеют население свыше миллиона. Если бы не запрет на использование LIMIT в ALL подзапросах, то решением было:
SELECT name FROM country WHERE continent=‘Europe’ AND
1000000 < ALL (SELECT population FROM city WHERE countrycode=code OREDR BY 1 DESC LIMIT 3);
через JOIN данный запрос примет вид:
SELECT country.name FROM country JOIN city ON countrycode=code
WHERE continent=‘Europe’ AND city.population>1000000
GROUP BY 1 HAVING(count(*)>2);
Замечание: Использовать вложенный подзапрос при mysql error 1235 является плохой идеей:
1. этот прием сработает только в случае независимых подзапросов;
2. на старых версиях (до MariaDB5.3/MySQL5.6) будет иметь худшую производительность, а в новых оптимизатор сам перепишет запрос через JOIN
P.S. Если после прочтения статьи ваш вопрос с MySQL Error 1093 или 1235 остался нерешенным, то задавайте его на форуме SQLinfo
Дата публикации: 25.10.2013
© Все права на данную статью принадлежат порталу SQLInfo.ru. Перепечатка в интернет-изданиях разрешается только с указанием автора и прямой ссылки на оригинальную статью. Перепечатка в бумажных изданиях допускается только с разрешения редакции.
Содержание
- MySQL error 1093 и 1235
- MySQL error 1093
- MySQL error 1235
- MySQL error code 1093 – How we tackle it
- Why MySQL error code 1093?
- How we fix it?
- Conclusion
- PREVENT YOUR SERVER FROM CRASHING!
- Ошибка MySQL 1093 — невозможно указать целевую таблицу для обновления в предложении FROM
- Mysql error 1093 hy000
MySQL error 1093 и 1235
Автор: Василий Лукьянчиков , vl (at) sqlinfo (dot) ru
В статье рассмотрены ошибки, возникающие из-за ограничений сервера MySQL на выполнение некоторых видов подзапросов. Даны рекомендации по их исправлению с примерами. Материал ориентирован на новичков.
MySQL error 1093
В MySQL нельзя изменять данные и одновременно делать выборку из той же таблицы в подзапросе. Запросы вида
Есть два варианта решения проблемы:
1. Универсальный способ, рекомендуемый в документации, — использовать вложенный подзапрос.
В этом случае подзапрос к изменяемой таблице оказывается в части FROM и материализуется во временную таблицу в начале выполнения запроса. Т.о. при обновлении чтение данных будет идти из временной таблицы, а не из той, которая обновляется.
2. Для запросов UPDATE и DELETE можно использовать многотабличную форму. Например, для UPDATE запрос выше примет вид:
По сути это тот же метод, что и предыдущий — подзапрос переносится в часть перечисления таблиц. Но кроме чуть более компактной записи многотабличная форма операторов UPDATE/DELETE в некоторых случаях позволяет вообще обойтись без подзапроса.
- мы хотим удалить из первой таблицы строки, не имеющие соответствия (по id) во второй.
MySQL error 1235
В MySQL не реализована возможность использования IN/ALL/ANY/SOME вместе с подзапросом, содержащим LIMIT. Попытка выполнить такой запрос приведет к ошибке:
Данное ограничение обходится путем переписывания запроса через JOIN с нужным подзапросом. Например:
SELECT * FROM t1 WHERE t1.col1 IN ( SELECT col2 FROM t2 WHERE x ) ;
можно переписать как
SELECT * FROM t1 JOIN ( SELECT DISTINCT col2 FROM t2 WHERE x ) t ON t1.col1=t.col2;
Если t2.col2 — уникальный ключ, то DISTINCT не потребуется и от подзапроса можно избавиться:
SELECT * FROM t1 JOIN t2 ON t1.col1=t.col2 WHERE t2.x;
На практике IN подзапросы более распространены и в большинстве случаев указанного правила будет достаточно. Некоторые виды ALL/ANY подзапросов могут потребовать более сложных преобразований, но переписать через JOIN можно любой их них.
Например, мы хотим найти страны в Европе, у которых каждый из трех самых крупных городов имеют население свыше миллиона. Если бы не запрет на использование LIMIT в ALL подзапросах, то решением было:
через JOIN данный запрос примет вид:
Замечание: Использовать вложенный подзапрос при mysql error 1235 является плохой идеей:
1. этот прием сработает только в случае независимых подзапросов;
2. на старых версиях (до MariaDB5.3/MySQL5.6) будет иметь худшую производительность, а в новых оптимизатор сам перепишет запрос через JOIN
Источник
MySQL error code 1093 – How we tackle it
Stuck with MySQL error code 1093? We can help you fix it.
This error is mainly related to the subqueries.
At Bobcares, we often get requests to fix MySQL errors, as a part of our Server Management Services.
Today, let’s see how our Support Engineers fix MySQL Error Code 1093 for our customers.
Why MySQL error code 1093?
While dealing with MySQL, we may encounter some errors.
Today, we shall discuss MySQL error 1093 and see how we fix it.
This MySQL error code is mainly related to subqueries. It appears while updating or deleting a table, and while building a subquery for that using the same table.
How we fix it?
Recently, one of our customers approached us with a request to fix an error like the one shown below, which he was getting while updating a table.
So, our Engineers checked in detail and found that he was using a subquery build with the same table which he wanted to update.
So, we deleted the reference of the table to update from subquery and this fixed the error.
Also, we handled a situation where a customer approached us with the same MySQL error code 1093.
He said this error appeared while trying to delete a table using a query as given below:
We changed the query as below because the customer is trying to delete the rows from the same data source which a subquery refers to, and that cannot be deleted.
Finally, this fixed the error.
[Need more assistance to fix the MySQL Error code 1093?- We’re available 24/7.]
Conclusion
In short, this error can be fixed by deleting the reference of the table to update from the subquery. Also, we saw how our Support Engineers find fix for this MySQL error.
PREVENT YOUR SERVER FROM CRASHING!
Never again lose customers to poor server speed! Let us help you.
Our server experts will monitor & maintain your server 24/7 so that it remains lightning fast and secure.
Источник
Ошибка MySQL 1093 — невозможно указать целевую таблицу для обновления в предложении FROM
У меня есть таблица story_category в моей базе данных с поврежденными записями. Следующий запрос возвращает поврежденные записи:
Я пытался удалить их, выполнив:
Но получаю следующую ошибку:
#1093 — You can’t specify target table ‘story_category’ for update in FROM clause
Как я могу это преодолеть?
Обновление: этот ответ охватывает общую классификацию ошибок. Более конкретный ответ о том, как лучше всего обрабатывать точный запрос OP, см. В других ответах на этот вопрос.
В MySQL вы не можете изменять ту же таблицу, которую используете в части SELECT.
Это поведение задокументировано по адресу: http://dev.mysql.com/doc/refman/5.6/en/update.html.
Может быть, вы можете просто присоединиться к столу к себе
Если логика достаточно проста, чтобы изменить форму запроса, потеряйте подзапрос и присоедините таблицу к самой себе, используя соответствующие критерии выбора. Это заставит MySQL рассматривать таблицу как две разные вещи, позволяя вносить деструктивные изменения.
В качестве альтернативы попробуйте вложить подзапрос глубже в предложение from .
Если вам абсолютно необходим подзапрос, есть обходной путь, но он уродлив по нескольким причинам, включая производительность:
Вложенный подзапрос в предложении FROM создает неявную временную таблицу , поэтому он не считается той же таблицей, которую вы обновляете.
. но остерегайтесь оптимизатора запросов
Однако имейте в виду , что начиная с MySQL 5.7.6 и выше оптимизатор может оптимизировать подзапрос и по-прежнему выдавать вам ошибку. К счастью, optimizer_switch переменную можно использовать для отключения этого поведения; хотя я не мог рекомендовать делать это как нечто большее, чем краткосрочное исправление или для небольших разовых задач.
Спасибо Peter V. Mørch за этот совет в комментариях.
Пример техники был от Baron Schwartz, первоначально опубликован в Nabble , перефразированный и расширенный здесь.
Источник
Mysql error 1093 hy000
This chapter lists the errors that may appear when you call MySQL from any host language. The first list displays server error messages. The second list displays client program messages.
Server error information comes from the following files:
The Error values and the symbols in parentheses correspond to definitions in the include/mysqld_error.h MySQL source file.
The SQLSTATE values correspond to definitions in the include/sql_state.h MySQL source file.
SQLSTATE error codes are displayed only if you use MySQL version 4.1 and up. SQLSTATE codes were added for compatibility with X/Open, ANSI, and ODBC behavior.
The Message values correspond to the error messages that are listed in the share/errmsg.txt file. %d and %s represent numbers and strings, respectively, that are substituted into the messages when they are displayed.
Because updates are frequent, it is possible that these files contain additional error information not listed here.
Ошибка: 1000 SQLSTATE: HY000 ( ER_HASHCHK )
Ошибка: 1001 SQLSTATE: HY000 ( ER_NISAMCHK )
Ошибка: 1002 SQLSTATE: HY000 ( ER_NO )
Ошибка: 1003 SQLSTATE: HY000 ( ER_YES )
Ошибка: 1004 SQLSTATE: HY000 ( ER_CANT_CREATE_FILE )
Сообщение: Невозможно создать файл ‘%s’ (ошибка: %d)
Ошибка: 1005 SQLSTATE: HY000 ( ER_CANT_CREATE_TABLE )
Сообщение: Невозможно создать таблицу ‘%s’ (ошибка: %d)
Ошибка: 1006 SQLSTATE: HY000 ( ER_CANT_CREATE_DB )
Сообщение: Невозможно создать базу данных ‘%s’ (ошибка: %d)
Ошибка: 1007 SQLSTATE: HY000 ( ER_DB_CREATE_EXISTS )
Сообщение: Невозможно создать базу данных ‘%s’. База данных уже существует
Ошибка: 1008 SQLSTATE: HY000 ( ER_DB_DROP_EXISTS )
Сообщение: Невозможно удалить базу данных ‘%s’. Такой базы данных нет
Ошибка: 1009 SQLSTATE: HY000 ( ER_DB_DROP_DELETE )
Сообщение: Ошибка при удалении базы данных (невозможно удалить ‘%s’, ошибка: %d)
Ошибка: 1010 SQLSTATE: HY000 ( ER_DB_DROP_RMDIR )
Сообщение: Невозможно удалить базу данных (невозможно удалить каталог ‘%s’, ошибка: %d)
Ошибка: 1011 SQLSTATE: HY000 ( ER_CANT_DELETE_FILE )
Сообщение: Ошибка при удалении ‘%s’ (ошибка: %d)
Ошибка: 1012 SQLSTATE: HY000 ( ER_CANT_FIND_SYSTEM_REC )
Сообщение: Невозможно прочитать запись в системной таблице
Ошибка: 1013 SQLSTATE: HY000 ( ER_CANT_GET_STAT )
Сообщение: Невозможно получить статусную информацию о ‘%s’ (ошибка: %d)
Ошибка: 1014 SQLSTATE: HY000 ( ER_CANT_GET_WD )
Сообщение: Невозможно определить рабочий каталог (ошибка: %d)
Ошибка: 1015 SQLSTATE: HY000 ( ER_CANT_LOCK )
Сообщение: Невозможно поставить блокировку на файле (ошибка: %d)
Ошибка: 1016 SQLSTATE: HY000 ( ER_CANT_OPEN_FILE )
Сообщение: Невозможно открыть файл: ‘%s’ (ошибка: %d)
Ошибка: 1017 SQLSTATE: HY000 ( ER_FILE_NOT_FOUND )
Сообщение: Невозможно найти файл: ‘%s’ (ошибка: %d)
Ошибка: 1018 SQLSTATE: HY000 ( ER_CANT_READ_DIR )
Сообщение: Невозможно прочитать каталог ‘%s’ (ошибка: %d)
Ошибка: 1019 SQLSTATE: HY000 ( ER_CANT_SET_WD )
Сообщение: Невозможно перейти в каталог ‘%s’ (ошибка: %d)
Ошибка: 1020 SQLSTATE: HY000 ( ER_CHECKREAD )
Сообщение: Запись изменилась с момента последней выборки в таблице ‘%s’
Ошибка: 1021 SQLSTATE: HY000 ( ER_DISK_FULL )
Сообщение: Диск заполнен. (%s). Ожидаем, пока кто-то не уберет после себя мусор.
Ошибка: 1022 SQLSTATE: 23000 ( ER_DUP_KEY )
Сообщение: Невозможно произвести запись, дублирующийся ключ в таблице ‘%s’
Ошибка: 1023 SQLSTATE: HY000 ( ER_ERROR_ON_CLOSE )
Сообщение: Ошибка при закрытии ‘%s’ (ошибка: %d)
Ошибка: 1024 SQLSTATE: HY000 ( ER_ERROR_ON_READ )
Сообщение: Ошибка чтения файла ‘%s’ (ошибка: %d)
Ошибка: 1025 SQLSTATE: HY000 ( ER_ERROR_ON_RENAME )
Сообщение: Ошибка при переименовании ‘%s’ в ‘%s’ (ошибка: %d)
Ошибка: 1026 SQLSTATE: HY000 ( ER_ERROR_ON_WRITE )
Сообщение: Ошибка записи в файл ‘%s’ (ошибка: %d)
Ошибка: 1027 SQLSTATE: HY000 ( ER_FILE_USED )
Сообщение: ‘%s’ заблокирован для изменений
Ошибка: 1028 SQLSTATE: HY000 ( ER_FILSORT_ABORT )
Сообщение: Сортировка прервана
Ошибка: 1029 SQLSTATE: HY000 ( ER_FORM_NOT_FOUND )
Сообщение: Представление ‘%s’ не существует для ‘%s’
Ошибка: 1030 SQLSTATE: HY000 ( ER_GET_ERRNO )
Сообщение: Получена ошибка %d от обработчика таблиц
Ошибка: 1031 SQLSTATE: HY000 ( ER_ILLEGAL_HA )
Сообщение: Обработчик таблицы ‘%s’ не поддерживает эту возможность
Ошибка: 1032 SQLSTATE: HY000 ( ER_KEY_NOT_FOUND )
Сообщение: Невозможно найти запись в ‘%s’
Ошибка: 1033 SQLSTATE: HY000 ( ER_NOT_FORM_FILE )
Сообщение: Некорректная информация в файле ‘%s’
Ошибка: 1034 SQLSTATE: HY000 ( ER_NOT_KEYFILE )
Сообщение: Некорректный индексный файл для таблицы: ‘%s’. Попробуйте восстановить его
Ошибка: 1035 SQLSTATE: HY000 ( ER_OLD_KEYFILE )
Сообщение: Старый индексный файл для таблицы ‘%s’; отремонтируйте его!
Ошибка: 1036 SQLSTATE: HY000 ( ER_OPEN_AS_READONLY )
Сообщение: Таблица ‘%s’ предназначена только для чтения
Ошибка: 1037 SQLSTATE: HY001 ( ER_OUTOFMEMORY )
Сообщение: Недостаточно памяти. Перезапустите сервер и попробуйте еще раз (нужно %d байт)
Ошибка: 1038 SQLSTATE: HY001 ( ER_OUT_OF_SORTMEMORY )
Сообщение: Недостаточно памяти для сортировки. Увеличьте размер буфера сортировки на сервере
Ошибка: 1039 SQLSTATE: HY000 ( ER_UNEXPECTED_EOF )
Сообщение: Неожиданный конец файла ‘%s’ (ошибка: %d)
Ошибка: 1040 SQLSTATE: 08004 ( ER_CON_COUNT_ERROR )
Сообщение: Слишком много соединений
Ошибка: 1041 SQLSTATE: HY000 ( ER_OUT_OF_RESOURCES )
Сообщение: Недостаточно памяти; удостоверьтесь, что mysqld или какой-либо другой процесс не занимает всю доступную память. Если нет, то вы можете использовать ulimit, чтобы выделить для mysqld больше памяти, или увеличить объем файла подкачки
Ошибка: 1042 SQLSTATE: 08S01 ( ER_BAD_HOST_ERROR )
Сообщение: Невозможно получить имя хоста для вашего адреса
Ошибка: 1043 SQLSTATE: 08S01 ( ER_HANDSHAKE_ERROR )
Сообщение: Некорректное приветствие
Ошибка: 1044 SQLSTATE: 42000 ( ER_DBACCESS_DENIED_ERROR )
Сообщение: Для пользователя ‘%s’@’%s’ доступ к базе данных ‘%s’ закрыт
Ошибка: 1045 SQLSTATE: 28000 ( ER_ACCESS_DENIED_ERROR )
Сообщение: Доступ закрыт для пользователя ‘%s’@’%s’ (был использован пароль: %s)
Ошибка: 1046 SQLSTATE: 3D000 ( ER_NO_DB_ERROR )
Сообщение: База данных не выбрана
Ошибка: 1047 SQLSTATE: 08S01 ( ER_UNKNOWN_COM_ERROR )
Сообщение: Неизвестная команда коммуникационного протокола
Ошибка: 1048 SQLSTATE: 23000 ( ER_BAD_NULL_ERROR )
Сообщение: Столбец ‘%s’ не может принимать величину NULL
Ошибка: 1049 SQLSTATE: 42000 ( ER_BAD_DB_ERROR )
Сообщение: Неизвестная база данных ‘%s’
Ошибка: 1050 SQLSTATE: 42S01 ( ER_TABLE_EXISTS_ERROR )
Сообщение: Таблица ‘%s’ уже существует
Ошибка: 1051 SQLSTATE: 42S02 ( ER_BAD_TABLE_ERROR )
Сообщение: Неизвестная таблица ‘%s’
Ошибка: 1052 SQLSTATE: 23000 ( ER_NON_UNIQ_ERROR )
Сообщение: Столбец ‘%s’ в %s задан неоднозначно
Ошибка: 1053 SQLSTATE: 08S01 ( ER_SERVER_SHUTDOWN )
Сообщение: Сервер находится в процессе остановки
Ошибка: 1054 SQLSTATE: 42S22 ( ER_BAD_FIELD_ERROR )
Сообщение: Неизвестный столбец ‘%s’ в ‘%s’
Ошибка: 1055 SQLSTATE: 42000 ( ER_WRONG_FIELD_WITH_GROUP )
Сообщение: ‘%s’ не присутствует в GROUP BY
Ошибка: 1056 SQLSTATE: 42000 ( ER_WRONG_GROUP_FIELD )
Сообщение: Невозможно произвести группировку по ‘%s’
Ошибка: 1057 SQLSTATE: 42000 ( ER_WRONG_SUM_SELECT )
Сообщение: Выражение содержит групповые функции и столбцы, но не включает GROUP BY. А как вы умудрились получить это сообщение об ошибке?
Ошибка: 1058 SQLSTATE: 21S01 ( ER_WRONG_VALUE_COUNT )
Сообщение: Количество столбцов не совпадает с количеством значений
Ошибка: 1059 SQLSTATE: 42000 ( ER_TOO_LONG_IDENT )
Сообщение: Слишком длинный идентификатор ‘%s’
Ошибка: 1060 SQLSTATE: 42S21 ( ER_DUP_FIELDNAME )
Сообщение: Дублирующееся имя столбца ‘%s’
Ошибка: 1061 SQLSTATE: 42000 ( ER_DUP_KEYNAME )
Сообщение: Дублирующееся имя ключа ‘%s’
Ошибка: 1062 SQLSTATE: 23000 ( ER_DUP_ENTRY )
Сообщение: Дублирующаяся запись ‘%s’ по ключу %d
Ошибка: 1063 SQLSTATE: 42000 ( ER_WRONG_FIELD_SPEC )
Сообщение: Некорректный определитель столбца для столбца ‘%s’
Ошибка: 1064 SQLSTATE: 42000 ( ER_PARSE_ERROR )
Сообщение: %s около ‘%s’ на строке %d
Ошибка: 1065 SQLSTATE: HY000 ( ER_EMPTY_QUERY )
Сообщение: Запрос оказался пустым
Ошибка: 1066 SQLSTATE: 42000 ( ER_NONUNIQ_TABLE )
Сообщение: Повторяющаяся таблица/псевдоним ‘%s’
Ошибка: 1067 SQLSTATE: 42000 ( ER_INVALID_DEFAULT )
Сообщение: Некорректное значение по умолчанию для ‘%s’
Ошибка: 1068 SQLSTATE: 42000 ( ER_MULTIPLE_PRI_KEY )
Сообщение: Указано несколько первичных ключей
Ошибка: 1069 SQLSTATE: 42000 ( ER_TOO_MANY_KEYS )
Сообщение: Указано слишком много ключей. Разрешается указывать не более %d ключей
Ошибка: 1070 SQLSTATE: 42000 ( ER_TOO_MANY_KEY_PARTS )
Сообщение: Указано слишком много частей составного ключа. Разрешается указывать не более %d частей
Ошибка: 1071 SQLSTATE: 42000 ( ER_TOO_LONG_KEY )
Сообщение: Указан слишком длинный ключ. Максимальная длина ключа составляет %d байт
Ошибка: 1072 SQLSTATE: 42000 ( ER_KEY_COLUMN_DOES_NOT_EXITS )
Сообщение: Ключевой столбец ‘%s’ в таблице не существует
Ошибка: 1073 SQLSTATE: 42000 ( ER_BLOB_USED_AS_KEY )
Сообщение: Столбец типа BLOB ‘%s’ не может быть использован как значение ключа в таблице такого типа
Ошибка: 1074 SQLSTATE: 42000 ( ER_TOO_BIG_FIELDLENGTH )
Сообщение: Слишком большая длина столбца ‘%s’ (максимум = %d). Используйте тип BLOB вместо текущего
Ошибка: 1075 SQLSTATE: 42000 ( ER_WRONG_AUTO_KEY )
Сообщение: Некорректное определение таблицы: может существовать только один автоинкрементный столбец, и он должен быть определен как ключ
Ошибка: 1076 SQLSTATE: HY000 ( ER_READY )
Сообщение: %s: Готов принимать соединения. Версия: ‘%s’ сокет: ‘%s’ порт: %d
Ошибка: 1077 SQLSTATE: HY000 ( ER_NORMAL_SHUTDOWN )
Сообщение: %s: Корректная остановка
Ошибка: 1078 SQLSTATE: HY000 ( ER_GOT_SIGNAL )
Сообщение: %s: Получен сигнал %d. Прекращаем!
Ошибка: 1079 SQLSTATE: HY000 ( ER_SHUTDOWN_COMPLETE )
Сообщение: %s: Остановка завершена
Ошибка: 1080 SQLSTATE: 08S01 ( ER_FORCING_CLOSE )
Сообщение: %s: Принудительно закрываем поток %ld пользователя: ‘%s’
Ошибка: 1081 SQLSTATE: 08S01 ( ER_IPSOCK_ERROR )
Сообщение: Невозможно создать IP-сокет
Ошибка: 1082 SQLSTATE: 42S12 ( ER_NO_SUCH_INDEX )
Сообщение: В таблице ‘%s’ нет такого индекса, как в CREATE INDEX. Создайте таблицу заново
Ошибка: 1083 SQLSTATE: 42000 ( ER_WRONG_FIELD_TERMINATORS )
Сообщение: Аргумент разделителя полей — не тот, который ожидался. Обращайтесь к документации
Ошибка: 1084 SQLSTATE: 42000 ( ER_BLOBS_AND_NO_TERMINATED )
Сообщение: Фиксированный размер записи с полями типа BLOB использовать нельзя, применяйте ‘fields terminated by’
Ошибка: 1085 SQLSTATE: HY000 ( ER_TEXTFILE_NOT_READABLE )
Сообщение: Файл ‘%s’ должен находиться в том же каталоге, что и база данных, или быть общедоступным для чтения
Ошибка: 1086 SQLSTATE: HY000 ( ER_FILE_EXISTS_ERROR )
Сообщение: Файл ‘%s’ уже существует
Ошибка: 1087 SQLSTATE: HY000 ( ER_LOAD_INFO )
Сообщение: Записей: %ld Удалено: %ld Пропущено: %ld Предупреждений: %ld
Ошибка: 1088 SQLSTATE: HY000 ( ER_ALTER_INFO )
Сообщение: Записей: %ld Дубликатов: %ld
Ошибка: 1089 SQLSTATE: HY000 ( ER_WRONG_SUB_KEY )
Сообщение: Некорректная часть ключа. Используемая часть ключа не является строкой, указанная длина больше, чем длина части ключа, или обработчик таблицы не поддерживает уникальные части ключа
Ошибка: 1090 SQLSTATE: 42000 ( ER_CANT_REMOVE_ALL_FIELDS )
Сообщение: Нельзя удалить все столбцы с помощью ALTER TABLE. Используйте DROP TABLE
Ошибка: 1091 SQLSTATE: 42000 ( ER_CANT_DROP_FIELD_OR_KEY )
Сообщение: Невозможно удалить (DROP) ‘%s’. Убедитесь что столбец/ключ действительно существует
Ошибка: 1092 SQLSTATE: HY000 ( ER_INSERT_INFO )
Сообщение: Записей: %ld Дубликатов: %ld Предупреждений: %ld
Ошибка: 1093 SQLSTATE: HY000 ( ER_UPDATE_TABLE_USED )
Сообщение: Не допускается указание таблицы ‘%s’ в списке таблиц FROM для внесения в нее изменений
Ошибка: 1094 SQLSTATE: HY000 ( ER_NO_SUCH_THREAD )
Сообщение: Неизвестный номер потока: %lu
Ошибка: 1095 SQLSTATE: HY000 ( ER_KILL_DENIED_ERROR )
Сообщение: Вы не являетесь владельцем потока %lu
Ошибка: 1096 SQLSTATE: HY000 ( ER_NO_TABLES_USED )
Сообщение: Никакие таблицы не использованы
Ошибка: 1097 SQLSTATE: HY000 ( ER_TOO_BIG_SET )
Сообщение: Слишком много значений для столбца %s в SET
Ошибка: 1098 SQLSTATE: HY000 ( ER_NO_UNIQUE_LOGFILE )
Сообщение: Невозможно создать уникальное имя файла журнала %s.(1-999)
Ошибка: 1099 SQLSTATE: HY000 ( ER_TABLE_NOT_LOCKED_FOR_WRITE )
Сообщение: Таблица ‘%s’ заблокирована уровнем READ lock и не может быть изменена
Ошибка: 1100 SQLSTATE: HY000 ( ER_TABLE_NOT_LOCKED )
Сообщение: Таблица ‘%s’ не была заблокирована с помощью LOCK TABLES
Ошибка: 1101 SQLSTATE: 42000 ( ER_BLOB_CANT_HAVE_DEFAULT )
Сообщение: Невозможно указывать значение по умолчанию для столбца BLOB ‘%s’
Ошибка: 1102 SQLSTATE: 42000 ( ER_WRONG_DB_NAME )
Сообщение: Некорректное имя базы данных ‘%s’
Ошибка: 1103 SQLSTATE: 42000 ( ER_WRONG_TABLE_NAME )
Сообщение: Некорректное имя таблицы ‘%s’
Ошибка: 1104 SQLSTATE: 42000 ( ER_TOO_BIG_SELECT )
Сообщение: Для такой выборки SELECT должен будет просмотреть слишком много записей и, видимо, это займет очень много времени. Проверьте ваше указание WHERE, и, если в нем все в порядке, укажите SET SQL_BIG_SELECTS=1
Ошибка: 1105 SQLSTATE: HY000 ( ER_UNKNOWN_ERROR )
Сообщение: Неизвестная ошибка
Ошибка: 1106 SQLSTATE: 42000 ( ER_UNKNOWN_PROCEDURE )
Сообщение: Неизвестная процедура ‘%s’
Ошибка: 1107 SQLSTATE: 42000 ( ER_WRONG_PARAMCOUNT_TO_PROCEDURE )
Сообщение: Некорректное количество параметров для процедуры ‘%s’
Ошибка: 1108 SQLSTATE: HY000 ( ER_WRONG_PARAMETERS_TO_PROCEDURE )
Сообщение: Некорректные параметры для процедуры ‘%s’
Ошибка: 1109 SQLSTATE: 42S02 ( ER_UNKNOWN_TABLE )
Сообщение: Неизвестная таблица ‘%s’ в %s
Ошибка: 1110 SQLSTATE: 42000 ( ER_FIELD_SPECIFIED_TWICE )
Сообщение: Столбец ‘%s’ указан дважды
Ошибка: 1111 SQLSTATE: HY000 ( ER_INVALID_GROUP_FUNC_USE )
Сообщение: Неправильное использование групповых функций
Ошибка: 1112 SQLSTATE: 42000 ( ER_UNSUPPORTED_EXTENSION )
Сообщение: В таблице ‘%s’ используются возможности, не поддерживаемые в этой версии MySQL
Ошибка: 1113 SQLSTATE: 42000 ( ER_TABLE_MUST_HAVE_COLUMNS )
Сообщение: В таблице должен быть как минимум один столбец
Ошибка: 1114 SQLSTATE: HY000 ( ER_RECORD_FILE_FULL )
Сообщение: Таблица ‘%s’ переполнена
Ошибка: 1115 SQLSTATE: 42000 ( ER_UNKNOWN_CHARACTER_SET )
Сообщение: Неизвестная кодировка ‘%s’
Ошибка: 1116 SQLSTATE: HY000 ( ER_TOO_MANY_TABLES )
Сообщение: Слишком много таблиц. MySQL может использовать только %d таблиц в соединении
Ошибка: 1117 SQLSTATE: HY000 ( ER_TOO_MANY_FIELDS )
Сообщение: Слишком много столбцов
Ошибка: 1118 SQLSTATE: 42000 ( ER_TOO_BIG_ROWSIZE )
Сообщение: Слишком большой размер записи. Максимальный размер строки, исключая поля BLOB, — %d. Возможно, вам следует изменить тип некоторых полей на BLOB
Ошибка: 1119 SQLSTATE: HY000 ( ER_STACK_OVERRUN )
Сообщение: Стек потоков переполнен: использовано: %ld из %ld стека. Применяйте ‘mysqld -O thread_stack=#’ для указания большего размера стека, если необходимо
Ошибка: 1120 SQLSTATE: 42000 ( ER_WRONG_OUTER_JOIN )
Сообщение: В OUTER JOIN обнаружена перекрестная зависимость. Внимательно проанализируйте свои условия ON
Ошибка: 1121 SQLSTATE: 42000 ( ER_NULL_COLUMN_IN_INDEX )
Сообщение: Столбец ‘%s’ используется в UNIQUE или в INDEX, но не определен как NOT NULL
Ошибка: 1122 SQLSTATE: HY000 ( ER_CANT_FIND_UDF )
Сообщение: Невозможно загрузить функцию ‘%s’
Ошибка: 1123 SQLSTATE: HY000 ( ER_CANT_INITIALIZE_UDF )
Сообщение: Невозможно инициализировать функцию ‘%s’; %s
Ошибка: 1124 SQLSTATE: HY000 ( ER_UDF_NO_PATHS )
Сообщение: Недопустимо указывать пути для динамических библиотек
Ошибка: 1125 SQLSTATE: HY000 ( ER_UDF_EXISTS )
Сообщение: Функция ‘%s’ уже существует
Ошибка: 1126 SQLSTATE: HY000 ( ER_CANT_OPEN_LIBRARY )
Сообщение: Невозможно открыть динамическую библиотеку ‘%s’ (ошибка: %d %s)
Ошибка: 1127 SQLSTATE: HY000 ( ER_CANT_FIND_DL_ENTRY )
Сообщение: Невозможно отыскать функцию ‘%s’ в библиотеке
Ошибка: 1128 SQLSTATE: HY000 ( ER_FUNCTION_NOT_DEFINED )
Сообщение: Функция ‘%s’ не определена
Ошибка: 1129 SQLSTATE: HY000 ( ER_HOST_IS_BLOCKED )
Сообщение: Хост ‘%s’ заблокирован из-за слишком большого количества ошибок соединения. Разблокировать его можно с помощью ‘mysqladmin flush-hosts’
Ошибка: 1130 SQLSTATE: HY000 ( ER_HOST_NOT_PRIVILEGED )
Сообщение: Хосту ‘%s’ не разрешается подключаться к этому серверу MySQL
Ошибка: 1131 SQLSTATE: 42000 ( ER_PASSWORD_ANONYMOUS_USER )
Сообщение: Вы используете MySQL от имени анонимного пользователя, а анонимным пользователям не разрешается менять пароли
Ошибка: 1132 SQLSTATE: 42000 ( ER_PASSWORD_NOT_ALLOWED )
Сообщение: Для того чтобы изменять пароли других пользователей, у вас должны быть привилегии на изменение таблиц в базе данных mysql
Ошибка: 1133 SQLSTATE: 42000 ( ER_PASSWORD_NO_MATCH )
Сообщение: Невозможно отыскать подходящую запись в таблице пользователей
Ошибка: 1134 SQLSTATE: HY000 ( ER_UPDATE_INFO )
Сообщение: Совпало записей: %ld Изменено: %ld Предупреждений: %ld
Ошибка: 1135 SQLSTATE: HY000 ( ER_CANT_CREATE_THREAD )
Сообщение: Невозможно создать новый поток (ошибка %d). Если это не ситуация, связанная с нехваткой памяти, то вам следует изучить документацию на предмет описания возможной ошибки работы в конкретной ОС
Ошибка: 1136 SQLSTATE: 21S01 ( ER_WRONG_VALUE_COUNT_ON_ROW )
Сообщение: Количество столбцов не совпадает с количеством значений в записи %ld
Ошибка: 1137 SQLSTATE: HY000 ( ER_CANT_REOPEN_TABLE )
Сообщение: Невозможно заново открыть таблицу ‘%s’
Ошибка: 1138 SQLSTATE: 42000 ( ER_INVALID_USE_OF_NULL )
Сообщение: Неправильное использование величины NULL
Ошибка: 1139 SQLSTATE: 42000 ( ER_REGEXP_ERROR )
Сообщение: Получена ошибка ‘%s’ от регулярного выражения
Ошибка: 1140 SQLSTATE: 42000 ( ER_MIX_OF_GROUP_FUNC_AND_FIELDS )
Сообщение: Одновременное использование сгруппированных (GROUP) столбцов (MIN(),MAX(),COUNT(). ) с несгруппированными столбцами является некорректным, если в выражении есть GROUP BY
Ошибка: 1141 SQLSTATE: 42000 ( ER_NONEXISTING_GRANT )
Сообщение: Такие права не определены для пользователя ‘%s’ на хосте ‘%s’
Ошибка: 1142 SQLSTATE: 42000 ( ER_TABLEACCESS_DENIED_ERROR )
Сообщение: Команда %s запрещена пользователю ‘%s’@’%s’ для таблицы ‘%s’
Ошибка: 1143 SQLSTATE: 42000 ( ER_COLUMNACCESS_DENIED_ERROR )
Сообщение: Команда %s запрещена пользователю ‘%s’@’%s’ для столбца ‘%s’ в таблице ‘%s’
Ошибка: 1144 SQLSTATE: 42000 ( ER_ILLEGAL_GRANT_FOR_TABLE )
Сообщение: Неверная команда GRANT или REVOKE. Обратитесь к документации, чтобы выяснить, какие привилегии можно использовать
Ошибка: 1145 SQLSTATE: 42000 ( ER_GRANT_WRONG_HOST_OR_USER )
Сообщение: Слишком длинное имя пользователя/хоста для GRANT
Ошибка: 1146 SQLSTATE: 42S02 ( ER_NO_SUCH_TABLE )
Сообщение: Таблица ‘%s.%s’ не существует
Ошибка: 1147 SQLSTATE: 42000 ( ER_NONEXISTING_TABLE_GRANT )
Сообщение: Такие права не определены для пользователя ‘%s’ на компьютере ‘%s’ для таблицы ‘%s’
Ошибка: 1148 SQLSTATE: 42000 ( ER_NOT_ALLOWED_COMMAND )
Сообщение: Эта команда не допускается в данной версии MySQL
Ошибка: 1149 SQLSTATE: 42000 ( ER_SYNTAX_ERROR )
Сообщение: У вас ошибка в запросе. Изучите документацию по используемой версии MySQL на предмет корректного синтаксиса
Ошибка: 1150 SQLSTATE: HY000 ( ER_DELAYED_CANT_CHANGE_LOCK )
Сообщение: Поток, обслуживающий отложенную вставку (delayed insert), не смог получить запрашиваемую блокировку на таблицу %s
Ошибка: 1151 SQLSTATE: HY000 ( ER_TOO_MANY_DELAYED_THREADS )
Сообщение: Слишком много потоков, обслуживающих отложенную вставку (delayed insert)
Ошибка: 1152 SQLSTATE: 08S01 ( ER_ABORTING_CONNECTION )
Сообщение: Прервано соединение %ld к базе данных ‘%s’ пользователя ‘%s’ (%s)
Ошибка: 1153 SQLSTATE: 08S01 ( ER_NET_PACKET_TOO_LARGE )
Сообщение: Полученный пакет больше, чем ‘max_allowed_packet’
Ошибка: 1154 SQLSTATE: 08S01 ( ER_NET_READ_ERROR_FROM_PIPE )
Сообщение: Получена ошибка чтения от потока соединения (connection pipe)
Ошибка: 1155 SQLSTATE: 08S01 ( ER_NET_FCNTL_ERROR )
Сообщение: Получена ошибка от fcntl()
Ошибка: 1156 SQLSTATE: 08S01 ( ER_NET_PACKETS_OUT_OF_ORDER )
Сообщение: Пакеты получены в неверном порядке
Ошибка: 1157 SQLSTATE: 08S01 ( ER_NET_UNCOMPRESS_ERROR )
Сообщение: Невозможно распаковать пакет, полученный через коммуникационный протокол
Ошибка: 1158 SQLSTATE: 08S01 ( ER_NET_READ_ERROR )
Сообщение: Получена ошибка в процессе получения пакета через коммуникационный протокол
Ошибка: 1159 SQLSTATE: 08S01 ( ER_NET_READ_INTERRUPTED )
Сообщение: Получен таймаут ожидания пакета через коммуникационный протокол
Ошибка: 1160 SQLSTATE: 08S01 ( ER_NET_ERROR_ON_WRITE )
Сообщение: Получена ошибка при передаче пакета через коммуникационный протокол
Ошибка: 1161 SQLSTATE: 08S01 ( ER_NET_WRITE_INTERRUPTED )
Сообщение: Получен таймаут в процессе передачи пакета через коммуникационный протокол
Ошибка: 1162 SQLSTATE: 42000 ( ER_TOO_LONG_STRING )
Сообщение: Результирующая строка больше, чем ‘max_allowed_packet’
Ошибка: 1163 SQLSTATE: 42000 ( ER_TABLE_CANT_HANDLE_BLOB )
Сообщение: Используемая таблица не поддерживает типы BLOB/TEXT
Ошибка: 1164 SQLSTATE: 42000 ( ER_TABLE_CANT_HANDLE_AUTO_INCREMENT )
Сообщение: Используемая таблица не поддерживает автоинкрементные столбцы
Ошибка: 1165 SQLSTATE: HY000 ( ER_DELAYED_INSERT_TABLE_LOCKED )
Сообщение: Нельзя использовать INSERT DELAYED для таблицы ‘%s’, потому что она заблокирована с помощью LOCK TABLES
Ошибка: 1166 SQLSTATE: 42000 ( ER_WRONG_COLUMN_NAME )
Сообщение: Неверное имя столбца ‘%s’
Ошибка: 1167 SQLSTATE: 42000 ( ER_WRONG_KEY_COLUMN )
Сообщение: Использованный обработчик таблицы не может проиндексировать столбец ‘%s’
Ошибка: 1168 SQLSTATE: HY000 ( ER_WRONG_MRG_TABLE )
Сообщение: Не все таблицы в MERGE определены одинаково
Ошибка: 1169 SQLSTATE: 23000 ( ER_DUP_UNIQUE )
Сообщение: Невозможно записать в таблицу ‘%s’ из-за ограничений уникального ключа
Ошибка: 1170 SQLSTATE: 42000 ( ER_BLOB_KEY_WITHOUT_LENGTH )
Сообщение: Столбец типа BLOB ‘%s’ был указан в определении ключа без указания длины ключа
Ошибка: 1171 SQLSTATE: 42000 ( ER_PRIMARY_CANT_HAVE_NULL )
Сообщение: Все части первичного ключа (PRIMARY KEY) должны быть определены как NOT NULL; Если вам нужна поддержка величин NULL в ключе, воспользуйтесь индексом UNIQUE
Ошибка: 1172 SQLSTATE: 42000 ( ER_TOO_MANY_ROWS )
Сообщение: В результате возвращена более чем одна строка
Ошибка: 1173 SQLSTATE: 42000 ( ER_REQUIRES_PRIMARY_KEY )
Сообщение: Этот тип таблицы требует определения первичного ключа
Ошибка: 1174 SQLSTATE: HY000 ( ER_NO_RAID_COMPILED )
Сообщение: Эта версия MySQL скомпилирована без поддержки RAID
Ошибка: 1175 SQLSTATE: HY000 ( ER_UPDATE_WITHOUT_KEY_IN_SAFE_MODE )
Сообщение: Вы работаете в режиме безопасных обновлений (safe update mode) и попробовали изменить таблицу без использования ключевого столбца в части WHERE
Ошибка: 1176 SQLSTATE: HY000 ( ER_KEY_DOES_NOT_EXITS )
Сообщение: Ключ ‘%s’ не существует в таблице ‘%s’
Ошибка: 1177 SQLSTATE: 42000 ( ER_CHECK_NO_SUCH_TABLE )
Сообщение: Невозможно открыть таблицу
Ошибка: 1178 SQLSTATE: 42000 ( ER_CHECK_NOT_IMPLEMENTED )
Сообщение: Обработчик таблицы не поддерживает этого: %s
Ошибка: 1179 SQLSTATE: 25000 ( ER_CANT_DO_THIS_DURING_AN_TRANSACTION )
Сообщение: Вам не разрешено выполнять эту команду в транзакции
Ошибка: 1180 SQLSTATE: HY000 ( ER_ERROR_DURING_COMMIT )
Сообщение: Получена ошибка %d в процессе COMMIT
Ошибка: 1181 SQLSTATE: HY000 ( ER_ERROR_DURING_ROLLBACK )
Сообщение: Получена ошибка %d в процессе ROLLBACK
Ошибка: 1182 SQLSTATE: HY000 ( ER_ERROR_DURING_FLUSH_LOGS )
Сообщение: Получена ошибка %d в процессе FLUSH_LOGS
Ошибка: 1183 SQLSTATE: HY000 ( ER_ERROR_DURING_CHECKPOINT )
Сообщение: Получена ошибка %d в процессе CHECKPOINT
Ошибка: 1184 SQLSTATE: 08S01 ( ER_NEW_ABORTING_CONNECTION )
Сообщение: Прервано соединение %ld к базе данных ‘%s’ пользователя ‘%s’ с хоста `%s’ (%s)
Ошибка: 1185 SQLSTATE: HY000 ( ER_DUMP_NOT_IMPLEMENTED )
Сообщение: Обработчик этой таблицы не поддерживает двоичного сохранения образа таблицы (dump)
Ошибка: 1186 SQLSTATE: HY000 ( ER_FLUSH_MASTER_BINLOG_CLOSED )
Сообщение: Двоичный журнал обновления закрыт, невозможно выполнить RESET MASTER
Ошибка: 1187 SQLSTATE: HY000 ( ER_INDEX_REBUILD )
Сообщение: Ошибка перестройки индекса сохраненной таблицы ‘%s’
Ошибка: 1188 SQLSTATE: HY000 ( ER_MASTER )
Сообщение: Ошибка от головного сервера: ‘%s’
Ошибка: 1189 SQLSTATE: 08S01 ( ER_MASTER_NET_READ )
Сообщение: Возникла ошибка чтения в процессе коммуникации с головным сервером
Ошибка: 1190 SQLSTATE: 08S01 ( ER_MASTER_NET_WRITE )
Сообщение: Возникла ошибка записи в процессе коммуникации с головным сервером
Ошибка: 1191 SQLSTATE: HY000 ( ER_FT_MATCHING_KEY_NOT_FOUND )
Сообщение: Невозможно отыскать полнотекстовый (FULLTEXT) индекс, соответствующий списку столбцов
Ошибка: 1192 SQLSTATE: HY000 ( ER_LOCK_OR_ACTIVE_TRANSACTION )
Сообщение: Невозможно выполнить указанную команду, поскольку у вас присутствуют активно заблокированные таблица или открытая транзакция
Ошибка: 1193 SQLSTATE: HY000 ( ER_UNKNOWN_SYSTEM_VARIABLE )
Сообщение: Неизвестная системная переменная ‘%s’
Ошибка: 1194 SQLSTATE: HY000 ( ER_CRASHED_ON_USAGE )
Сообщение: Таблица ‘%s’ помечена как испорченная и должна пройти проверку и ремонт
Ошибка: 1195 SQLSTATE: HY000 ( ER_CRASHED_ON_REPAIR )
Сообщение: Таблица ‘%s’ помечена как испорченная и последний (автоматический?) ремонт не был успешным
Ошибка: 1196 SQLSTATE: HY000 ( ER_WARNING_NOT_COMPLETE_ROLLBACK )
Сообщение: Внимание: по некоторым измененным нетранзакционным таблицам невозможно будет произвести откат транзакции
Ошибка: 1197 SQLSTATE: HY000 ( ER_TRANS_CACHE_FULL )
Сообщение: Транзакции, включающей большое количество команд, потребовалось более чем ‘max_binlog_cache_size’ байт. Увеличьте эту переменную сервера mysqld и попробуйте еще раз
Ошибка: 1198 SQLSTATE: HY000 ( ER_SLAVE_MUST_STOP )
Сообщение: Эту операцию невозможно выполнить при работающем потоке подчиненного сервера. Сначала выполните STOP SLAVE
Ошибка: 1199 SQLSTATE: HY000 ( ER_SLAVE_NOT_RUNNING )
Сообщение: Для этой операции требуется работающий подчиненный сервер. Сначала выполните START SLAVE
Ошибка: 1200 SQLSTATE: HY000 ( ER_BAD_SLAVE )
Сообщение: Этот сервер не настроен как подчиненный. Внесите исправления в конфигурационном файле или с помощью CHANGE MASTER TO
Ошибка: 1201 SQLSTATE: HY000 ( ER_MASTER_INFO )
Сообщение: Could not initialize master info structure, more error messages can be found in the MySQL error log
Ошибка: 1202 SQLSTATE: HY000 ( ER_SLAVE_THREAD )
Сообщение: Невозможно создать поток подчиненного сервера. Проверьте системные ресурсы
Ошибка: 1203 SQLSTATE: 42000 ( ER_TOO_MANY_USER_CONNECTIONS )
Сообщение: У пользователя %s уже больше чем ‘max_user_connections’ активных соединений
Ошибка: 1204 SQLSTATE: HY000 ( ER_SET_CONSTANTS_ONLY )
Сообщение: Вы можете использовать в SET только константные выражения
Ошибка: 1205 SQLSTATE: HY000 ( ER_LOCK_WAIT_TIMEOUT )
Сообщение: Таймаут ожидания блокировки истек; попробуйте перезапустить транзакцию
Ошибка: 1206 SQLSTATE: HY000 ( ER_LOCK_TABLE_FULL )
Сообщение: Общее количество блокировок превысило размеры таблицы блокировок
Ошибка: 1207 SQLSTATE: 25000 ( ER_READ_ONLY_TRANSACTION )
Сообщение: Блокировки обновлений нельзя получить в процессе чтения не принятой (в режиме READ UNCOMMITTED) транзакции
Ошибка: 1208 SQLSTATE: HY000 ( ER_DROP_DB_WITH_READ_LOCK )
Сообщение: Не допускается DROP DATABASE, пока поток держит глобальную блокировку чтения
Ошибка: 1209 SQLSTATE: HY000 ( ER_CREATE_DB_WITH_READ_LOCK )
Сообщение: Не допускается CREATE DATABASE, пока поток держит глобальную блокировку чтения
Ошибка: 1210 SQLSTATE: HY000 ( ER_WRONG_ARGUMENTS )
Сообщение: Неверные параметры для %s
Ошибка: 1211 SQLSTATE: 42000 ( ER_NO_PERMISSION_TO_CREATE_USER )
Сообщение: ‘%s’@’%s’ не разрешается создавать новых пользователей
Ошибка: 1212 SQLSTATE: HY000 ( ER_UNION_TABLES_IN_DIFFERENT_DIR )
Сообщение: Неверное определение таблицы; Все таблицы в MERGE должны принадлежать одной и той же базе данных
Ошибка: 1213 SQLSTATE: 40001 ( ER_LOCK_DEADLOCK )
Сообщение: Возникла тупиковая ситуация в процессе получения блокировки; Попробуйте перезапустить транзакцию
Ошибка: 1214 SQLSTATE: HY000 ( ER_TABLE_CANT_HANDLE_FT )
Сообщение: Используемый тип таблиц не поддерживает полнотекстовых индексов
Ошибка: 1215 SQLSTATE: HY000 ( ER_CANNOT_ADD_FOREIGN )
Сообщение: Невозможно добавить ограничения внешнего ключа
Ошибка: 1216 SQLSTATE: 23000 ( ER_NO_REFERENCED_ROW )
Сообщение: Невозможно добавить или обновить дочернюю строку: проверка ограничений внешнего ключа не выполняется
Ошибка: 1217 SQLSTATE: 23000 ( ER_ROW_IS_REFERENCED )
Сообщение: Невозможно удалить или обновить родительскую строку: проверка ограничений внешнего ключа не выполняется
Ошибка: 1218 SQLSTATE: 08S01 ( ER_CONNECT_TO_MASTER )
Сообщение: Ошибка соединения с головным сервером: %s
Ошибка: 1219 SQLSTATE: HY000 ( ER_QUERY_ON_MASTER )
Сообщение: Ошибка выполнения запроса на головном сервере: %s
Ошибка: 1220 SQLSTATE: HY000 ( ER_ERROR_WHEN_EXECUTING_COMMAND )
Сообщение: Ошибка при выполнении команды %s: %s
Ошибка: 1221 SQLSTATE: HY000 ( ER_WRONG_USAGE )
Сообщение: Неверное использование %s и %s
Ошибка: 1222 SQLSTATE: 21000 ( ER_WRONG_NUMBER_OF_COLUMNS_IN_SELECT )
Сообщение: Использованные операторы выборки (SELECT) дают разное количество столбцов
Ошибка: 1223 SQLSTATE: HY000 ( ER_CANT_UPDATE_WITH_READLOCK )
Сообщение: Невозможно исполнить запрос, поскольку у вас установлены конфликтующие блокировки чтения
Ошибка: 1224 SQLSTATE: HY000 ( ER_MIXING_NOT_ALLOWED )
Сообщение: Использование транзакционных таблиц наряду с нетранзакционными запрещено
Ошибка: 1225 SQLSTATE: HY000 ( ER_DUP_ARGUMENT )
Сообщение: Опция ‘%s’ дважды использована в выражении
Ошибка: 1226 SQLSTATE: 42000 ( ER_USER_LIMIT_REACHED )
Сообщение: Пользователь ‘%s’ превысил использование ресурса ‘%s’ (текущее значение: %ld)
Ошибка: 1227 SQLSTATE: HY000 ( ER_SPECIFIC_ACCESS_DENIED_ERROR )
Сообщение: В доступе отказано. Вам нужны привилегии %s для этой операции
Ошибка: 1228 SQLSTATE: HY000 ( ER_LOCAL_VARIABLE )
Сообщение: Переменная ‘%s’ является потоковой (SESSION) переменной и не может быть изменена с помощью SET GLOBAL
Ошибка: 1229 SQLSTATE: HY000 ( ER_GLOBAL_VARIABLE )
Сообщение: Переменная ‘%s’ является глобальной (GLOBAL) переменной, и ее следует изменять с помощью SET GLOBAL
Ошибка: 1230 SQLSTATE: 42000 ( ER_NO_DEFAULT )
Сообщение: Переменная ‘%s’ не имеет значения по умолчанию
Ошибка: 1231 SQLSTATE: 42000 ( ER_WRONG_VALUE_FOR_VAR )
Сообщение: Переменная ‘%s’ не может быть установлена в значение ‘%s’
Ошибка: 1232 SQLSTATE: 42000 ( ER_WRONG_TYPE_FOR_VAR )
Сообщение: Неверный тип аргумента для переменной ‘%s’
Ошибка: 1233 SQLSTATE: HY000 ( ER_VAR_CANT_BE_READ )
Сообщение: Переменная ‘%s’ может быть только установлена, но не считана
Ошибка: 1234 SQLSTATE: 42000 ( ER_CANT_USE_OPTION_HERE )
Сообщение: Неверное использование или в неверном месте указан ‘%s’
Ошибка: 1235 SQLSTATE: 42000 ( ER_NOT_SUPPORTED_YET )
Сообщение: Эта версия MySQL пока еще не поддерживает ‘%s’
Ошибка: 1236 SQLSTATE: HY000 ( ER_MASTER_FATAL_ERROR_READING_BINLOG )
Сообщение: Получена неисправимая ошибка %d: ‘%s’ от головного сервера в процессе выборки данных из двоичного журнала
Ошибка: 1237 SQLSTATE: HY000 ( ER_SLAVE_IGNORED_TABLE )
Сообщение: Slave SQL thread ignored the query because of replicate-*-table rules
Ошибка: 1238 SQLSTATE: HY000 ( ER_INCORRECT_GLOBAL_LOCAL_VAR )
Сообщение: Variable ‘%s’ is a %s variable
Ошибка: 1239 SQLSTATE: 42000 ( ER_WRONG_FK_DEF )
Сообщение: Incorrect foreign key definition for ‘%s’: %s
Ошибка: 1240 SQLSTATE: HY000 ( ER_KEY_REF_DO_NOT_MATCH_TABLE_REF )
Сообщение: Key reference and table reference don’t match
Ошибка: 1241 SQLSTATE: 21000 ( ER_OPERAND_COLUMNS )
Сообщение: Операнд должен содержать %d колонок
Ошибка: 1242 SQLSTATE: 21000 ( ER_SUBQUERY_NO_1_ROW )
Сообщение: Подзапрос возвращает более одной записи
Ошибка: 1243 SQLSTATE: HY000 ( ER_UNKNOWN_STMT_HANDLER )
Сообщение: Unknown prepared statement handler (%.*s) given to %s
Ошибка: 1244 SQLSTATE: HY000 ( ER_CORRUPT_HELP_DB )
Сообщение: Help database is corrupt or does not exist
Ошибка: 1245 SQLSTATE: HY000 ( ER_CYCLIC_REFERENCE )
Сообщение: Циклическая ссылка на подзапрос
Ошибка: 1246 SQLSTATE: HY000 ( ER_AUTO_CONVERT )
Сообщение: Преобразование поля ‘%s’ из %s в %s
Ошибка: 1247 SQLSTATE: 42S22 ( ER_ILLEGAL_REFERENCE )
Сообщение: Ссылка ‘%s’ не поддерживается (%s)
Ошибка: 1248 SQLSTATE: 42000 ( ER_DERIVED_MUST_HAVE_ALIAS )
Сообщение: Every derived table must have its own alias
Ошибка: 1249 SQLSTATE: 01000 ( ER_SELECT_REDUCED )
Сообщение: Select %u был упразднен в процессе оптимизации
Ошибка: 1250 SQLSTATE: 42000 ( ER_TABLENAME_NOT_ALLOWED_HERE )
Сообщение: Table ‘%s’ from one of the SELECTs cannot be used in %s
Ошибка: 1251 SQLSTATE: 08004 ( ER_NOT_SUPPORTED_AUTH_MODE )
Сообщение: Client does not support authentication protocol requested by server; consider upgrading MySQL client
Ошибка: 1252 SQLSTATE: 42000 ( ER_SPATIAL_CANT_HAVE_NULL )
Сообщение: All parts of a SPATIAL index must be NOT NULL
Ошибка: 1253 SQLSTATE: 42000 ( ER_COLLATION_CHARSET_MISMATCH )
Сообщение: COLLATION ‘%s’ is not valid for CHARACTER SET ‘%s’
Ошибка: 1254 SQLSTATE: HY000 ( ER_SLAVE_WAS_RUNNING )
Сообщение: Slave is already running
Ошибка: 1255 SQLSTATE: HY000 ( ER_SLAVE_WAS_NOT_RUNNING )
Сообщение: Slave has already been stopped
Ошибка: 1256 SQLSTATE: HY000 ( ER_TOO_BIG_FOR_UNCOMPRESS )
Сообщение: Uncompressed data size too large; the maximum size is %d (probably, length of uncompressed data was corrupted)
Ошибка: 1257 SQLSTATE: HY000 ( ER_ZLIB_Z_MEM_ERROR )
Сообщение: ZLIB: Not enough memory
Ошибка: 1258 SQLSTATE: HY000 ( ER_ZLIB_Z_BUF_ERROR )
Сообщение: ZLIB: Not enough room in the output buffer (probably, length of uncompressed data was corrupted)
Ошибка: 1259 SQLSTATE: HY000 ( ER_ZLIB_Z_DATA_ERROR )
Сообщение: ZLIB: Input data corrupted
Ошибка: 1260 SQLSTATE: HY000 ( ER_CUT_VALUE_GROUP_CONCAT )
Сообщение: %d line(s) were cut by GROUP_CONCAT()
Ошибка: 1261 SQLSTATE: 01000 ( ER_WARN_TOO_FEW_RECORDS )
Сообщение: Row %ld doesn’t contain data for all columns
Ошибка: 1262 SQLSTATE: 01000 ( ER_WARN_TOO_MANY_RECORDS )
Сообщение: Row %ld was truncated; it contained more data than there were input columns
Ошибка: 1263 SQLSTATE: 01000 ( ER_WARN_NULL_TO_NOTNULL )
Сообщение: Data truncated; NULL supplied to NOT NULL column ‘%s’ at row %ld
Ошибка: 1264 SQLSTATE: 01000 ( ER_WARN_DATA_OUT_OF_RANGE )
Сообщение: Data truncated; out of range for column ‘%s’ at row %ld
Ошибка: 1265 SQLSTATE: 01000 ( ER_WARN_DATA_TRUNCATED )
Сообщение: Data truncated for column ‘%s’ at row %ld
Ошибка: 1266 SQLSTATE: HY000 ( ER_WARN_USING_OTHER_HANDLER )
Сообщение: Using storage engine %s for table ‘%s’
Ошибка: 1267 SQLSTATE: HY000 ( ER_CANT_AGGREGATE_2COLLATIONS )
Сообщение: Illegal mix of collations (%s,%s) and (%s,%s) for operation ‘%s’
Ошибка: 1268 SQLSTATE: HY000 ( ER_DROP_USER )
Сообщение: Can’t drop one or more of the requested users
Ошибка: 1269 SQLSTATE: HY000 ( ER_REVOKE_GRANTS )
Сообщение: Can’t revoke all privileges, grant for one or more of the requested users
Ошибка: 1270 SQLSTATE: HY000 ( ER_CANT_AGGREGATE_3COLLATIONS )
Сообщение: Illegal mix of collations (%s,%s), (%s,%s), (%s,%s) for operation ‘%s’
Ошибка: 1271 SQLSTATE: HY000 ( ER_CANT_AGGREGATE_NCOLLATIONS )
Сообщение: Illegal mix of collations for operation ‘%s’
Ошибка: 1272 SQLSTATE: HY000 ( ER_VARIABLE_IS_NOT_STRUCT )
Сообщение: Variable ‘%s’ is not a variable component (can’t be used as XXXX.variable_name)
Ошибка: 1273 SQLSTATE: HY000 ( ER_UNKNOWN_COLLATION )
Сообщение: Unknown collation: ‘%s’
Ошибка: 1274 SQLSTATE: HY000 ( ER_SLAVE_IGNORED_SSL_PARAMS )
Сообщение: SSL parameters in CHANGE MASTER are ignored because this MySQL slave was compiled without SSL support; they can be used later if MySQL slave with SSL is started
Ошибка: 1275 SQLSTATE: HY000 ( ER_SERVER_IS_IN_SECURE_AUTH_MODE )
Сообщение: Сервер запущен в режиме —secure-auth (безопасной авторизации), но для пользователя ‘%s’@’%s’ пароль сохранён в старом формате; необходимо обновить формат пароля
Ошибка: 1276 SQLSTATE: HY000 ( ER_WARN_FIELD_RESOLVED )
Сообщение: Поле или ссылка ‘%s%s%s%s%s’ из SELECTа #%d была найдена в SELECTе #%d
Ошибка: 1277 SQLSTATE: HY000 ( ER_BAD_SLAVE_UNTIL_COND )
Сообщение: Incorrect parameter or combination of parameters for START SLAVE UNTIL
Ошибка: 1278 SQLSTATE: HY000 ( ER_MISSING_SKIP_SLAVE )
Сообщение: It is recommended to run with —skip-slave-start when doing step-by-step replication with START SLAVE UNTIL; otherwise, you are not safe in case of unexpected slave’s mysqld restart
Ошибка: 1279 SQLSTATE: HY000 ( ER_UNTIL_COND_IGNORED )
Сообщение: SQL thread is not to be started so UNTIL options are ignored
Ошибка: 1280 SQLSTATE: 42000 ( ER_WRONG_NAME_FOR_INDEX )
Сообщение: Incorrect index name ‘%s’
Ошибка: 1281 SQLSTATE: 42000 ( ER_WRONG_NAME_FOR_CATALOG )
Сообщение: Incorrect catalog name ‘%s’
Ошибка: 1282 SQLSTATE: HY000 ( ER_WARN_QC_RESIZE )
Сообщение: Кеш запросов не может установить размер %lu, новый размер кеша зпросов — %lu
Ошибка: 1283 SQLSTATE: HY000 ( ER_BAD_FT_COLUMN )
Сообщение: Column ‘%s’ cannot be part of FULLTEXT index
Ошибка: 1284 SQLSTATE: HY000 ( ER_UNKNOWN_KEY_CACHE )
Сообщение: Unknown key cache ‘%s’
Ошибка: 1285 SQLSTATE: HY000 ( ER_WARN_HOSTNAME_WONT_WORK )
Сообщение: MySQL is started in —skip-name-resolve mode. You need to restart it without this switch for this grant to work
Ошибка: 1286 SQLSTATE: 42000 ( ER_UNKNOWN_STORAGE_ENGINE )
Сообщение: Unknown table engine ‘%s’
Ошибка: 1287 SQLSTATE: HY000 ( ER_WARN_DEPRECATED_SYNTAX )
Сообщение: ‘%s’ is deprecated, use ‘%s’ instead
Ошибка: 1288 SQLSTATE: HY000 ( ER_NON_UPDATABLE_TABLE )
Сообщение: Таблица %s в %s не может изменятся
Ошибка: 1289 SQLSTATE: HY000 ( ER_FEATURE_DISABLED )
Сообщение: The ‘%s’ feature was disabled; you need MySQL built with ‘%s’ to have it working
Ошибка: 1290 SQLSTATE: HY000 ( ER_OPTION_PREVENTS_STATEMENT )
Сообщение: The MySQL server is running with the %s option so it cannot execute this statement
Ошибка: 1291 SQLSTATE: HY000 ( ER_DUPLICATED_VALUE_IN_TYPE )
Сообщение: Column ‘%s’ has duplicated value ‘%s’ in %s
Ошибка: 1292 SQLSTATE: HY000 ( ER_TRUNCATED_WRONG_VALUE )
Сообщение: Truncated wrong %s value: ‘%s’
Ошибка: 1293 SQLSTATE: HY000 ( ER_TOO_MUCH_AUTO_TIMESTAMP_COLS )
Сообщение: Incorrect table definition; there can be only one TIMESTAMP column with CURRENT_TIMESTAMP in DEFAULT or ON UPDATE clause
Ошибка: 1294 SQLSTATE: HY000 ( ER_INVALID_ON_UPDATE )
Сообщение: Invalid ON UPDATE clause for ‘%s’ column
Ошибка: 1295 SQLSTATE: HY000 ( ER_UNSUPPORTED_PS )
Сообщение: This command is not supported in the prepared statement protocol yet
Ошибка: 1296 SQLSTATE: HY000 ( ER_GET_ERRMSG )
Сообщение: Got error %d ‘%s’ from %s
Ошибка: 1297 SQLSTATE: HY000 ( ER_GET_TEMPORARY_ERRMSG )
Сообщение: Got temporary error %d ‘%s’ from %s
Ошибка: 1298 SQLSTATE: HY000 ( ER_UNKNOWN_TIME_ZONE )
Сообщение: Unknown or incorrect time zone: ‘%s’
Ошибка: 1299 SQLSTATE: HY000 ( ER_WARN_INVALID_TIMESTAMP )
Сообщение: Invalid TIMESTAMP value in column ‘%s’ at row %ld
Ошибка: 1300 SQLSTATE: HY000 ( ER_INVALID_CHARACTER_STRING )
Сообщение: Invalid %s character string: ‘%s’
Ошибка: 1301 SQLSTATE: HY000 ( ER_WARN_ALLOWED_PACKET_OVERFLOWED )
Сообщение: Result of %s() was larger than max_allowed_packet (%ld) — truncated
Ошибка: 1302 SQLSTATE: HY000 ( ER_CONFLICTING_DECLARATIONS )
Сообщение: Conflicting declarations: ‘%s%s’ and ‘%s%s’
Client error information comes from the following files:
The Error values and the symbols in parentheses correspond to definitions in the include/errmsg.h MySQL source file.
The Message values correspond to the error messages that are listed in the libmysql/errmsg.c file. %d and %s represent numbers and strings, respectively, that are substituted into the messages when they are displayed.
Because updates are frequent, it is possible that these files contain additional error information not listed here.
Ошибка: 2000 ( CR_UNKNOWN_ERROR )
Сообщение: Unknown MySQL error
Ошибка: 2001 ( CR_SOCKET_CREATE_ERROR )
Сообщение: Can’t create UNIX socket (%d)
Ошибка: 2002 ( CR_CONNECTION_ERROR )
Сообщение: Can’t connect to local MySQL server through socket ‘%s’ (%d)
Ошибка: 2003 ( CR_CONN_HOST_ERROR )
Сообщение: Can’t connect to MySQL server on ‘%s’ (%d)
Ошибка: 2004 ( CR_IPSOCK_ERROR )
Сообщение: Can’t create TCP/IP socket (%d)
Ошибка: 2005 ( CR_UNKNOWN_HOST )
Сообщение: Unknown MySQL server host ‘%s’ (%d)
Ошибка: 2006 ( CR_SERVER_GONE_ERROR )
Сообщение: MySQL server has gone away
Ошибка: 2007 ( CR_VERSION_ERROR )
Сообщение: Protocol mismatch; server version = %d, client version = %d
Ошибка: 2008 ( CR_OUT_OF_MEMORY )
Сообщение: MySQL client ran out of memory
Ошибка: 2009 ( CR_WRONG_HOST_INFO )
Сообщение: Wrong host info
Ошибка: 2010 ( CR_LOCALHOST_CONNECTION )
Сообщение: Localhost via UNIX socket
Ошибка: 2011 ( CR_TCP_CONNECTION )
Сообщение: %s via TCP/IP
Ошибка: 2012 ( CR_SERVER_HANDSHAKE_ERR )
Сообщение: Error in server handshake
Ошибка: 2013 ( CR_SERVER_LOST )
Сообщение: Lost connection to MySQL server during query
Ошибка: 2014 ( CR_COMMANDS_OUT_OF_SYNC )
Сообщение: Commands out of sync; you can’t run this command now
Ошибка: 2015 ( CR_NAMEDPIPE_CONNECTION )
Сообщение: Named pipe: %s
Ошибка: 2016 ( CR_NAMEDPIPEWAIT_ERROR )
Сообщение: Can’t wait for named pipe to host: %s pipe: %s (%lu)
Ошибка: 2017 ( CR_NAMEDPIPEOPEN_ERROR )
Сообщение: Can’t open named pipe to host: %s pipe: %s (%lu)
Ошибка: 2018 ( CR_NAMEDPIPESETSTATE_ERROR )
Сообщение: Can’t set state of named pipe to host: %s pipe: %s (%lu)
Ошибка: 2019 ( CR_CANT_READ_CHARSET )
Сообщение: Can’t initialize character set %s (path: %s)
Ошибка: 2020 ( CR_NET_PACKET_TOO_LARGE )
Сообщение: Got packet bigger than ‘max_allowed_packet’ bytes
Ошибка: 2021 ( CR_EMBEDDED_CONNECTION )
Сообщение: Embedded server
Ошибка: 2022 ( CR_PROBE_SLAVE_STATUS )
Сообщение: Error on SHOW SLAVE STATUS:
Ошибка: 2023 ( CR_PROBE_SLAVE_HOSTS )
Сообщение: Error on SHOW SLAVE HOSTS:
Ошибка: 2024 ( CR_PROBE_SLAVE_CONNECT )
Сообщение: Error connecting to slave:
Ошибка: 2025 ( CR_PROBE_MASTER_CONNECT )
Сообщение: Error connecting to master:
Ошибка: 2026 ( CR_SSL_CONNECTION_ERROR )
Сообщение: SSL connection error
Ошибка: 2027 ( CR_MALFORMED_PACKET )
Сообщение: Malformed packet
Ошибка: 2028 ( CR_WRONG_LICENSE )
Сообщение: This client library is licensed only for use with MySQL servers having ‘%s’ license
Ошибка: 2029 ( CR_NULL_POINTER )
Сообщение: Invalid use of null pointer
Ошибка: 2030 ( CR_NO_PREPARE_STMT )
Сообщение: Statement not prepared
Ошибка: 2031 ( CR_PARAMS_NOT_BOUND )
Сообщение: No data supplied for parameters in prepared statement
Ошибка: 2032 ( CR_DATA_TRUNCATED )
Сообщение: Data truncated
Ошибка: 2033 ( CR_NO_PARAMETERS_EXISTS )
Сообщение: No parameters exist in the statement
Ошибка: 2034 ( CR_INVALID_PARAMETER_NO )
Сообщение: Invalid parameter number
Ошибка: 2035 ( CR_INVALID_BUFFER_USE )
Сообщение: Can’t send long data for non-string/non-binary data types (parameter: %d)
Ошибка: 2036 ( CR_UNSUPPORTED_PARAM_TYPE )
Сообщение: Using unsupported buffer type: %d (parameter: %d)
Ошибка: 2037 ( CR_SHARED_MEMORY_CONNECTION )
Сообщение: Shared memory: %s
Ошибка: 2038 ( CR_SHARED_MEMORY_CONNECT_REQUEST_ERROR )
Сообщение: Can’t open shared memory; client could not create request event (%lu)
Ошибка: 2039 ( CR_SHARED_MEMORY_CONNECT_ANSWER_ERROR )
Сообщение: Can’t open shared memory; no answer event received from server (%lu)
Ошибка: 2040 ( CR_SHARED_MEMORY_CONNECT_FILE_MAP_ERROR )
Сообщение: Can’t open shared memory; server could not allocate file mapping (%lu)
Ошибка: 2041 ( CR_SHARED_MEMORY_CONNECT_MAP_ERROR )
Сообщение: Can’t open shared memory; server could not get pointer to file mapping (%lu)
Ошибка: 2042 ( CR_SHARED_MEMORY_FILE_MAP_ERROR )
Сообщение: Can’t open shared memory; client could not allocate file mapping (%lu)
Ошибка: 2043 ( CR_SHARED_MEMORY_MAP_ERROR )
Сообщение: Can’t open shared memory; client could not get pointer to file mapping (%lu)
Ошибка: 2044 ( CR_SHARED_MEMORY_EVENT_ERROR )
Сообщение: Can’t open shared memory; client could not create %s event (%lu)
Ошибка: 2045 ( CR_SHARED_MEMORY_CONNECT_ABANDONED_ERROR )
Сообщение: Can’t open shared memory; no answer from server (%lu)
Ошибка: 2046 ( CR_SHARED_MEMORY_CONNECT_SET_ERROR )
Сообщение: Can’t open shared memory; cannot send request event to server (%lu)
Ошибка: 2047 ( CR_CONN_UNKNOW_PROTOCOL )
Сообщение: Wrong or unknown protocol
Ошибка: 2048 ( CR_INVALID_CONN_HANDLE )
Сообщение: Invalid connection handle
Ошибка: 2049 ( CR_SECURE_AUTH )
Сообщение: Connection using old (pre-4.1.1) authentication protocol refused (client option ‘secure_auth’ enabled)
Ошибка: 2050 ( CR_FETCH_CANCELED )
Сообщение: Row retrieval was canceled by mysql_stmt_close() call
Ошибка: 2051 ( CR_NO_DATA )
Сообщение: Attempt to read column without prior row fetch
Ошибка: 2052 ( CR_NO_STMT_METADATA )
Сообщение: Prepared statement contains no metadata
Источник
27 июля 2009 г.
MySQL
Не возможно использовать для обновления таблицу, в которой производишь выборку
Понадобилось ежесуточно высчитывать размер шрифта для оформления вывода жанров на Кинсбурге. И столкнулся с проблемой, что нельзя выбирать данные из таблицы, которая участвует в обновлении данных.
Вот примеры запросов
Пробуем в лоб:
update `categories` set `size` = (`count` / ((max(`count`) - min(`count`)) / 10)); ERROR 1111 (HY000): Invalid use of group function
Попробуем вложенный селект:
update `categories` set `size` = (select (`count` / ((max(`count`) - min(`count`)) / 10)) from `categories`); ERROR 1093 (HY000): You can't specify target table 'categories' for update in FROM clause
Попробуем жоин:
update `categories` as `c1` JOIN `categories` as `c2` using(`category_id`) set `c1`.`size` = (`c2`.`count` / ((max(`c2`.`count`) - min(`c2`.`count`)) / 10)); ERROR 1111 (HY000): Invalid use of group function
По отдельности все работает
Выводим «размер шрифта»:
select (`count` / ((max(`count`) - min(`count`)) / 10)) from `categories`; +--------------------------------------------------------+ | (`count` / ((max(`count`) - min(`count`)) / 10)) | +--------------------------------------------------------+ | 3.47826087 | +--------------------------------------------------------+ 1 row in set (0.00 sec)
Обновляем поле с размером шрифта:
update `categories` set `size` = 3.47826087; Query OK, 0 rows affected (0.00 sec) Rows matched: 21 Changed: 0 Warnings: 0
Решение
Погуглив, и поломав голову с disc’ом, я пришел к следующему решению, представленное ниже.
Я решил выделить вычисление процента в переменную @percent, далее создал вьюху для таблицы «categories» и жойню таблицу с вьюхой:
-- создаем коэффициент деления set @percent = (select (max(`count`) - min(`count`)) / 10 from `categories`); -- создаем вьюху create view `categories_view` as select `category_id`, `count` from `categories`; -- жойним таблицу и вьюху, обновляя данные update `categories` as `c` join `categories_view` as `cv` using(`category_id`) set `c`.`size` = `cv`.`count` / @percent;
Вот и все, приятного манокурения
UPD: Создадим процедуру и евент для этого события
/* Создаем вьюху и процедуру для установки размеров шрифта */ use kinsburg; /* создаем вьюху */ CREATE VIEW `categories_view` AS SELECT `category_id`, `count` FROM `categories`; /* создаем процедуру */ delimiter // DROP PROCEDURE IF EXISTS `updateCategorySize`// CREATE PROCEDURE `updateCategorySize` () BEGIN /* создаем коэффициент деления */ SET @percent = (SELECT (max(`count`) - min(`count`)) / 10 FROM `categories`); /* жойним таблицу и вьюху, обновляя данные */ UPDATE `categories` AS `c` JOIN `categories_view` AS `cv` USING(`category_id`) SET `c`.`size` = `cv`.`count` / @percent; END// delimiter ; /* создаем евент для вызова процедуры раз в сутки */ CREATE DEFINER = kinsburg@localhost EVENT `updateCategorySizeEvent` ON SCHEDULE EVERY 1 DAY DO CALL updateCategorySize;
In this blog, we will solve one MySQL question and understand errors while solving the problem.
Problem :
Delete Duplicate Emails
Table: Person
+-------------+---------+
| Column Name | Type |
+-------------+---------+
| id | int |
| email | varchar |
+-------------+---------+
Enter fullscreen mode
Exit fullscreen mode
id is the primary key column for this table.
Each row of this table contains an email. The emails will not contain uppercase letters.
Write an SQL query to delete all the duplicate emails, keeping only one unique email with the smallest id.
Input:
Person table:
+----+------------------+
| id | email |
+----+------------------+
| 1 | john@example.com |
| 2 | bob@example.com |
| 3 | john@example.com |
+----+------------------+
Enter fullscreen mode
Exit fullscreen mode
Output:
+----+------------------+
| id | email |
+----+------------------+
| 1 | john@example.com |
| 2 | bob@example.com |
+----+------------------+
Enter fullscreen mode
Exit fullscreen mode
Explanation: john@example.com is repeated two times. We keep the row with the smallest Id = 1.
If We want No. of count which is having same email then we should use GROUP BY method.
The GROUP BY statement groups rows that have the same values into summary rows, like «find the number of id in each email».
The GROUP BY statement is often used with aggregate functions (COUNT(), MAX(), MIN(), SUM(), AVG()) to group the result-set by one or more columns.
Here we group each row that has the same email and find a count of the row with COUNT() function. email john@example.com occurs two times so we get a count as 2 and for bob@example.com we get a count as 1 because it occurs only one time.
Here email john@example.com has two ids 1 and 3. If We want to get minimum id from these two ids or minimum id from any no. of ids for particular email then we have to use MIN() function.
MySQL query should be like :
Here we get id 1 for email john@example.com because min(1,3) should be 1 and get 2 for bob@example.com because it has only one id that should be returned in MIN() function.
Now we have completed our major task in this problem. We want only id that is not in this min id because we want to keep the smallest id in our table and delete all ids that are greater than small id which has same email. so we first group row that has same email and then finds the smallest id from that to keep smallest id in table and delete all the row that has same email with id > small(id).
so the query will delete all id that is not equal to smallest id of particular email.
Oops…
We have got an Error.
ERROR #1093 : You can’t specify the target table table_name for an update in FROM clause
What you can do is change the query to something like this below.
Okay, let me explain how the magic happens here.
You can not delete the rows from the same data source to which your sub-query refers. This above-mentioned query is a working, but it’s ugly for several reasons, including performance. Here nested subquery makes a temporary table. So it doesn’t count as the same table you’re trying to delete data from.
This is because your update could be cyclical. what if updating that record causes something to happen which made the WHERE condition FALSE? You know that isn’t the case, but the engine doesn’t. There also could be opposing locks on the table in the operation.
Timeless DEV post…
Git Concepts I Wish I Knew Years Ago
The most used technology by developers is not Javascript.
It’s not Python or HTML.
It hardly even gets mentioned in interviews or listed as a pre-requisite for jobs.
I’m talking about Git and version control of course.
Read next
How to unchecked a radio button using JavaScript/jQuery?
Code And Deploy — Mar 23 ’22
How To Check Radio Button Based On Selected Value in Javascript/jQuery?
Code And Deploy — Mar 23 ’22
Coupon Code Generator in PHP and MySQL using Ajax and jQuery
Code And Deploy — Mar 23 ’22
Ajax Search Data in PHP & MySQL using jQuery
Code And Deploy — Mar 23 ’22
Once unpublished, all posts by ahana001 will become hidden and only accessible to themselves.
If ahana001 is not suspended, they can still re-publish their posts from their dashboard.
Note:
Once unpublished, this post will become invisible to the public and only accessible to Ankita.
They can still re-publish the post if they are not suspended.
Thanks for keeping DEV Community 👩💻👨💻 safe. Here is what you can do to flag ahana001:
Make all posts by ahana001 less visible
ahana001 consistently posts content that violates DEV Community 👩💻👨💻’s
code of conduct because it is harassing, offensive or spammy.