I’m getting a strange error in my access database.
The Error:
The table ‘[insert table name here]’ already exists. You created or
renamed a table and then tried to save it. before Microsoft access
could save the table, another user created or renamed one using the
same name.
This is happening when an RPA team runs an Access Macro that is just a list of queries to run in sequence.
The error comes up during an append query that takes records from one table and adds them to another table that is the core of a work environment.
This is only happening to the RPA team. When I run the same Macro from my workstation, it runs flawlessly. When 2 other people who are authorized run the Macro, it runs flawlessly. I can’t duplicate it. I also cannot find any reference to this error in this circumstance in the time I have spent on google or here. I’m stumped. I could just be typing in keyword searches wrong, but I don’t quite know where to go next with this.
Thanks in advance.
Edit: Here is the SQL for the offending Append query. It’s ugly, but it’s what I have to work with
INSERT INTO [New ZSPWAR Prime] (Payer, AI, Bill_doc,
Sqwak, Site, Plnt, Billing_Dt, ProfitCntr, Customer,
Equipment, Issued_Material, Material_Description, SLoc,
Serial_No, ItCC, Mtrl_Grp, Manuf_No, Manuf_Name, RTN,
Warranty, PPC, SVO_No, Ref_No, Notification_Subject,
AC_C, Corrective_Action, SB_Data, AC_R, Corr_Action_R,
SaleDebCre, Sales_Ord, SO_Date, SU, Returned_Material,
Returned_SNR, [Reason for Rejection], SLCo, Canel_Doc,
Can_Doc_Dt, Tail, ItCa, Sold_to, Sold_to_Name,
Customer_PO_No, [User], Comp_Date, OB_Del_NO, OB_Del_DT,
Ret_Delv, Rt_SO_It, Ret_Date, Ret_EQUI, Ret_Note,
NoteCR_DT, NoteCM_DT, Ret_Note_DESC, WACD,
Wty_Prog_Code_Desc, PO_NO, PO_DT, PO_PI, VR_Amount,
INV_PT_DT, ZZ07, Freight_Amt, [ME23N PO_Owner], VDCD,
Ven_Den_Code_Desc, DISP, [Disp code Descr], PRI, HVNE,
[Approve By], [MM Vendor Number], [Sourcing Vendor Number],
[Sourcing Vendor Name], [Vendor Contract], [FFF Class],
[Ref Contract], [Company Code], [BUSAC TYPE],
[Warr Typ], [Aircraft Material], [Aircraft Serial Number],
[Aircraft Program], [GL Date], [Obj Type], [ID Number],
[MD04 Purchasing Group], [MD04 PurG Name], [RO Number],
[RO Creation Date], [RO Contact Name], [RO Vendor Code],
[RO Vendor Name], [ODC Amount], [Issue_New/Rotable],
Issue_Core, [Recovery_New/Rotable], Recovery_Core,
Labor_Hours, Rate, Labor_Cost, Mtrl_Qty_Billed,
Mtrl_ea_Cost, Mtrl_ttl_Cost, Total_Cost, MAUC_STD,
Core_cost, Cat_Price, Discount, [% Discount],
[ODC Freight], [Repair Cost], [Material Burden],
[% Material Burden], [Rotable Depreciation], [% Core Dep],
[Net Spend], Margin, Item_Cost, [Total Material Burden],
[Total Rotables Dep], SVO_Direct_Labor, SVO_Labor_OH)
SELECT [New ZSPWAR Merge].Payer, [New ZSPWAR Merge].AI,
[New ZSPWAR Merge].Bill_doc, [New ZSPWAR Merge].Sqwak,
[New ZSPWAR Merge].Site, [New ZSPWAR Merge].Plnt,
[New ZSPWAR Merge].Billing_Dt, [New ZSPWAR Merge].ProfitCntr,
[New ZSPWAR Merge].Customer, [New ZSPWAR Merge].Equipment,
[New ZSPWAR Merge].Issued_Material, [New ZSPWAR Merge].Material_Description,
[New ZSPWAR Merge].SLoc, [New ZSPWAR Merge].Serial_No, [New ZSPWAR Merge].ItCC,
[New ZSPWAR Merge].Mtrl_Grp, [New ZSPWAR Merge].Manuf_No, [New ZSPWAR Merge].Manuf_Name,
[New ZSPWAR Merge].RTN, [New ZSPWAR Merge].Warranty, [New ZSPWAR Merge].PPC,
[New ZSPWAR Merge].SVO_No, [New ZSPWAR Merge].Ref_No, [New ZSPWAR Merge].Notification_Subject,
[New ZSPWAR Merge].AC_C, [New ZSPWAR Merge].Corrective_Action,
[New ZSPWAR Merge].SB_Data, [New ZSPWAR Merge].AC_R,
[New ZSPWAR Merge].Corr_Action_R, [New ZSPWAR Merge].SaleDebCre,
[New ZSPWAR Merge].Sales_Ord, [New ZSPWAR Merge].SO_Date,
[New ZSPWAR Merge].SU, [New ZSPWAR Merge].Returned_Material,
[New ZSPWAR Merge].Returned_SNR, [New ZSPWAR Merge].[Reason for Rejection],
[New ZSPWAR Merge].SLCo, [New ZSPWAR Merge].Canel_Doc,
[New ZSPWAR Merge].Can_Doc_Dt, [New ZSPWAR Merge].Tail,
[New ZSPWAR Merge].ItCa, [New ZSPWAR Merge].Sold_to,
[New ZSPWAR Merge].Sold_to_Name, [New ZSPWAR Merge].Customer_PO_No,
[New ZSPWAR Merge].User, [New ZSPWAR Merge].Comp_Date,
[New ZSPWAR Merge].OB_Del_NO, [New ZSPWAR Merge].OB_Del_DT,
[New ZSPWAR Merge].Ret_Delv, [New ZSPWAR Merge].Rt_SO_It,
[New ZSPWAR Merge].Ret_Date, [New ZSPWAR Merge].Ret_EQUI,
[New ZSPWAR Merge].Ret_Note, [New ZSPWAR Merge].NoteCR_DT,
[New ZSPWAR Merge].NoteCM_DT, [New ZSPWAR Merge].Ret_Note_DESC,
[New ZSPWAR Merge].WACD, [New ZSPWAR Merge].Wty_Prog_Code_Desc,
[New ZSPWAR Merge].PO_NO, [New ZSPWAR Merge].PO_DT,
[New ZSPWAR Merge].PO_PI, [New ZSPWAR Merge].VR_Amount,
[New ZSPWAR Merge].INV_PT_DT, [New ZSPWAR Merge].ZZ07,
[New ZSPWAR Merge].Freight_Amt, [New ZSPWAR Merge].[ME23N PO_Owner],
[New ZSPWAR Merge].VDCD, [New ZSPWAR Merge].Ven_Den_Code_Desc,
[New ZSPWAR Merge].DISP, [New ZSPWAR Merge].[Disp code Descr],
[New ZSPWAR Merge].PRI, [New ZSPWAR Merge].HVNE, [New ZSPWAR Merge].[Approve By],
[New ZSPWAR Merge].[MM Vendor Number], [New ZSPWAR Merge].[Sourcing Vendor Number],
[New ZSPWAR Merge].[Sourcing Vendor Name], [New ZSPWAR Merge].[Vendor Contract], [New ZSPWAR Merge].[FFF Class],
[New ZSPWAR Merge].[Ref Contract], [New ZSPWAR Merge].[Company Code],
[New ZSPWAR Merge].[BUSAC TYPE], [New ZSPWAR Merge].[Warr Typ],
[New ZSPWAR Merge].[Aircraft Material], [New ZSPWAR Merge].[Aircraft Serial Number],
[New ZSPWAR Merge].[Aircraft Program], [New ZSPWAR Merge].[GL Date],
[New ZSPWAR Merge].[Obj Type], [New ZSPWAR Merge].[ID Number],
[New ZSPWAR Merge].[MD04 Purchasing Group],
[New ZSPWAR Merge].[MD04 PurG Name], [New ZSPWAR Merge].[RO Number],
[New ZSPWAR Merge].[RO Creation Date], [New ZSPWAR Merge].[RO Contact Name], [New ZSPWAR Merge].[RO Vendor Code],
[New ZSPWAR Merge].[RO Vendor Name], [New ZSPWAR Merge].[ODC Amount],
[New ZSPWAR Merge].[Issue_New/Rotable], [New ZSPWAR Merge].Issue_Core,
[New ZSPWAR Merge].[Recovery_New/Rotable], [New ZSPWAR Merge].Recovery_Core,
[New ZSPWAR Merge].Labor_Hours, [New ZSPWAR Merge].Rate, [New ZSPWAR Merge].Labor_Cost,
[New ZSPWAR Merge].Mtrl_Qty_Billed, [New ZSPWAR Merge].Mtrl_ea_Cost,
[New ZSPWAR Merge].Mtrl_ttl_Cost, [New ZSPWAR Merge].Total_Cost,
[New ZSPWAR Merge].MAUC_STD, [New ZSPWAR Merge].Core_cost,
[New ZSPWAR Merge].Cat_Price, [New ZSPWAR Merge].Discount,
[New ZSPWAR Merge].[% Discount], [New ZSPWAR Merge].[ODC Freight],
[New ZSPWAR Merge].[Repair Cost], [New ZSPWAR Merge].[Material Burden],
[New ZSPWAR Merge].[% Material Burden], [New ZSPWAR Merge].[Rotable Depreciation],
[New ZSPWAR Merge].[% Core Dep], [New ZSPWAR Merge].[Net Spend],
[New ZSPWAR Merge].Margin, [New ZSPWAR Merge].Item_Cost,
[New ZSPWAR Merge].[Total Material Burden], [New ZSPWAR Merge].[Total Rotables Dep],
[New ZSPWAR Merge].SVO_Direct_Labor, [New ZSPWAR Merge].SVO_Labor_OH
FROM [New ZSPWAR Merge]
WHERE ( ( ( [New ZSPWAR Merge].Bill_doc ) NOT LIKE "1*" )
AND ( ( [New ZSPWAR Merge].ItCC ) LIKE "ZCOM" )
AND ( ( [New ZSPWAR Merge].ItCa ) NOT LIKE "ZRN*" )
)
OR ( ( ( [New ZSPWAR Merge].Bill_doc ) NOT LIKE "1*"
)
AND ( ( [New ZSPWAR Merge].ItCC ) LIKE "ZCOM" )
AND ( ( [New ZSPWAR Merge].ItCa ) NOT LIKE "I*"
) );
Apologies, the code snippet feature doesn’t seem to like me today.
Выдаёт ошибку — #1050 — Table ‘users’ already exists.
CREATE TABLE users (
usersId int(11) PRIMARY KEY AUTO_INCREMENT NOT NULL,
usersEmail varchar(128) NOT NULL,
usersUid varchar(128) NOT NULL,
usersPwd varchar(128) NOT NULL
);
-
Вопрос задан04 авг. 2022
-
1776 просмотров
CREATE TABLE IF NOT EXISTS users (
Потому что нельзя создать таблицу с именем существующей.
DROP TABLE users;
CREATE TABLE users (
usersId int(11) PRIMARY KEY AUTO_INCREMENT NOT NULL,
usersEmail varchar(128) NOT NULL,
usersUid varchar(128) NOT NULL,
usersPwd varchar(128) NOT NULL
);
Пригласить эксперта
-
Показать ещё
Загружается…
21 июн. 2023, в 16:27
10000 руб./за проект
21 июн. 2023, в 15:55
3000 руб./за проект
21 июн. 2023, в 15:40
5000 руб./за проект
Минуточку внимания
я добавляю эту таблицу:
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’ уже существует
24 ответов
звучит как Шредингера таблице…
серьезно, у вас, вероятно, сломанный стол. Попробуйте:
DROP TABLE IF EXISTS contenttype
REPAIR TABLE contenttype
- если у вас есть достаточные разрешения, удалите файлы данных (в /mysql/data/db_name)
59
автор: NullUserException
из журнала MySQL:
InnoDB: You can drop the orphaned table inside InnoDB by
InnoDB: creating an InnoDB table with the same name in another
InnoDB: database and copying the .frm file to the current database.
InnoDB: Then MySQL thinks the table exists, and DROP TABLE will
InnoDB: succeed.
я получил эту же ошибку, и таблица восстановления (из ответа @NullUserException) не помогла.
В конце концов я нашел данное решение:
sudo mysqladmin flush-tables
для меня, без sudo
, Я получил следующую ошибку:
mysqladmin: refresh failed; error: 'Access denied; you need the RELOAD privilege for this operation'
(работает на OS X 10.6)
возможно, потребуется очистить кэш таблицы. Например:
DROP TABLE IF EXISTS `tablename` ;
FLUSH TABLES `tablename` ; /* or exclude `tablename` to flush all tables */
CREATE TABLE `tablename` ...
я боролся с этим весь день: у меня есть скрипт на Perl, который создает набор таблиц, выполнив DROP IF EXISTS ...
и CREATE
ing их. The DROP
удалось, но на CREATE
Я получил это сообщение об ошибке: table already exists
я, наконец, добрался до сути: новая версия MySQL, которую я использую, имеет движок по умолчанию InnoDB («show engine G;»), я изменил его в my.cnf файл по умолчанию MyISAM, перезапустил MySQL, и теперь я больше не получаю » таблицу уже существует ошибка».
столкнувшись с той же проблемой (создайте таблицу InnoDB), это то, что наконец сработало для меня:
DROP DATABASE `having_issues`;
Я проверил на основе файла, разрешения, попытался восстановить и смыть, но ничего не получилось.
поэтому, если это опция, переместите все рабочие таблицы в другую базу данных, отбросьте старую (возможно, вам придется вручную удалить любые файлы из папки базы данных перед падением на работу) переименуйте новый, и вы должны быть на вашем пути. По-видимому, все, что «кэшируется» с помощью InnoDB, удаляется вместе с исходной базой данных.
У меня была эта проблема на Win7 в Sql Maestro для MySql 12.3. Ужасно раздражает, на самом деле, остановка шоу. Ничто не помогало, даже удаление и воссоздание базы данных. У меня такая же настройка на XP, и она работает там, поэтому после прочтения ваших ответов о разрешениях я понял, что это должны быть разрешения Win7. Поэтому я запустил MySql как администратор, и хотя Sql Maestro был запущен нормально, ошибка исчезла. Таким образом, это должно было быть проблемой разрешений между Win7 и Для MySQL.
Я также столкнулся с этой проблемой, когда при попытке создать таблицу сказал, что она уже существует и отбрасывая таблицу сказал, что она не существует.
Я сделал «флеш-таблицы», и это очистило проблему.
такая же проблема возникла со мной при создании представления.
Представление присутствовало ранее из-за некоторых изменений, которые он удалил, но когда я попытался добавить его снова, он показывал мне сообщение об ошибке «view already exists».
решение:
вы можете сделать одну вещь вручную.
- перейдите в папку MySQL, где вы установили его
- перейдите в папку данных внутри него.
- выберите базу данных и зайдите внутрь он.
- базы данных создает «.frm » формат файлов.
- удалить файл конкретной таблицы.
- Теперь создайте таблицу снова.
Он успешно создаст таблицу.
сначала проверьте, находитесь ли вы в правильной базе данных USE yourDB
и Select * from contenttype
просто посмотреть, что это такое и существует ли оно на самом деле…
У меня была такая же проблема в Mac OS X и MySQL 5.1.40. Я использовал eclipse для редактирования моего SQL-скрипта, а затем попробовал MySQLWorkbench 5.2.28. Вероятно, он преобразовал символы новой строки в формат Mac. Я понятия не имел, что не так с моим сценарием, пока я не прокомментировал первую строку в файле. После этого этот скрипт был интерпретирован mysql как один единственный комментарий. Я использовал встроенное приложение TextEdit Mac, чтобы исправить это. После того, как разрывы строк были преобразованы в правильный формат, ошибка 1050 ушедший.
обновление для пользователей Eclipse:
чтобы настроить окончание по умолчанию для новых файлов, созданных во всей рабочей области:
у меня был такой же случай. Проблема закончилась тем, что разрешения на родительский каталог.
я копировал файлы в mysql и из mysql во время тестирования.
drwx------ 3 _mysql wheel
было недостаточно, нужно было:
-rw-rw---- 3 _mysql wheel
извините за воскрешение.
Я борюсь с той же проблемой. Я не могу создать таблицу, даже если она не существует. Я пробовал все вышеперечисленные решения без успеха.
моим решением было удалить файлы ib_logfil0
, ib_logfile1
, ibdata1
и auto.cnf
из папки данных MySQL; убедитесь, что сначала остановите службу MySQL перед удалением этих файлов.
затем после перезапуска службы MySQL воссоздал эти файлы, и я смог запустить сценарий резервного копирования, все мои CREATE
s были хранится (файл sqldump).
у меня была такая же проблема, и похоже, что имя базы данных было чувствительным к регистру. Моя база данных называется:
Mydatabase
в то время как мой скрипт входит
USE mydatabase
Как только я изменил имя базы данных на правильный случай, все это, казалось, работало. Использование MySQL Workbench на MAC OSX
эта проблема также возникает, если «представление» (воображаемая таблица) существует в базе данных с тем же именем, что и наше новое имя таблицы.
в моем случае я обнаружил, что это проблема с InnoDB; я никогда не обнаружил, в чем заключалась фактическая проблема, но создание как MyISAM позволило ему построить
вы не верите мне!! Ive просто удалите блок комментариев из моего .sql-файл и теперь все работает!!!!!!!
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;
удаленный блок комментариев был такой:
--
-- Table structure for table `protocolo`
--
Я оставил только проблемный стол в одном .sql-файл. После этого я удалил комментарии, остался только код, и ошибка пропадает.
для меня проблема была вызвана при использовании копии файловой системы каталога базы данных mysql вместо mysqldump. У меня есть очень большие таблицы, в основном MyISAM и несколько таблиц кэша InnoDB, и это не практично mysqldump данные. Поскольку мы все еще запускаем MyISAM, XtraBackup не является вариантом.
те же симптомы, что и выше произошло со мной. Таблицы нет, в каталоге нет файлов, относящихся к таблице, но она не может быть создана, потому что MySQL думает его там. Drop table говорит, что его нет, create table говорит, что он есть.
проблема возникла на двух машинах, обе были исправлены путем копирования резервных копий. Тем не менее, я заметил, что в моей резервной копии есть .MYD and .MYI файл, хотя я был под впечатлением, что эти файлы не используются для InnoDB. Этот.MYD and .Файлы MYI имели владельца root, в то время как.frm принадлежал mysql.
Если вы копируете из резервной копии, проверьте права доступа к файлам. Таблицы Flush могут работа, но я решил закрыть и перезапустить базу данных.
удачи.
боже, у меня была такая же проблема с osCommerce
установить скрипт, пока я не выяснил, что система mysql имеет много баз данных и create table
запрос копирует себя в каждый и, таким образом, удаление только рабочей таблицы на активной БД не помогло, мне пришлось удалить таблицу из всех dbs
мой оператор CREATE был частью промежуточного дампа env.
Я попробовал все, что было сказано выше. Я не получил решения. Однако мой путь к искуплению был:
-
я натыкаюсь на тот факт, что (один из многих) оператор CREATE прошел, когда я исправил чувствительность к регистру имени базы данных. Что-то щелкнуло. Я повторил то же самое для других столов.
-
однако на сцену вышла новая ошибка. Прямые кавычки для «комментариев» бросали синтаксическую ошибку. Я был потрясен. заменил их, но новая ошибка начала появляться. Наконец-то я нашел решение.
решение: дамп, который я использовал, мог быть из другой версии MySql. Я получил разрешение подключиться к промежуточному MYsql, используя локальный (установленный на моей машине) MySQL workbench. Я не rdp в промежуточный сервер для входа в промежуточный MySQL workbench. Создал дамп оттуда. Побежал на свалку и это сработало как конфета.
пытался импортировать резервный файл sql, но получал ошибку; 1050 «таблица уже существует»
моя установка была такой:
- Windows 7
- Mysql 5.5.16
устранение:
- изменен движок сервера с InnoDB на MyISAM
- используя phpMyAdmin удалил базу данных, которую я пытался импортировать в
- перезапустил службу mysql
- попробовал реимпорт и он работал
у меня были огромные проблемы с ошибкой 1050 и 150.
проблема для меня заключалась в том, что я пытался добавить ограничение с ON DELETE SET NULL
как одно из условий.
изменение ON DELETE NO ACTION
позволил мне добавить необходимые ограничения FK.
к сожалению, сообщения об ошибках MySql совершенно бесполезны, поэтому мне пришлось найти это решение итеративно и с помощью ответов на вопрос выше.
в моем случае проблема заключалась в том, что было представление с тем же именем, что и моя таблица, поэтому мне пришлось удалить представление, чтобы позволить импорту продолжаться.
drop view `my-view-that-has-same-name-as-table`;
автоматическое решение, которое сработало для меня, — заменить обычную таблицу drop на этот sed во время дампа, чтобы также удалить любые представления, которые могут существовать:
mysqldump my-db
| sed -E 's/^DROP TABLE IF EXISTS(.+)$/ DROP VIEW IF EXISTS/g'
| mysql my-other-db
или если вы предпочитаете печатать в файл для резервного копирования
mysqldump my-db
| sed -E 's/^DROP TABLE IF EXISTS(.+)$/ DROP VIEW IF EXISTS/g'
> my-db.dump.sql
или если вы получили сбросил файл и импортируете его в свой db
cat my-db.dump.sql
| sed -E 's/^DROP TABLE IF EXISTS(.+)$/ DROP VIEW IF EXISTS/g'
| mysql my-other-db
идея
Примечание: важно, чтобы вы добавить ^
в начале регулярного выражения замены, потому что есть другие типы DROP TABLE IF EXISTS
команды в дампах, которые вы не хотите трогать.
вы идете от чего-то вроде этого:
--
-- 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` (
...
иметь что-то вроде этого:
--
-- 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’ уже существует
Я добавляю эту таблицу:
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’ уже существует
Ответ 1
Похоже, что у вас таблица Schroedinger…
Серьезно, теперь у вас, вероятно, есть разбитая таблица. Попробуйте:
-
DROP TABLE IF EXISTS contenttype
-
REPAIR TABLE contenttype
- Если у вас есть достаточные разрешения, удалите файлы данных (в/mysql/data/db_name)
Ответ 2
из журнала MySQL:
InnoDB: You can drop the orphaned table inside InnoDB by
InnoDB: creating an InnoDB table with the same name in another
InnoDB: database and copying the .frm file to the current database.
InnoDB: Then MySQL thinks the table exists, and DROP TABLE will
InnoDB: succeed.
Ответ 3
Я получил ту же ошибку, и REPAIR TABLE (из ответа @NullUserException) не помогло.
В итоге я нашел это решение:
sudo mysqladmin flush-tables
Для меня, без sudo
, я получил следующую ошибку:
mysqladmin: refresh failed; error: 'Access denied; you need the RELOAD privilege for this operation'
(Работает на OS X 10.6)
Ответ 4
Вам может понадобиться очистить кеш таблицы. Например:
DROP TABLE IF EXISTS `tablename` ;
FLUSH TABLES `tablename` ; /* or exclude `tablename` to flush all tables */
CREATE TABLE `tablename` ...
Ответ 5
Я борюсь с этим весь день: у меня есть Perl script, который строит набор таблиц, сначала делая DROP IF EXISTS ...
на них, а затем CREATE
их. DROP
преуспел, но на CREATE
я получил это сообщение об ошибке: table already exists
Наконец-то я понял: новая версия MySQL, которую я использую, имеет двигатель InnoDB по умолчанию ( «show engineG;» ). Я изменил его в файле my.cnf по умолчанию на MyISAM, повторно запустил MySQL, и теперь я больше не получаю ошибку «таблица уже существует».
Ответ 6
Встречая ту же проблему (создайте таблицу InnoDB), это то, что окончательно сработало для меня:
DROP DATABASE `having_issues`;
Я проверил файлы, разрешения, попытался выполнить REPAIR и FLUSH, но ничего не получилось.
Итак, если это вариант, переместите все рабочие таблицы в другую базу данных, отбросьте старую (вам может потребоваться вручную удалить любые файлы из папки базы данных до того, как она начнет работать), переименуйте новую, должен «вернуться на ваш путь». По-видимому, все, что «кэшируется» с помощью InnoDB, отбрасывается вместе с исходной базой данных.
Ответ 7
У меня была эта проблема на Win7 в Sql Maestro для MySql 12.3. Огромное раздражение, шоу-стоп на самом деле. Ничто не помогло, даже не отбросило и не воссоздало базу данных. У меня есть такая же настройка на XP, и она работает там, поэтому, прочитав ваши ответы о разрешениях, я понял, что это должны быть разрешения Win7. Поэтому я запускал MySql как администратор, и хотя Sql Maestro запускался нормально, ошибка исчезла. Таким образом, это может быть проблема с разрешениями между Win7 и MySql.
Ответ 8
Я также столкнулся с этой проблемой, когда пытаюсь создать таблицу, в которой говорилось, что она уже существует, и сбросив таблицу, сказал, что ее не существует.
Я сделал «FLUSH TABLES», и он очистил проблему.
Ответ 9
Аналогичная проблема возникла при создании представления.
Представление было раньше, но из-за некоторых изменений, которые он удалил. Но когда я попытался добавить его снова, он показывал мне сообщение об ошибке «вид уже существует».
Решение:
Вы можете сделать одно дело вручную.
- Перейдите в папку MySQL, в которой вы ее установили.
- Перейдите в папку данных внутри нее.
- Выберите свою базу данных и зайдите в нее.
- База данных создает файлы формата .frm.
- удалить конкретный файл таблицы.
- Теперь создайте таблицу еще раз.
Он успешно создаст таблицу.
Ответ 10
Сначала проверьте, находитесь ли вы в правильной базе данных USE yourDB
и попробуйте Select * from contenttype
просто посмотреть, что это такое, и если оно действительно существует…
Ответ 11
У меня была такая же проблема в Mac OS X и MySQL 5.1.40. Я использовал eclipse для редактирования моего SQL script, и я попробовал MySQLWorkbench 5.2.28. Вероятно, он преобразует символы новой строки в формат Mac. Я понятия не имел, что случилось с моим script, пока я не прокомментировал первую строку в файле. После этого этот script был интерпретирован mysql как один комментарий. Для этого я использовал встроенное приложение TextEdit Mac. После того, как разрывы строк были преобразованы в правильный формат, ошибка 1050 исчезла.
Обновление для пользователей Eclipse:
Чтобы настроить окончание по умолчанию для новых файлов, созданных по всей рабочей области:
Окно → Настройки → Общие → Рабочая область → Новая строка текстового файла разделитель.
Чтобы преобразовать существующие файлы, откройте файл для редактирования и для текущего файла, перейдите в меню:
Файл → Преобразование разделителей строк в
Ответ 12
У меня был такой же случай. Проблема заключалась в разрешении родительского каталога.
В ходе тестирования я копировал файлы из mysql и из него.
drwx------ 3 _mysql wheel
недостаточно, необходимо:
-rw-rw---- 3 _mysql wheel
Извините, что воскрес.
Ответ 13
Я борюсь с той же проблемой. Я не могу создать таблицу, даже если она не существует. Я пробовал все вышеперечисленные решения без успеха.
Моим решением было удалить файлы ib_logfil0
, ib_logfile1
, ibdata1
и auto.cnf
из папки данных MySQL; перед удалением этих файлов обязательно запустите службу MySQL.
Затем после перезапуска службы MySQL воссоздал эти файлы, и я смог запустить резервную копию script, все мои файлы CREATE
были сохранены (файл sqldump).
Ответ 14
У меня была такая же проблема, и похоже, что имя базы данных было чувствительным к регистру. Моя база данных называется:
Mydatabase
Хотя мой script включен
USE mydatabase
Как только я изменил имя базы данных на правильный случай, все это работало. Использование инструментария MYSQL для MAC OSX
Ответ 15
Эта проблема также возникает, если в базе данных существует «представление» (мнимая таблица) как одно и то же имя, что и наше новое имя таблицы.
Ответ 16
В моем случае я обнаружил, что это проблема с InnoDB; Я никогда не обнаружил, что представляет собой настоящая проблема, но создание в качестве MyISAM позволило ему построить
Ответ 17
Вы не поверите мне! Я только что удалил блок комментариев из моего файла .sql, и теперь он работает.
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;
Удаленный блок комментариев был таким:
--
-- Table structure for table 'protocolo'
--
Я оставил проблемную таблицу один в том же файле .sql. После этого я удалил комментарии, остался единственный код и ошибка исчезла.
Ответ 18
Мой оператор CREATE был частью промежуточного сценария env.
Я попробовал все, что было упомянуто выше. Я НЕ получил решение. Однако мой путь к искуплению:
-
Я натыкаюсь на то, что (один из многих в) оператор CREATE прошел, когда я исправил чувствительность к регистру базы данных. Это что-то нажало. Я повторил то же самое для других таблиц.
-
Однако на сцену появилась новая ошибка. Прямые цитаты для «комментариев» бросали синтаксическую ошибку. Я был потрясен. заменили их, но появилась новая ошибка. Наконец я знал решение.
РЕШЕНИЕ: Дамп, который я использовал, возможно, был из другой версии MySql. Я получил разрешение на подключение к промежуточной MYsql с помощью локальной (установленной на моей машине) рабочей среды mysql. Я не rdp на промежуточном сервере для входа в очередь для работы с mysql workbench. Создал дамп оттуда. Отказался от дампа, и он работал как сладкий.
Ответ 19
Для меня проблема возникла при использовании копии файловой системы базы данных mysql вместо mysqldump. У меня есть очень большие таблицы, в основном MyISAM и несколько таблиц кэша InnoDB, и это не является практичным для mysqldump данных. Поскольку мы все еще запускаем MyISAM, XtraBackup не является вариантом.
Те же симптомы, что и выше, произошли со мной. Таблицы там нет, в каталоге нет файлов, относящихся к таблице, но это невозможно создать, потому что MySQL думает о ней. Капля таблицы говорит, что нет, создание таблицы говорит, что это так.
Проблема возникла на двух машинах, оба были исправлены путем копирования резервных копий. Тем не менее, я заметил, что в моей резервной копии был файл .MYD и .MYI, хотя у меня создалось впечатление, что эти файлы не используются для InnoDB. У файлов .MYD и .MYI был владелец root, а .frm принадлежал mysql.
Если вы копируете из резервной копии, проверьте права доступа к файлу. Таблицы Flush могут работать, но я решил закрыть и перезапустить базу данных.
Удачи.
Ответ 20
gosh, у меня была та же проблема с osCommerce
install script, пока я не выяснил, что система mysql имеет много баз данных, а запрос create table
сам копирует в каждый из них и, таким образом, отбрасывает только рабочую таблицу на активном db didnt help, мне пришлось отказаться от таблицы из всех dbs
Ответ 21
пытался импортировать резервный sql файл, но получал ошибку; 1050 «Таблица уже существует»
Моя настройка была:
- Windows 7
- Mysql 5.5.16
Решение:
- Изменен движок сервера от InnoDB до MyISAM
- Использование phpMyAdmin Удаленная база данных, которую я пытался импортировать в
- Перезапуск службы mysql
- Пробовал повторный импорт и работал
Ответ 22
У меня возникли огромные проблемы с ошибкой 1050 и 150.
Проблема заключалась в том, что я пытался добавить ограничение с ON DELETE SET NULL
в качестве одного из условий.
Переход на ON DELETE NO ACTION
позволил мне добавить необходимые ограничения FK.
К сожалению, сообщения об ошибках MySql совершенно бесполезны, поэтому я должен был найти это решение итеративно и с помощью ответов на вопрос выше.
Ответ 23
В моем случае проблема заключалась в том, что было представление с тем же именем, что и моя таблица, поэтому мне пришлось отбросить представление, чтобы продолжить импорт.
drop view `my-view-that-has-same-name-as-table`;
Автоматизированное решение, которое сработало для меня, — это заменить стандартную таблицу drop на этот sed во время дампа, чтобы также удалить любые существующие представления:
mysqldump my-db
| sed -E 's/^DROP TABLE IF EXISTS(.+)$/ DROP VIEW IF EXISTS1/g'
| mysql my-other-db
Или, если вы предпочитаете печатать в файл для резервного копирования
mysqldump my-db
| sed -E 's/^DROP TABLE IF EXISTS(.+)$/ DROP VIEW IF EXISTS1/g'
> my-db.dump.sql
Или, если вы получили сбрасываемый файл и импортируете его в свой db
cat my-db.dump.sql
| sed -E 's/^DROP TABLE IF EXISTS(.+)$/ DROP VIEW IF EXISTS1/g'
| mysql my-other-db
Вы получаете идею
Примечание: важно добавить ^
в начало замещающего регулярного выражения, потому что в дампах, которые вы не хотите касаться, есть другие типы команд DROP TABLE IF EXISTS
.
У вас есть что-то вроде этого:
--
-- 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` (
...
Чтобы иметь что-то вроде этого:
--
-- 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` (
...
Ответ 24
Ваш диск также может быть заполнен. (просто было)
Ответ 25
У меня была такая же ошибка, но я знал, что таблица уже существует, и хотел добавить к ней. Я добавляю свой ответ, так как этот вопрос для меня в Google выглядит как № 1 при поиске той же ошибки, но по немного другому сценарию. В основном мне нужно было поставить галочку
«Добавить оператор DROP TABLE/VIEW/PROCEDURE/FUNCTION/EVENT/TRIGGER»
И это решило ошибку для меня.