无法在FOREIGN KEY上创建表(错误号:150)

时间:2014-12-28 19:36:33

标签: php mysql sql foreign-keys errno

我看到很多相同的问题,但我无法解决我的问题。

如果我运行此代码:

<?php
include_once($_SERVER['DOCUMENT_ROOT'].'/config.php');

$servername = HOST;
$username = USERNAME;
$password = PASSWORD;
$dbname = DB;

// Create connection
$conn = new mysqli($servername, $username, $password, $dbname);
// Check connection
if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
} 

// sql to create table
$sql = "CREATE TABLE IF NOT EXISTS Articls (
            id INT(10) UNSIGNED AUTO_INCREMENT PRIMARY KEY,     
            name VARCHAR(254) COLLATE utf8_persian_ci NOT NULL      
) DEFAULT COLLATE utf8_persian_ci";

if ($conn->query($sql) === TRUE) {
    echo "Table Articls created successfully";
} else {
    echo "Error creating table: " . $conn->error;
}

/////////////////////////////////////////////////////////////////////////

$sql = "CREATE TABLE IF NOT EXISTS Tags (
            id INT(10) UNSIGNED AUTO_INCREMENT PRIMARY KEY,  
            id_articls INT(10) UNSIGNED NOT NULL,   
            name VARCHAR(256) COLLATE utf8_persian_ci NOT NULL,           
            FOREIGN KEY(Tags.id_articls) REFERENCES Articls(Articls.id)         
) DEFAULT COLLATE utf8_persian_ci";

if ($conn->query($sql) === TRUE) {
    echo "Table Tags created successfully";
} else {
    echo "Error creating table: " . $conn->error;
}

$conn->close();
?>

我收到此错误:(如果我删除FOREIGN KEY,则无效)

  

表格Articls创建成功错误创建表格:无法创建   table&#39; admin_wepar.Tags&#39; (错误:150)

修改

如果更改into Articls.idTags.id_articls我收到此错误:

  

表格Articls创建了SuccessfulError创建表:你有一个   SQL语法错误;查看与您的手册相对应的手册   MySQL服务器版本,用于在&#39; FOREIGN KEY附近使用正确的语法   (Tags.id_articls)参考文献Articls(Articls.id))DEFAULT COLLA&#39;在   第5行

2 个答案:

答案 0 :(得分:0)

Tags.id_articls签名的整数,而Articl.id无符号整数。 MySQL要求引用字段完全相同。让Tags.id_articls无符号以使其有效。

此外,MySQL中不允许列列表中的表名。始终清楚表明哪个表:首先是引用表,然后是引用的表。所以改变

FOREIGN KEY(Tags.id_articls) REFERENCES Articls(Articls.id)

FOREIGN KEY(id_articls) REFERENCES Articls(id)

它会起作用。

答案 1 :(得分:0)

您需要声明Articls.idTags.id_articls已签名或未签名