簡體   English   中英

無法添加外鍵約束

[英]Cannot add foreign key constraint

首先,這是我的主要參考表mysql dump

-- phpMyAdmin SQL Dump
-- version 4.1.14
-- http://www.phpmyadmin.net
--
-- Host: 127.0.0.1
-- Generation Time: Nov 17, 2015 at 03:15 AM
-- Server version: 5.6.17
-- PHP Version: 5.5.12

SET SQL_MODE = "NO_AUTO_VALUE_ON_ZERO"; SET time_zone = "+00:00";


/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */; /*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */; /*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */; /*!40101 SET NAMES utf8 */;

--
-- Database: `j_inventory`
--

-- --------------------------------------------------------

--
-- Table structure for table `users`
--

CREATE TABLE IF NOT EXISTS `users` (   `user_id` int(10) unsigned NOT NULL AUTO_INCREMENT,   `username` varchar(200) COLLATE utf8_unicode_ci NOT NULL,   `password` varchar(500) COLLATE utf8_unicode_ci NOT NULL,  `real_password` varchar(250) COLLATE utf8_unicode_ci NOT NULL,   `role` varchar(50) COLLATE utf8_unicode_ci NOT NULL,   `full_name` varchar(250) COLLATE utf8_unicode_ci NOT NULL,   `remember_token` varchar(100) COLLATE utf8_unicode_ci DEFAULT NULL,   `created_at` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',   `updated_at` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',   `status` varchar(100) COLLATE utf8_unicode_ci NOT NULL,   PRIMARY KEY (`user_id`) ) ENGINE=InnoDB  DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=44 ;

/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */; /*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */; /*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;

和希望外鍵所在的第二個表

-- phpMyAdmin SQL Dump
-- version 4.1.14
-- http://www.phpmyadmin.net
--
-- Host: 127.0.0.1
-- Generation Time: Nov 17, 2015 at 03:14 AM
-- Server version: 5.6.17
-- PHP Version: 5.5.12

SET SQL_MODE = "NO_AUTO_VALUE_ON_ZERO"; SET time_zone = "+00:00";


/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */; /*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */; /*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */; /*!40101 SET NAMES utf8 */;

--
-- Database: `j_inventory`
--

-- --------------------------------------------------------

--
-- Table structure for table `user_details`
--

CREATE TABLE IF NOT EXISTS `user_details` (   `id` int(11) NOT NULL AUTO_INCREMENT,   `phone` varchar(200) NOT NULL,   `age` int(100) NOT NULL,   `gender` varchar(50) NOT NULL,   `address` varchar(250) NOT NULL,   `course` varchar(250) NOT NULL,   `college` varchar(200) NOT NULL,   `year` int(11) NOT NULL,   `user_id` int(100) NOT NULL,   `updated_at` timestamp NOT NULL,   `created_at` timestamp NOT NULL,   PRIMARY KEY (`id`),   KEY `user_id` (`user_id`) ) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=3 ;

/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */; /*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */; /*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;

users_details中的外鍵(由於mysql錯誤“無法添加外鍵約束”而設置)是'user_id',而引用表是'users'表,其中外鍵的引用鍵是'user_id'在用戶表上我嘗試了這個

ALTER TABLE user_details ADD FOREIGN KEY fk1(user_id)REFERENCES users(user_id)ON DELETE CASCADE ON UPDATE NO ACTION;

但遺憾的是,它讓我錯了

錯誤SQL查詢:

ALTER TABLE user_details ADD CONSTRAINT fk1 FOREIGN KEY( user_id )REFERENCES j_inventory usersuser_id )ON DELETE CASCADE ON UPDATE NO ACTION; MySQL說:文檔

1215 - 無法添加外鍵約束文檔

請給我任何幫助,線索,想法,建議和建議?

您的用戶ID在users表上未簽名。 從users table create語句中刪除此字段中的“unsigned”,看看它是否有效。 我認為您所看到的是由用戶和user_details表上的user_id字段類型不匹配導致的錯誤

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM