- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
在问这个问题之前在Stackoerflow看到了很多问题
当我执行下面的 mlm_commission 创建表查询时,
我收到以下错误。
1005 - Can't create table 'mlm_new.mlm_commission' (errno: 150) (Details…)
此外,当我单击“详细信息”时,我得到了以下文本
Supports transactions, row-level locking, and foreign keys
创建佣金表
CREATE TABLE IF NOT EXISTS mlm_commission
(`weekno` int(11) NOT NULL,
`level` int(11) NOT NULL,
`username` varchar(500) NOT NULL,
`PositionA` int(11) NOT NULL,
`CFPositionA` int(11) NOT NULL,
`PositionB` int(11) NOT NULL,
`CFPositionB` int(11) NOT NULL,
`PositionC` int(11) NOT NULL,
`CFPositionC` int(11) NOT NULL,
`ABLeft` int(11) NOT NULL,
`CFABLeft` int(11) NOT NULL,
`ABRight` int(11) NOT NULL,
`CFABRight` int(11) NOT NULL,
`CLeft` int(11) NOT NULL,
`CFCLeft` int(11) NOT NULL,
`CRight` int(11) NOT NULL,
`CFCRight` int(11) NOT NULL,
`ABMatchingPair` int(11) NOT NULL,
`CMatchingPair` int(11) NOT NULL,
`IsIncludedToParent` enum('Y','N'),
`side` enum('L','R') NOT NULL,
`leg` enum('0','1','2') NOT NULL,
`parent_key` varchar(15) NOT NULL,
`commission` int(11) NOT NULL,
FOREIGN KEY(`username`) REFERENCES mlm_rtmfx_users(`username`),
FOREIGN KEY(`side`) REFERENCES mlm_rtmfx_users(`side`),
FOREIGN KEY(`leg`) REFERENCES mlm_rtmfx_users(`leg`),
FOREIGN KEY(`parent_key`) REFERENCES mlm_rtmfx_users(`parent_key`),
PRIMARY KEY(`username`,`weekno`,`level`));
我在下表的 mlm_rtmfx_commission 表中引用了 4 个外键值。
CREATE TABLE `mlm_rtmfx_users` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`user_id` varchar(1023) NOT NULL,
`username` varchar(500) NOT NULL,
`user_key` varchar(15) NOT NULL,
`parent_key` varchar(15) NOT NULL,
`sponsor_key` varchar(15) NOT NULL,
`leg` enum('0','1','2') NOT NULL,
`payment_status` enum('0','1') NOT NULL,
`pinno` int(11) NOT NULL,
`user_password` varchar(8) NOT NULL,
`side` enum('L','R') NOT NULL,
`iseligible` enum('Y','N') NOT NULL,
`created_date` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
PRIMARY KEY (`id`)
)
您可以检查每个外键引用是否具有相同的名称和类型。
我看过这个Error No:150我对索引感到困惑。
我在 mlm_rtmfx_users 表中也有索引列表。请检查以下内容。
我从下面的查询中得到了索引表。
SHOW INDEX FROM mlm_rtmfx_users
请澄清我哪里出错了?如果我的问题不清楚,请告诉我。
最佳答案
FOREIGN KEY
创建有两个要求。首先,引用列必须与被引用列具有完全相同的数据类型。其次,被引用列的索引必须与引用列完全一样。也就是说,如果您有 3 个单个 FOREIGN KEY
,则需要在引用表上有 3 个相应的索引。如果您有一个包含 3 列的复合 FOREIGN KEY
,则您需要在引用表中的相同 3 列上有一个相应的复合索引。
您在mlm_rtmfx_users
中引用了一些 列索引,但每个 引用列的索引必须与FOREIGN KEY
引用表中的列。因此,您需要在 side,leg,parent_key,user
上添加索引。
如果减少 username
的长度,您将不会超过每个索引 767 字节的 InnoDB 限制。
CREATE TABLE `mlm_rtmfx_users` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`user_id` varchar(1023) NOT NULL,
`username` varchar(50) NOT NULL,
`user_key` varchar(15) NOT NULL,
`parent_key` varchar(15) NOT NULL,
`sponsor_key` varchar(15) NOT NULL,
`leg` enum('0','1','2') NOT NULL,
`payment_status` enum('0','1') NOT NULL,
`pinno` int(11) NOT NULL,
`user_password` varchar(8) NOT NULL,
`side` enum('L','R') NOT NULL,
`iseligible` enum('Y','N') NOT NULL,
`created_date` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
PRIMARY KEY (`id`),
-- More indices are needed in the parent table:
INDEX (`username`),
INDEX (`side`),
INDEX (`leg`),
INDEX (`parent_key`)
)
如果你必须保持用户名
的长度为500,你将需要enable innodb_long_prefix
增加索引的允许字节长度。
将额外的索引添加到父表(并且 username
长度减少到 InnoDB 的索引限制),可以成功创建表。 Here it is in action
关于mysql - #1005 - 无法创建表 errno : 150,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24840781/
我删除数据库失败: mysql> 删除数据库 mydb; 错误 1010 (HY000):删除数据库时出错(不能 rmdir './mydb',errno: 39) 目录 db/mydb 存在于 my
据我所知,python的异常返回的errnos大部分与“linux/errno.h”中的errnos相同。但有时,事情并不像我期望的那样: 例如,当一个socket连接抛出一个socket.timeo
我们是否需要在调用函数之前将errno 重置为零?请参见下面的代码。现在的场景是 a_dest_path 是一个现有目录。但是当我执行代码时,它总是尝试 mkdir 但返回错误说该目录无法创建,因为它
在Red Hat Enterprise Linux Server release 5.7 上配置YUM本地源时,遇到了"[Errno 5] OSError: [Errno 2] No su
我正在尝试制作在线FPS游戏,到目前为止,它可以在我的本地网络上运行。我正在尝试做的是使其在全局范围内运作 过去,我曾尝试过使其他Python项目在全局范围内工作,但到目前为止,我还无法使其正常工作。
我希望获得有关在 Python 2.7 中使用urlopen时出现IOError: [Errno socket error] [Errno 10060]的更多信息。我正在使用我的个人 35MB/s 互
来自 linux 中 fwrite 的手册页, 描述 函数 fread() 从 stream 指向的流中读取数据的 nmemb 元素,每个 size 字节长,并将它们存储在 ptr 给定的位置。
我试图了解 glibc 如何在预处理器不替换 errno 符号的情况下初始化 errno。 我首先尝试自己基于csu/errno-loc.c实现了一个简单的版本和 csu/errno.c : myer
我看过这段代码: #if !defined(errno) extern int errno; #endif 所以我的问题是 errno 是 int 还是 macro ,因为使用 #if if 可以检查
errno.h 中的这 2 个 linux 错误有什么区别? 23 和 24 我尝试了 2 个不同的网站,但无法理解两者之间的区别。 [EMFILE] Too many open files. [EN
操作系统:Oracle Linux 6 [xxx@host /etc]$ uname -a Linux slc08yld 2.6.39-400.298.2.el5uek #1 SMP Mon Jan
什么样的库函数所面临的什么样的错误会影响errno并将其设置为非零值?在我下面的程序中,我打算使用 if(errno!=0) 作为条件来检查我使用的库函数是否正常运行,这是我发现的(见下面的代码):
我有一个 python 脚本,它创建一个 tar 文件,将文件移动到 tar 文件中,然后删除它们。 我可以毫无问题地手动运行脚本。但是当它从 cron 运行时,它失败了: IOError: [Err
我已经安装了 TensorFlow。当我下载 MNISTdataset 时,存在一个错误。谁能告诉我出了什么问题?非常感谢!错误详情如下: Python 2.7.9 (default, Apr 2
我正在尝试运行我的 python 代码,它显示以下内容: IOError: [Errno socket error] [Errno 54] Connection reset by peer 这是我的代
我正在将大量金融时间序列数据写入单个 CSV 文件。在一个实例中,我发现 to_csv 方法反复失败,但我终生无法弄清楚原因。在调用 to_csv 方法期间,一切都会挂起 10-15 分钟以上。在因错
我正在尝试从我的Python脚本打开文件recentlyUpdated.yaml。但当我尝试使用时:。我收到一个错误,内容是:。为什么?我怎样才能解决这个问题?
我正在尝试从我的Python脚本打开文件recentlyUpdated.yaml。但当我尝试使用时:。我收到一个错误,内容是:。为什么?我怎样才能解决这个问题?
我正在尝试从我的Python脚本打开文件recentlyUpdated.yaml。但当我尝试使用时:。我收到一个错误,内容是:。为什么?我怎样才能解决这个问题?
请解释以下程序中发生了什么。 我在程序的开头和结尾检查了 strerror(errno) 返回的地址,并确认它每次都返回相同的地址。然后一旦确定这一点,在第一种情况下我继续将相同的地址分配给 ptr,
我是一名优秀的程序员,十分优秀!