Модераторы: skyboy
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Таблица не создается из-за связи: errno: 150 
V
    Опции темы
Royan
Дата 1.12.2007, 19:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Dreamer
***


Профиль
Группа: Участник Клуба
Сообщений: 1708
Регистрация: 14.9.2002
Где: Лондон

Репутация: нет
Всего: 15



Пытаюсь создать две таблички и связь между ними:
Код

CREATE DATABASE IF NOT EXISTS `my_db`;

USE `my_db`;

-- Drop table TCompany
DROP TABLE IF EXISTS `TCompany`;

CREATE TABLE `TCompany` (
  `uid` int(11) UNSIGNED NOT NULL AUTO_INCREMENT,
  PRIMARY KEY(`uid`),
  UNIQUE INDEX `idx_uid`(`uid`)
)
ENGINE=INNODB
CHARACTER SET cp1251 ;


-- Drop table TCompanyData
DROP TABLE IF EXISTS `TCompanyData`;

CREATE TABLE `TCompanyData` (
  `companyId` int(11),
  CONSTRAINT `RComp_Comp` FOREIGN KEY (`companyId`)
    REFERENCES `TCompany`(`uid`)
    ON DELETE CASCADE
    ON UPDATE CASCADE
)
ENGINE=INNODB
CHARACTER SET cp1251 ;


 MySQL ругается говорит
Цитата

Can't create table '.\my_db\tcompanydata.frm' (errno: 150)


Причем если убрать из `TCompanyData` создание FK то все в порядке 


--------------------
Открыта вакансия Junior Java Developer'а в нашем лондонском офисе, подробнее можно узнать здесь
PM MAIL MSN   Вверх
Royan
Дата 2.12.2007, 14:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Dreamer
***


Профиль
Группа: Участник Клуба
Сообщений: 1708
Регистрация: 14.9.2002
Где: Лондон

Репутация: нет
Всего: 15



Оказалась реально тупая ошибка - несовпадение типов. В одном случае int(11) UNSIGNED в другом просто int(11)


--------------------
Открыта вакансия Junior Java Developer'а в нашем лондонском офисе, подробнее можно узнать здесь
PM MAIL MSN   Вверх
cmygeHm
Дата 11.2.2010, 07:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 96
Регистрация: 3.12.2008

Репутация: нет
Всего: -2



А у меня получилось что кодировка в одной таблице latin, то а в другой cp1251.
PM MAIL   Вверх
dreamir
  Дата 22.11.2010, 09:43 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 1
Регистрация: 21.11.2010

Репутация: 1
Всего: 1



А у меня такая ошибка была, когда я пытался создать таблицу типа INNODB с внешним ключом на поле таблицы типа MyISAM.
Специально зарегался для того чтобы тоже внести свою лепту, вдруг кому-то пригодится =) .
PM MAIL   Вверх
skyboy
Дата 22.11.2010, 11:35 (ссылка) |    (голосов:2) Загрузка ... Загрузка ... Быстрая цитата Цитата


неОпытный
****


Профиль
Группа: Модератор
Сообщений: 9820
Регистрация: 18.5.2006
Где: Днепропетровск

Репутация: 41
Всего: 260



Цитата(dreamir @  22.11.2010,  08:43 Найти цитируемый пост)
а поле таблицы типа MyISAM

угу. 
а в мане, кста, по пунктам расписаны условия работоспособности внешних ключей: как полное соответствие типов полей, так и то, что "обе таблицы должны быть innodb и не должны быть temporary".
но в любом случае - это круто, что ты зарегился на форуме не для того, чтоб спросить, а для того, чтоб поделиться информацией!
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | MySQL | Следующая тема »


 




[ Время генерации скрипта: 0.0940 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.