繁体   English   中英

无法在FOREIGN KEY上创建表(errno:150)

[英]Can't create table (errno: 150) on FOREIGN KEY

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

如果我运行此代码:

<?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创建表时出错:无法创建表“ admin_wepar.Tags”(错误号:150)

编辑

如果更改into Articls.idinto Articls.idTags.id_articls出现此错误:

成功创建了表链接创建表时出错:SQL语法错误; 在第5行的“ FOREIGN KEY(Tags.id_articls)参考参考Articls(Articls.id))DEFAULT COLLA”附近,查看与您的MySQL服务器版本相对应的手册以获取正确的语法。

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)

它会工作。

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM