带有FOREIGN KEY REFERENCES的错误消息

时间:2013-02-21 09:46:06

标签: sql-server foreign-keys create-table

我正在尝试创建一个链接到多个角色的表。 该表名为UserRoles,只有两列。

第一列包含对用户的引用 第二列包含指向角色的链接

我使用了FOREIGN KEY REFERENCES,你可能会注意到底部,但我一直收到错误信息

执行查询时出现以下错误:

  

服务器:消息1770,级别16,状态0,行1外键   'FK_ UserRoles _user ___ 70DDC3D8'引用无效列'user_id'   在参考表'MyUsers'中。

无法创建约束。查看以前的错误。

有更好的方法吗?

CREATE TABLE MyUsers
(
id                INT          IDENTITY(1,1)PRIMARY KEY,
user_logon_id     VARCHAR(30)  NOT NULL,
user_full_name    VARCHAR(30)  NULL,
user_description  VARCHAR(125) NULL,
user_password     VARCHAR(125) NOT NULL,
);

INSERT INTO MyUsers (user_logon_id, user_full_name, user_description, user_password) VALUES ('mcobery', 'Marc Cobery',

CREATE TABLE MyRole
(
myrole_id         INT          IDENTITY(1,1)PRIMARY KEY,
role_name         VARCHAR(30)  NOT NULL,
role_description  VARCHAR(50)  NULL,
);

INSERT INTO MyRole (role_name, role_description) VALUES ('administrator', ' Administrator of the web site');

INSERT INTO MyRole (role_name, role_description) VALUES ('user', ' User of the web site');

CREATE TABLE UserRoles
(
user_id int FOREIGN KEY REFERENCES MyUsers(user_id),
role_id int FOREIGN KEY REFERENCES MyRole(role_id),
);

2 个答案:

答案 0 :(得分:5)

应该如下所示

CREATE TABLE UserRoles
 (
    user_id int FOREIGN KEY REFERENCES MyUsers(id),
    role_id int FOREIGN KEY REFERENCES MyRole(myrole_id),
 );
MyUsers表中

user_id列

答案 1 :(得分:1)

您的表格应如下所示:

CREATE TABLE UserRoles
(
user_id int FOREIGN KEY REFERENCES MyUsers(id),
role_id int FOREIGN KEY REFERENCES MyRole(myrole_id),
);

创建引用时的规则如下:

Column_Name DATATYPE FOREIGN KEY REFERENCES ParentTableName(parentColumnName)