I’m adding this table:
CREATE TABLE contenttype (
contenttypeid INT UNSIGNED NOT NULL AUTO_INCREMENT,
class VARBINARY(50) NOT NULL,
packageid INT UNSIGNED NOT NULL,
canplace ENUM('0','1') NOT NULL DEFAULT '0',
cansearch ENUM('0','1') NOT NULL DEFAULT '0',
cantag ENUM('0','1') DEFAULT '0',
canattach ENUM('0','1') DEFAULT '0',
isaggregator ENUM('0', '1') NOT NULL DEFAULT '0',
PRIMARY KEY (contenttypeid),
UNIQUE KEY packageclass (packageid, class)
);
And I get a 1050 «table already exists»
But the table does NOT exist. Any ideas?
EDIT: more details because everyone seems to not believe me
DESCRIBE contenttype
yields:
1146 — Table ‘gunzfact_vbforumdb.contenttype’ doesn’t exist
and
CREATE TABLE gunzfact_vbforumdb.contenttype(
contenttypeid INT UNSIGNED NOT NULL AUTO_INCREMENT ,
class VARBINARY( 50 ) NOT NULL ,
packageid INT UNSIGNED NOT NULL ,
canplace ENUM( '0', '1' ) NOT NULL DEFAULT '0',
cansearch ENUM( '0', '1' ) NOT NULL DEFAULT '0',
cantag ENUM( '0', '1' ) DEFAULT '0',
canattach ENUM( '0', '1' ) DEFAULT '0',
isaggregator ENUM( '0', '1' ) NOT NULL DEFAULT '0',
PRIMARY KEY ( contenttypeid ) ,
Yields:
1050 — Table ‘contenttype’ already exists
Содержание
- Database.Guide
- Beginners
- Categories
- Fix ERROR 1050 (42S01) “Table … already exists” in MySQL
- Example of Error
- Solution 1
- Solution 2
- The Table REALLY Doesn’t Exist?
- Mysql 1050 Ошибка «Таблица уже существует», хотя на самом деле это не так
- 24 ответа
- Ошибка Mysql 1050 «Таблица уже существует», когда на самом деле она не
Database.Guide
Beginners
Categories
- Azure SQL Edge (16)
- Database Concepts (48)
- Database Tools (70)
- DBMS (8)
- MariaDB (420)
- Microsoft Access (17)
- MongoDB (265)
- MySQL (375)
- NoSQL (7)
- Oracle (296)
- PostgreSQL (255)
- Redis (184)
- SQL (588)
- SQL Server (887)
- SQLite (235)
Fix ERROR 1050 (42S01) “Table … already exists” in MySQL
If you’re getting an error that reads something like “ERROR 1050 (42S01): Table ‘customers’ already exists” when trying to create a table in MySQL, it’s probably because there’s already a table in the database with the same name.
To fix this issue, either change the name of the table you’re trying to create, or check the existing table to see if it’s the one you actually need.
Example of Error
Here’s an example of code that produces the error:
In this case, I’m trying to create a table called Customers , but it already exists in the database.
Solution 1
The most obvious solution is to change the name of the table we’re creating:
Here, I simply renamed the table to Customers2 . In practice, we would probably give it a more appropriate name.
We should also be mindful that if there’s already a table with the same name as the one we’re trying to create, there’s a possibility that our desired table has already been created. In this case we wouldn’t need to recreate it (unless we had good reason). We could either just go ahead and use it, or we could alter it to suit our new requirements.
Solution 2
Another way to deal with this error is to suppress it. We can modify our CREATE TABLE statement to only create the table if it doesn’t already exist:
In this case, we got a warning. Let’s check the warning:
The warning explicitly tells us that the table already exists.
The Table REALLY Doesn’t Exist?
If you believe that the table really doesn’t exist, perhaps there’s something else going on. See this article on Stack Overflow for a discussion on possible solutions.
Источник
Mysql 1050 Ошибка «Таблица уже существует», хотя на самом деле это не так
Я добавляю эту таблицу:
И я получаю таблицу 1050 «уже существует»
Но таблица НЕ существует. Любые идеи?
EDIT: подробности, потому что все, кажется, не верят мне:)
1146 — Таблица ‘gunzfact_vbforumdb.contenttype’ не существует
1050 — Табл. ‘contenttype’ уже существует
24 ответа
Серьезно, теперь у вас, вероятно, есть разбитая таблица. Попробуйте:
- DROP TABLE IF EXISTS contenttype
- REPAIR TABLE contenttype
- Если у вас есть достаточные разрешения, удалите файлы данных (в/mysql/data/db_name)
из журнала MySQL:
Я получил ту же ошибку, и REPAIR TABLE (из ответа @NullUserException) не помогло.
В итоге я нашел это решение:
Для меня, без sudo , я получил следующую ошибку:
(Работает на OS X 10.6)
Вам может понадобиться очистить кеш таблицы. Например:
Встречая ту же проблему (создайте таблицу InnoDB), это то, что окончательно сработало для меня:
Я проверил файлы, разрешения, попытался выполнить REPAIR и FLUSH, но ничего не получилось.
Итак, если это вариант, переместите все рабочие таблицы в другую базу данных, отбросьте старую (вам может потребоваться вручную удалить любые файлы из папки базы данных до того, как она начнет работать), переименуйте новую, должен «вернуться на ваш путь». По-видимому, все, что «кэшируется» с помощью InnoDB, отбрасывается вместе с исходной базой данных.
Я борюсь с этим весь день: у меня есть Perl script, который строит набор таблиц, сначала делая DROP IF EXISTS . на них, а затем CREATE их. DROP преуспел, но на CREATE я получил это сообщение об ошибке: table already exists
Наконец-то я понял: новая версия MySQL, которую я использую, имеет двигатель InnoDB по умолчанию ( «show engineG;» ). Я изменил его в файле my.cnf по умолчанию на MyISAM, повторно запустил MySQL, и теперь я больше не получаю ошибку «таблица уже существует».
Аналогичная проблема возникла при создании представления. Представление было раньше, но из-за некоторых изменений, которые он удалил. Но когда я попытался добавить его снова, он показывал мне сообщение об ошибке «вид уже существует».
Решение:
Вы можете сделать одно дело вручную.
- Перейдите в папку MySQL, в которой вы ее установили.
- Перейдите в папку данных внутри нее.
- Выберите свою базу данных и зайдите в нее.
- База данных создает файлы формата .frm.
- удалить конкретный файл таблицы.
- Теперь создайте таблицу еще раз.
Он успешно создаст таблицу.
Я также столкнулся с этой проблемой, когда пытаюсь создать таблицу, в которой говорилось, что она уже существует, и сбросив таблицу, сказал, что ее не существует.
Я сделал «FLUSH TABLES», и он очистил проблему.
У меня была эта проблема на Win7 в Sql Maestro для MySql 12.3. Огромное раздражение, шоу-стоп на самом деле. Ничто не помогло, даже не отбросило и не воссоздало базу данных. У меня есть такая же настройка на XP, и она работает там, поэтому, прочитав ваши ответы о разрешениях, я понял, что это должны быть разрешения Win7. Поэтому я запускал MySql как администратор, и хотя Sql Maestro запускался нормально, ошибка исчезла. Таким образом, это может быть проблема с разрешениями между Win7 и MySql.
Я борюсь с той же проблемой. Я не могу создать таблицу, даже если она не существует. Я пробовал все вышеперечисленные решения без успеха.
Моим решением было удалить файлы ib_logfil0 , ib_logfile1 , ibdata1 и auto.cnf из папки данных MySQL; перед удалением этих файлов обязательно запустите службу MySQL.
Затем после перезапуска службы MySQL воссоздал эти файлы, и я смог запустить резервную копию script, все мои файлы CREATE были сохранены (файл sqldump).
У меня был такой же случай. Проблема заключалась в разрешении родительского каталога.
В ходе тестирования я копировал файлы из mysql и из него.
Извините, что воскрес.
У меня была такая же проблема в Mac OS X и MySQL 5.1.40. Я использовал eclipse для редактирования моего SQL script, и я попробовал MySQLWorkbench 5.2.28. Вероятно, он преобразует символы новой строки в формат Mac. Я понятия не имел, что случилось с моим script, пока я не прокомментировал первую строку в файле. После этого этот script был интерпретирован mysql как один комментарий. Для этого я использовал встроенное приложение TextEdit Mac. После того, как разрывы строк были преобразованы в правильный формат, ошибка 1050 исчезла.
Обновление для пользователей Eclipse:
Чтобы настроить окончание по умолчанию для новых файлов, созданных по всей рабочей области:
Окно → Настройки → Общие → Рабочая область → Новая строка текстового файла разделитель.
Чтобы преобразовать существующие файлы, откройте файл для редактирования и для текущего файла, перейдите в меню:
Файл → Преобразование разделителей строк в
Сначала проверьте, находитесь ли вы в правильной базе данных USE yourDB и попробуйте Select * from contenttype просто посмотреть, что это такое, и если оно действительно существует.
В моем случае проблема заключалась в том, что было представление с тем же именем, что и моя таблица, поэтому мне пришлось отбросить представление, чтобы продолжить импорт.
Автоматизированное решение, которое сработало для меня, — это заменить стандартную таблицу drop на этот sed во время дампа, чтобы также удалить любые существующие представления:
Или, если вы предпочитаете печатать в файл для резервного копирования
Или, если вы получили сбрасываемый файл и импортируете его в свой db
Вы получаете идею
Примечание: важно добавить ^ в начало замещающего регулярного выражения, потому что в дампах, которые вы не хотите касаться, есть другие типы команд DROP TABLE IF EXISTS .
У вас есть что-то вроде этого:
Чтобы иметь что-то вроде этого:
У меня возникли огромные проблемы с ошибкой 1050 и 150.
Проблема заключалась в том, что я пытался добавить ограничение с ON DELETE SET NULL в качестве одного из условий.
Переход на ON DELETE NO ACTION позволил мне добавить необходимые ограничения FK.
К сожалению, сообщения об ошибках MySql совершенно бесполезны, поэтому я должен был найти это решение итеративно и с помощью ответов на вопрос выше.
пытался импортировать резервный sql файл, но получал ошибку; 1050 «Таблица уже существует»
Моя настройка была:
- Изменен движок сервера от InnoDB до MyISAM
- Использование phpMyAdmin Удаленная база данных, которую я пытался импортировать в
- Перезапуск службы mysql
- Пробовал повторный импорт и работал
gosh, у меня была та же проблема с osCommerce install script, пока я не выяснил, что система mysql имеет много баз данных, а запрос create table сам копирует в каждый из них и, таким образом, отбрасывает только рабочую таблицу на активном db didnt help, мне пришлось отказаться от таблицы из всех dbs
Для меня проблема возникла при использовании копии файловой системы базы данных mysql вместо mysqldump. У меня есть очень большие таблицы, в основном MyISAM и несколько таблиц кэша InnoDB, и это не является практичным для mysqldump данных. Поскольку мы все еще запускаем MyISAM, XtraBackup не является вариантом.
Те же симптомы, что и выше, произошли со мной. Таблицы там нет, в каталоге нет файлов, относящихся к таблице, но это невозможно создать, потому что MySQL думает о ней. Капля таблицы говорит, что нет, создание таблицы говорит, что это так.
Проблема возникла на двух машинах, оба были исправлены путем копирования резервных копий. Тем не менее, я заметил, что в моей резервной копии был файл .MYD и .MYI, хотя у меня создалось впечатление, что эти файлы не используются для InnoDB. У файлов .MYD и .MYI был владелец root, а .frm принадлежал mysql.
Если вы копируете из резервной копии, проверьте права доступа к файлу. Таблицы Flush могут работать, но я решил закрыть и перезапустить базу данных.
Мой оператор CREATE был частью промежуточного сценария env.
Я попробовал все, что было упомянуто выше. Я НЕ получил решение. Однако мой путь к искуплению:
Я натыкаюсь на то, что (один из многих в) оператор CREATE прошел, когда я исправил чувствительность к регистру базы данных. Это что-то нажало. Я повторил то же самое для других таблиц.
Однако на сцену появилась новая ошибка. Прямые цитаты для «комментариев» бросали синтаксическую ошибку. Я был потрясен. заменили их, но появилась новая ошибка. Наконец я знал решение.
РЕШЕНИЕ: Дамп, который я использовал, возможно, был из другой версии MySql. Я получил разрешение на подключение к промежуточной MYsql с помощью локальной (установленной на моей машине) рабочей среды mysql. Я не rdp на промежуточном сервере для входа в очередь для работы с mysql workbench. Создал дамп оттуда. Отказался от дампа, и он работал как сладкий.
Источник
Ошибка Mysql 1050 «Таблица уже существует», когда на самом деле она не
Я добавляю эту таблицу:
И я получаю таблицу 1050 “уже существует”
Но таблица НЕ существует. Любые идеи?
EDIT: подробности, потому что все, кажется, не верят мне:)
1146 – Таблица ‘gunzfact_vbforumdb.contenttype’ не существует
1050 – Табл. ‘contenttype’ уже существует
Серьезно, теперь у вас, вероятно, есть разбитая таблица. Попробуйте:
- DROP TABLE IF EXISTS contenttype
- REPAIR TABLE contenttype
- Если у вас есть достаточные разрешения, удалите файлы данных (в/mysql/data/db_name)
из журнала MySQL:
Я получил ту же ошибку, и REPAIR TABLE (из ответа @NullUserException) не помогло.
В итоге я нашел это решение:
Для меня, без sudo , я получил следующую ошибку:
(Работает на OS X 10.6)
Вам может понадобиться очистить кеш таблицы. Например:
Я борюсь с этим весь день: у меня есть Perl script, который строит набор таблиц, сначала делая DROP IF EXISTS . на них, а затем CREATE их. DROP преуспел, но на CREATE я получил это сообщение об ошибке: table already exists
Наконец-то я понял: новая версия MySQL, которую я использую, имеет двигатель InnoDB по умолчанию ( “show engineG;” ). Я изменил его в файле my.cnf по умолчанию на MyISAM, повторно запустил MySQL, и теперь я больше не получаю ошибку “таблица уже существует”.
Встречая ту же проблему (создайте таблицу InnoDB), это то, что окончательно сработало для меня:
Я проверил файлы, разрешения, попытался выполнить REPAIR и FLUSH, но ничего не получилось.
Итак, если это вариант, переместите все рабочие таблицы в другую базу данных, отбросьте старую (вам может потребоваться вручную удалить любые файлы из папки базы данных до того, как она начнет работать), переименуйте новую, должен “вернуться на ваш путь”. По-видимому, все, что “кэшируется” с помощью InnoDB, отбрасывается вместе с исходной базой данных.
У меня была эта проблема на Win7 в Sql Maestro для MySql 12.3. Огромное раздражение, шоу-стоп на самом деле. Ничто не помогло, даже не отбросило и не воссоздало базу данных. У меня есть такая же настройка на XP, и она работает там, поэтому, прочитав ваши ответы о разрешениях, я понял, что это должны быть разрешения Win7. Поэтому я запускал MySql как администратор, и хотя Sql Maestro запускался нормально, ошибка исчезла. Таким образом, это может быть проблема с разрешениями между Win7 и MySql.
Я также столкнулся с этой проблемой, когда пытаюсь создать таблицу, в которой говорилось, что она уже существует, и сбросив таблицу, сказал, что ее не существует.
Я сделал “FLUSH TABLES”, и он очистил проблему.
Аналогичная проблема возникла при создании представления.
Представление было раньше, но из-за некоторых изменений, которые он удалил. Но когда я попытался добавить его снова, он показывал мне сообщение об ошибке “вид уже существует”.
Решение:
Вы можете сделать одно дело вручную.
- Перейдите в папку MySQL, в которой вы ее установили.
- Перейдите в папку данных внутри нее.
- Выберите свою базу данных и зайдите в нее.
- База данных создает файлы формата .frm.
- удалить конкретный файл таблицы.
- Теперь создайте таблицу еще раз.
Он успешно создаст таблицу.
Сначала проверьте, находитесь ли вы в правильной базе данных USE yourDB и попробуйте Select * from contenttype просто посмотреть, что это такое, и если оно действительно существует…
У меня была такая же проблема в Mac OS X и MySQL 5.1.40. Я использовал eclipse для редактирования моего SQL script, и я попробовал MySQLWorkbench 5.2.28. Вероятно, он преобразует символы новой строки в формат Mac. Я понятия не имел, что случилось с моим script, пока я не прокомментировал первую строку в файле. После этого этот script был интерпретирован mysql как один комментарий. Для этого я использовал встроенное приложение TextEdit Mac. После того, как разрывы строк были преобразованы в правильный формат, ошибка 1050 исчезла.
Обновление для пользователей Eclipse:
Чтобы настроить окончание по умолчанию для новых файлов, созданных по всей рабочей области:
Окно → Настройки → Общие → Рабочая область → Новая строка текстового файла разделитель.
Чтобы преобразовать существующие файлы, откройте файл для редактирования и для текущего файла, перейдите в меню:
Файл → Преобразование разделителей строк в
У меня был такой же случай. Проблема заключалась в разрешении родительского каталога.
В ходе тестирования я копировал файлы из mysql и из него.
Извините, что воскрес.
Я борюсь с той же проблемой. Я не могу создать таблицу, даже если она не существует. Я пробовал все вышеперечисленные решения без успеха.
Моим решением было удалить файлы ib_logfil0 , ib_logfile1 , ibdata1 и auto.cnf из папки данных MySQL; перед удалением этих файлов обязательно запустите службу MySQL.
Затем после перезапуска службы MySQL воссоздал эти файлы, и я смог запустить резервную копию script, все мои файлы CREATE были сохранены (файл sqldump).
У меня была такая же проблема, и похоже, что имя базы данных было чувствительным к регистру. Моя база данных называется:
Хотя мой script включен
Как только я изменил имя базы данных на правильный случай, все это работало. Использование инструментария MYSQL для MAC OSX
Эта проблема также возникает, если в базе данных существует “представление” (мнимая таблица) как одно и то же имя, что и наше новое имя таблицы.
В моем случае я обнаружил, что это проблема с InnoDB; Я никогда не обнаружил, что представляет собой настоящая проблема, но создание в качестве MyISAM позволило ему построить
Вы не поверите мне! Я только что удалил блок комментариев из моего файла .sql, и теперь он работает.
Удаленный блок комментариев был таким:
Я оставил проблемную таблицу один в том же файле .sql. После этого я удалил комментарии, остался единственный код и ошибка исчезла.
Мой оператор CREATE был частью промежуточного сценария env.
Я попробовал все, что было упомянуто выше. Я НЕ получил решение. Однако мой путь к искуплению:
Я натыкаюсь на то, что (один из многих в) оператор CREATE прошел, когда я исправил чувствительность к регистру базы данных. Это что-то нажало. Я повторил то же самое для других таблиц.
Однако на сцену появилась новая ошибка. Прямые цитаты для “комментариев” бросали синтаксическую ошибку. Я был потрясен. заменили их, но появилась новая ошибка. Наконец я знал решение.
РЕШЕНИЕ: Дамп, который я использовал, возможно, был из другой версии MySql. Я получил разрешение на подключение к промежуточной MYsql с помощью локальной (установленной на моей машине) рабочей среды mysql. Я не rdp на промежуточном сервере для входа в очередь для работы с mysql workbench. Создал дамп оттуда. Отказался от дампа, и он работал как сладкий.
Для меня проблема возникла при использовании копии файловой системы базы данных mysql вместо mysqldump. У меня есть очень большие таблицы, в основном MyISAM и несколько таблиц кэша InnoDB, и это не является практичным для mysqldump данных. Поскольку мы все еще запускаем MyISAM, XtraBackup не является вариантом.
Те же симптомы, что и выше, произошли со мной. Таблицы там нет, в каталоге нет файлов, относящихся к таблице, но это невозможно создать, потому что MySQL думает о ней. Капля таблицы говорит, что нет, создание таблицы говорит, что это так.
Проблема возникла на двух машинах, оба были исправлены путем копирования резервных копий. Тем не менее, я заметил, что в моей резервной копии был файл .MYD и .MYI, хотя у меня создалось впечатление, что эти файлы не используются для InnoDB. У файлов .MYD и .MYI был владелец root, а .frm принадлежал mysql.
Если вы копируете из резервной копии, проверьте права доступа к файлу. Таблицы Flush могут работать, но я решил закрыть и перезапустить базу данных.
gosh, у меня была та же проблема с osCommerce install script, пока я не выяснил, что система mysql имеет много баз данных, а запрос create table сам копирует в каждый из них и, таким образом, отбрасывает только рабочую таблицу на активном db didnt help, мне пришлось отказаться от таблицы из всех dbs
пытался импортировать резервный sql файл, но получал ошибку; 1050 “Таблица уже существует”
Моя настройка была:
- Изменен движок сервера от InnoDB до MyISAM
- Использование phpMyAdmin Удаленная база данных, которую я пытался импортировать в
- Перезапуск службы mysql
- Пробовал повторный импорт и работал
У меня возникли огромные проблемы с ошибкой 1050 и 150.
Проблема заключалась в том, что я пытался добавить ограничение с ON DELETE SET NULL в качестве одного из условий.
Переход на ON DELETE NO ACTION позволил мне добавить необходимые ограничения FK.
К сожалению, сообщения об ошибках MySql совершенно бесполезны, поэтому я должен был найти это решение итеративно и с помощью ответов на вопрос выше.
В моем случае проблема заключалась в том, что было представление с тем же именем, что и моя таблица, поэтому мне пришлось отбросить представление, чтобы продолжить импорт.
Автоматизированное решение, которое сработало для меня, – это заменить стандартную таблицу drop на этот sed во время дампа, чтобы также удалить любые существующие представления:
Или, если вы предпочитаете печатать в файл для резервного копирования
Или, если вы получили сбрасываемый файл и импортируете его в свой db
Вы получаете идею
Примечание: важно добавить ^ в начало замещающего регулярного выражения, потому что в дампах, которые вы не хотите касаться, есть другие типы команд DROP TABLE IF EXISTS .
У вас есть что-то вроде этого:
Чтобы иметь что-то вроде этого:
Ваш диск также может быть заполнен. (просто было)
У меня была такая же ошибка, но я знал, что таблица уже существует, и хотел добавить к ней. Я добавляю свой ответ, так как этот вопрос для меня в Google выглядит как № 1 при поиске той же ошибки, но по немного другому сценарию. В основном мне нужно было поставить галочку
“Добавить оператор DROP TABLE/VIEW/PROCEDURE/FUNCTION/EVENT/TRIGGER”
Источник
If you’re getting an error that reads something like “ERROR 1050 (42S01): Table ‘customers’ already exists” when trying to create a table in MySQL, it’s probably because there’s already a table in the database with the same name.
To fix this issue, either change the name of the table you’re trying to create, or check the existing table to see if it’s the one you actually need.
Example of Error
Here’s an example of code that produces the error:
CREATE TABLE Customers (
CustomerId int NOT NULL PRIMARY KEY,
CustomerName varchar(60) NOT NULL
);
Result:
ERROR 1050 (42S01): Table 'customers' already exists
In this case, I’m trying to create a table called Customers
, but it already exists in the database.
Solution 1
The most obvious solution is to change the name of the table we’re creating:
CREATE TABLE Customers2 (
CustomerId int NOT NULL PRIMARY KEY,
CustomerName varchar(60) NOT NULL
);
Result:
Query OK, 0 rows affected (0.02 sec)
Here, I simply renamed the table to Customers2
. In practice, we would probably give it a more appropriate name.
We should also be mindful that if there’s already a table with the same name as the one we’re trying to create, there’s a possibility that our desired table has already been created. In this case we wouldn’t need to recreate it (unless we had good reason). We could either just go ahead and use it, or we could alter it to suit our new requirements.
Solution 2
Another way to deal with this error is to suppress it. We can modify our CREATE TABLE
statement to only create the table if it doesn’t already exist:
CREATE TABLE IF NOT EXISTS Customers (
CustomerId int NOT NULL PRIMARY KEY,
CustomerName varchar(60) NOT NULL
);
Result:
Query OK, 0 rows affected, 1 warning (0.00 sec)
In this case, we got a warning. Let’s check the warning:
SHOW WARNINGS;
Result:
+-------+------+----------------------------------+ | Level | Code | Message | +-------+------+----------------------------------+ | Note | 1050 | Table 'Customers' already exists | +-------+------+----------------------------------+ 1 row in set (0.00 sec)
The warning explicitly tells us that the table already exists.
The Table REALLY Doesn’t Exist?
If you believe that the table really doesn’t exist, perhaps there’s something else going on. See this article on Stack Overflow for a discussion on possible solutions.
When ALTER TABLE crashes MySQL server it leaves orphaned records in InnoDB dictionary. It is annoying because next time you run the same ALTER TABLE query it will fail with error:
Shell
ERROR 1050 (42S01) at line 1: Table ‘sakila/#sql-ib712’ already exists
1
ERROR 1050 (42S01) at line 1: Table ‘sakila/#sql-ib712’ already exists
The post explains why it happens and how to fix it.
When you run ALTER table InnoDB follows the plan:
Block the original table
Create an empty temporary table with the new structure. The name of the new table is something like #sql-ib712.
Copy all records from the original table to the temporary one
Swap the temporary and original tables
Unblock the original table
The temporary table is a normal InnoDB table except it’s not visible to a user. InnoDB creates a record in the dictionary for the temporary table as for any other table.
If MySQL crashes in the middle of the ALTER process the dictionary ends up with an orphaned table.
We wouldn’t care much if the temporary table name were random. But it’s not and when you run ALTER TABLE again, InnoDB picks up the same name for the temporary table. As long as a record for a table with the same name already exists in the dictionary the subsequent ALTER fails.
How to fix “ERROR 1050 (42S01) at line 1: Table ‘sakila/#sql-ib712’ already exists”
MySQL suggests quite cumbersome method. In short you need to fool MySQL with a fake .frm file so you can DROP the temporary table with an SQL query. It works fine, but the structure of the fake table in .frm file must match the structure in the dictionary. It’s not that easy to find out. Fortunately you don’t need to.
An idea is following.
Not only DROP TABLE removes a records from InnoDB dictionary, DROP DATABASE does it too.
In case of DROP TABLE you need to specify exact name of the table while in case of DROP DATABASE InnoDB will delete all tables for a given database.
To get a clean dictionary for a given database we need to do following:
Create empty temporary database. Let it be tmp1234
Move all tables from the original database to tmp1234
Drop the original database (it’s empty by now, all tables are in tmp1234)
Create the original database again
Move all tables from the temporary database to the original one.
Drop the empty temporary database.
Here’s a script that performs this task. It must be run by root and mysql command should connect to the server without asking the password. Stop all writes to the database before running the script.
#!/usr/bin/env bash
set -eu
for db in `mysql -NBe «SHOW DATABASES» | grep -wv -e mysql -e information_schema -e mysql -e performance_schema`; do
db_tmp=tmp$RANDOM
c=`mysql -NBe «select COUNT(*) from information_schema.tables WHERE TABLE_SCHEMA = ‘$db’ AND TABLE_TYPE <> ‘BASE TABLE'»`
if [ «$c» -ne 0 ]; then
echo «There are non-base tables (views etc) in $db»
continue
fi
mysql -e «CREATE DATABASE `$db_tmp`»
IFS=»
«
for t in `mysql -NBe «SELECT TABLE_NAME FROM information_schema.TABLES WHERE TABLE_SCHEMA = ‘$db’ AND TABLE_TYPE = ‘BASE TABLE'»`; do
echo «Moving $db.$t to $db_tmp.$t»
mysql -e «RENAME TABLE `$db`.`$t` TO `$db_tmp`.`$t`»
done
n=`mysql -e «SHOW TABLES» «$db»| wc -l`
if [ $n -ne 0 ]; then
echo «there are $n tables in $db , not gonna drop it!»
exit -1
fi
datadir=`mysql -NBe «SELECT @@datadir»`
rm -f «$datadir/$db/»*
mysql -e «DROP DATABASE `$db`»
mysql -e «CREATE DATABASE `$db`»
for t in `mysql -NBe «SELECT TABLE_NAME FROM information_schema.TABLES WHERE TABLE_SCHEMA = ‘$db_tmp’ AND TABLE_TYPE = ‘BASE TABLE'»`; do
echo «Moving $db_tmp.$t to $db.$t»
mysql -e «RENAME TABLE `$db_tmp`.`$t` TO `$db`.`$t`»
done
n=`mysql -e «SHOW TABLES» «$db_tmp»| wc -l`
if [ $n -ne 0 ]; then
echo «there are $n tables in $db_tmp , not gonna drop it!»
exit -1
fi
mysql -e «DROP DATABASE `$db_tmp`»
done
0 Пользователей и 1 Гость просматривают эту тему.
- 7 Ответов
- 21978 Просмотров
Здравствуйте. Извиняюсь заранее, если вопрос идиотский Вроде сделал сайт на Joomla, стал переносить хостинг и при импорте базы данных столкнулся с такой штукой:
Ошибка
SQL-запрос:
— phpMyAdmin SQL Dump
— version 2.6.1
— http://www.phpmyadmin.net
—
— Хост: localhost
— Время создания: Дек 16 2009 г., 11:09
— Версия сервера: 5.0.45
— Версия PHP: 5.2.4
—
— БД: `goman`
—
— ———————————————————
—
— Структура таблицы `jos_banner`
—
CREATE TABLE `jos_banner` (
`bid` int( 11 ) NOT NULL AUTO_INCREMENT ,
`cid` int( 11 ) NOT NULL default ‘0’,
`type` varchar( 30 ) NOT NULL default ‘banner’,
`name` varchar( 255 ) NOT NULL default »,
`alias` varchar( 255 ) NOT NULL default »,
`imptotal` int( 11 ) NOT NULL default ‘0’,
`impmade` int( 11 ) NOT NULL default ‘0’,
`clicks` int( 11 ) NOT NULL default ‘0’,
`imageurl` varchar( 100 ) NOT NULL default »,
`clickurl` varchar( 200 ) NOT NULL default »,
`date` datetime default NULL ,
`showBanner` tinyint( 1 ) NOT NULL default ‘0’,
`checked_out` tinyint( 1 ) NOT NULL default ‘0’,
`checked_out_time` datetime NOT NULL default ‘0000-00-00 00:00:00’,
`editor` varchar( 50 ) default NULL ,
`custombannercode` text,
`catid` int( 10 ) unsigned NOT NULL default ‘0’,
`description` text NOT NULL ,
`sticky` tinyint( 1 ) unsigned NOT NULL default ‘0’,
`ordering` int( 11 ) NOT NULL default ‘0’,
`publish_up` datetime NOT NULL default ‘0000-00-00 00:00:00’,
`publish_down` datetime NOT NULL default ‘0000-00-00 00:00:00’,
`tags` text NOT NULL ,
`params` text NOT NULL ,
PRIMARY KEY ( `bid` ),
KEY `viewbanner` ( `showBanner` ),
KEY `idx_banner_catid` ( `catid` )
) ENGINE = MYISAM DEFAULT CHARSET = utf8 AUTO_INCREMENT =1;
Ответ MySQL: Документация
#1050 — Table ‘jos_banner’ already exists
Не могли бы вы пояснить в чём тут дело?
Заранее огромное спасибо!
Так sql сама сказала ответ Ответ MySQL: Документация
#1050 — Table ‘jos_banner’ already exists
Что означает что таблица с таким названием уже есть в базе, удалите ее и все пойдет.
Спасибо. Я же говорил, что я …
« Последнее редактирование: 16.12.2009, 15:31:39 от Ksen »
Записан
Так sql сама сказала ответ Ответ MySQL: Документация
#1050 — Table ‘jos_banner’ already exists
Что означает что таблица с таким названием уже есть в базе, удалите ее и все пойдет.
СПАСИБО, ПОМОГЛО!
СПАСИБО, ПОМОГЛО!
Как решили проблему?
Что означает что таблица с таким названием уже есть в базе, удалите ее и все пойдет.
Хотя всегда предварительно делайте бекапы.
Хотя всегда предварительно делайте бекапы.
Где найти эту таблицу в OSPanel? В панели phpMyAdmin я удалил все лишние базы и все равно выдает ошибку. Если можно поподробнее.
Где найти эту таблицу в OSPanel? Если можно поподробнее.
примерный путь
OpenServerOSPaneluserdataMySQL-5.6-x64
конкретно зависит от:
1) в какую папку поставлен OSPanel
2) Какая версия MySQL у вас включена в настройках
MySQL-5.6-x64
MySQL-5.6
MySQL-5.4
по OSPanel есть подробный хелп на сайте разработчиков
Seriously now, you probably have a broken table. Try:
DROP TABLE IF EXISTS contenttype
REPAIR TABLE contenttype
- If you have sufficient permissions, delete the data files (in /mysql/data/db_name)
I got this same error, and REPAIR TABLE (from @NullUserException’s answer) didn’t help.
sudo mysqladmin flush-tables
For me, without the sudo
, I got the following error:
mysqladmin: refresh failed; error: 'Access denied; you need the RELOAD privilege for this operation'
(Running on OS X 10.6)
I’ve been fighting with this all day: I have a Perl script that builds a set of tables by first doing a DROP IF EXISTS ...
on them and then CREATE
ing them. The DROP
succeeded, but on CREATE
I got this error message: table already exists
I finally got to the bottom of it: The new version of MySQL that I’m using has a default engine of InnoDB («show engine G;») I changed it in the my.cnf file to default to MyISAM, re-started MySQL, and now I no longer get the «table already exists» error.
I had this problem on Win7 in Sql Maestro for MySql 12.3. Enormously irritating, a show stopper in fact. Nothing helped, not even dropping and recreating the database. I have this same setup on XP and it works there, so after reading your answers about permissions I realized that it must be Win7 permissions related. So I ran MySql as administrator and even though Sql Maestro was run normally, the error disappeared. So it must have been a permissions issue between Win7 and MySql.
Same problem occurred with me while creating a view. The view was present earlier then due to some changes it got removed But when I tried to add it again it was showing me «view already exists» error message.
Solution:
You can do one thing manually.
- Go to the MySQL folder where you have installed it
- Go to the data folder inside it.
- Choose your database and go inside it.
- Data base creates «.frm» format files.
- delete the particular table’s file.
- Now create the table again.
It will create the table successfully.
I had the same problem at Mac OS X and MySQL 5.1.40. I used eclipse to edit my SQL script and than I tried MySQLWorkbench 5.2.28. Probably it converted newline characters to Mac format. I had no idea about what’s wrong with my script until I commented out the first line in file. After this this script was interpreted by mysql as a one single comment. I used build-in TextEdit Mac application to fix this. After line-breaks was converted to the correct format, the error 1050 gone.
Update for Eclipse users:
To set up default ending for new files created, across the entire workspace:
Window -> Preferences -> General -> Workspace -> New text file line delimiter.
To convert existing files, open file for editing and for the currently edited file, go to the menu:
File -> Convert Line Delimiters To
I am struggling with the same issue. I cannot create a table, even though it does not exist. I tried all the above solutions with no success.
My solution was to delete the files ib_logfil0
, ib_logfile1
, ibdata1
, and auto.cnf
from the data folder of MySQL; make sure to stop the MySQL service first before deleting these files.
Then after restarting the service, MySQL recreated these files and I was able to run a backup script were all my CREATE
s were stored (a sqldump file).
This problem also occurs if a ‘view’ (imaginary table) exists in database as same name as our new table name.
You won´t believe me!! I´ve just remove a comment block from my .sql file and now it works!!!!!!!
CREATE DATABASE IF NOT EXISTS `issga` /*!40100 DEFAULT CHARACTER SET utf8 */;
USE `issga`;
--
-- Table structure for table `protocolo`
--
DROP TABLE IF EXISTS protocolo;
/*!40101 SET @saved_cs_client = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE protocolo (
`idProtocolo` int(11) NOT NULL AUTO_INCREMENT,
`tipo` varchar(30) DEFAULT NULL,
`estado` int(2) DEFAULT 0,
PRIMARY KEY (`idProtocolo`)
) ENGINE=InnoDB AUTO_INCREMENT=142 DEFAULT CHARSET=utf8;
/*!40101 SET character_set_client = @saved_cs_client */;
--
-- Dumping data for table `protocolo`
--
LOCK TABLES protocolo WRITE;
/*!40000 ALTER TABLE protocolo DISABLE KEYS */;
/* INSERT INTO `protocolo` VALUES () */
/*!40000 ALTER TABLE protocolo ENABLE KEYS */;
UNLOCK TABLES;
The deleted comment block was this:
--
-- Table structure for table `protocolo`
--
I´ve left the problematic table alone in the same .sql file. After that I´ve removed comments, only code was left, and the error dissapears.
gosh, i had the same problem with osCommerce
install script until i figured out the mysql system has many databases and the create table
query copies itself into each one and thus droping only the working table on active db didnt help, i had to drop the table from all dbs
Was trying to import a backup sql file but was getting the error; 1050 «Table already exists»
My setup was:
- Windows 7
- Mysql 5.5.16
Solution:
- Changed the server engine from InnoDB to MyISAM
- Using phpMyAdmin Deleted the database I was trying to import to
- Restarted the mysql service
- Tried the re-importation and it worked
In my case the problem was that there was a view with the same name as my table, so I had to drop the view to allow the import to continue.
drop view `my-view-that-has-same-name-as-table`;
An automated solution that worked for me is to replace the normal drop table with this sed during the dump to also drop any views that might exist:
mysqldump my-db
| sed -E 's/^DROP TABLE IF EXISTS(.+)$/ DROP VIEW IF EXISTS1/g'
| mysql my-other-db
Or if you would rather print to a file for backup
mysqldump my-db
| sed -E 's/^DROP TABLE IF EXISTS(.+)$/ DROP VIEW IF EXISTS1/g'
> my-db.dump.sql
Or if you received the dumped file and you are importing it to your db
cat my-db.dump.sql
| sed -E 's/^DROP TABLE IF EXISTS(.+)$/ DROP VIEW IF EXISTS1/g'
| mysql my-other-db
You get the idea
Note: it is important that you add the ^
at the beginning of the replacement regex, because there are other types of DROP TABLE IF EXISTS
commands in dumps that you don’t want to touch.
You go from having something like this:
--
-- Table structure for table `my_table`
--
DROP TABLE IF EXISTS `my_table`;
/*!40101 SET @saved_cs_client = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `my_table` (
...
To having something like this:
--
-- Table structure for table `my_table`
--
DROP TABLE IF EXISTS `my_table`; DROP VIEW IF EXISTS `my_table`;
/*!40101 SET @saved_cs_client = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `my_table` (
...
Я добавляю эту таблицу:
CREATE TABLE contenttype (
contenttypeid INT UNSIGNED NOT NULL AUTO_INCREMENT,
class VARBINARY(50) NOT NULL,
packageid INT UNSIGNED NOT NULL,
canplace ENUM('0','1') NOT NULL DEFAULT '0',
cansearch ENUM('0','1') NOT NULL DEFAULT '0',
cantag ENUM('0','1') DEFAULT '0',
canattach ENUM('0','1') DEFAULT '0',
isaggregator ENUM('0', '1') NOT NULL DEFAULT '0',
PRIMARY KEY (contenttypeid),
UNIQUE KEY packageclass (packageid, class)
);
И я получаю таблицу 1050 «уже существует»
Но таблица НЕ существует. Любые идеи?
EDIT: подробности, потому что все, кажется, не верят мне:)
DESCRIBE contenttype
дает:
1146 — Таблица ‘gunzfact_vbforumdb.contenttype’ не существует
и
CREATE TABLE gunzfact_vbforumdb.contenttype(
contenttypeid INT UNSIGNED NOT NULL AUTO_INCREMENT ,
class VARBINARY( 50 ) NOT NULL ,
packageid INT UNSIGNED NOT NULL ,
canplace ENUM( '0', '1' ) NOT NULL DEFAULT '0',
cansearch ENUM( '0', '1' ) NOT NULL DEFAULT '0',
cantag ENUM( '0', '1' ) DEFAULT '0',
canattach ENUM( '0', '1' ) DEFAULT '0',
isaggregator ENUM( '0', '1' ) NOT NULL DEFAULT '0',
PRIMARY KEY ( contenttypeid ) ,
Урожайность:
1050 — Табл. ‘contenttype’ уже существует
At the time of database startup, I accidentally deleted the data file, and then I kept working on this table and kept reporting errors. The query report did not exist, but a new table with the same name already existed. The solution is to create a table with the same name in another database and copy its data files.
mysql> show databases;
+ — — — — — — — — — — — — — — — — — — — — +
| Database |
+ — — — — — — — — — — — — — — — — — — — — +
| information_schema |
| mysql |
| performance_schema |
| test |
+——————–+
mysql> use test
mysql> create table t1(id int);
ERROR 1813 (HY000): Tablespace for table ‘`test`.`t1`’ exists. Please DISCARD the tablespace before IMPORT.
mysql> alter table t1 DISCARD tablespace;
ERROR 1146 (42S02): Table ‘test.t1’ doesn’t exist
mysql> create database gg;
mysql> show databases;
+ — — — — — — — — — — — — — — — — — — — — +
| Database |
+ — — — — — — — — — — — — — — — — — — — — +
| information_schema |
| gg |
| mysql |
| performance_schema |
| test
| + — — — — — — — — — — — — — — — — — — — — +
mysql> use gg
Database changed
mysql> create table t1(id int);
go to the database gg
cp-a t1.frm.. /test/t1.frm
mysql> select * from t1;
ERROR 1146 (42S02): Table ‘test.t1’ doesn’t exist
mysql> Alter TABLE T1, TABLESPACE;
Query OK, 0 rows affected, 2 warnings (0.01 SEC)
goes to database gg
cp -a t1.ibd .. /test/t1.ibd
mysql> use test
mysql> select * from t1;
ERROR 1814 (HY000): Tablespace has been discarded for table ‘t1’
mysql> Alter TABLE T1 Import TABLESpace;
Query OK, 0 rows affected, 1 warning (0.04 SEC)
mysql> select * from t1;
Empty set (0.00 SEC)