我正在尝试添加多个值
INSERT INTO Requierments (item_ID, SName) VALUES (
05, 'Exotic Weapons''basic weapon');
可能吗?我已经准备好了|
和&
,但我不允许这样做。
这个想法是为了证明item_ID
需要多个Sname。
如果不需要SName
,我该如何对其进行编码,在alter table
中它向我显示默认为'0'表示item_ID
而''表示Sname
1}},但是当我尝试时:
INSERT INTO Requierments (item_ID, SName) VALUES (
02, '');
或
INSERT INTO Requierments (item_ID, SName) VALUES (
02, );
发生错误。 item_ID
和SName
是两个不同表的主键和外键
CREATE TABLE `requierments` (
`item_ID` int(11) NOT NULL DEFAULT '0',
`SName` varchar(30) NOT NULL DEFAULT '',
PRIMARY KEY (`item_ID`,`SName`),
KEY `SName` (`SName`),
CONSTRAINT `requierments_ibfk_1` FOREIGN KEY (`item_ID`) REFERENCES `item` (`ID`),
CONSTRAINT `requierments_ibfk_2` FOREIGN KEY (`SName`) REFERENCES `talents` (`SkillName`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
CREATE TABLE `talents` (
`SkillName` varchar(40) NOT NULL DEFAULT '',
`Bonus` varchar(30) DEFAULT NULL,
`Description` varchar(90) DEFAULT NULL,
`R_Str` int(11) DEFAULT NULL,
`R_WS` int(11) DEFAULT NULL,
`R_BS` int(11) DEFAULT NULL,
`R_Fel` int(11) DEFAULT NULL,
`R_Per` int(11) DEFAULT NULL,
`R_Int` int(11) DEFAULT NULL,
`R_Agi` int(11) DEFAULT NULL,
`R_WP` int(11) DEFAULT NULL,
`Talent_requiret` varchar(40) DEFAULT NULL,
PRIMARY KEY (`SkillName`),
KEY `Talent_requiret` (`Talent_requiret`),
CONSTRAINT `talents_ibfk_1` FOREIGN KEY (`Talent_requiret`) REFERENCES `talents` (`SkillName`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
CREATE TABLE `item` (
`ID` int(11) NOT NULL DEFAULT '0',
`Name_` varchar(30) DEFAULT NULL,
`Weight` int(11) DEFAULT NULL,
`Value_` int(11) DEFAULT NULL,
`Availability` varchar(30) DEFAULT NULL,
PRIMARY KEY (`ID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
以下是我希望在需求表中存储item_ID
需要在SName
下使用的3个表,因为一个项目可能需要多个SName
或者没有,它对于该怎么做感到困惑。
答案 0 :(得分:1)
'Exotic Weapons''basic weapon'
语法被解释为'Exotic Weapons'basic weapon'
(请参阅manual page on String Literals)。如果你用逗号或其他东西('Exotic Weapons,basic weapon'
)之类的特殊字符将它们分开,你可以存储两者,但由于后面的原因,这是一个坏主意。
每当您想要在一列中存储多个值时,您应该有一个新表来存储每个值并将其链接到相关的item_ID
。这称为“规范化” - 它使您的数据库更稳定,您的应用程序代码更简单,一切都更有可能在您前进和修改时起作用。搜索“数据库规范化”,并阅读有关如何做你想要做的事情。
编辑:现在仍然有点难以判断你要做什么,但看起来你只想在items
中存储多个元组。例如:
INSERT INTO Requierments (item_ID, SName) VALUES
(5, 'Exotic Weapons'),
(5, 'basic weapon');
请注意,它应为5
,而不是05
。这就是INSERT INTO Requierments (item_ID, SName) VALUES ( 02, '');
失败的原因。此外,您不能只省略一个值并有空格,就像在其他示例中一样:INSERT INTO Requierments (item_ID, SName) VALUES ( 02, );
老实说,很难说出你在这里尝试做什么,似乎对表结构和SQL语法的基础知识有些混淆。例如,这个陈述非常令人困惑和不清楚:“因为一个项目可能需要有一个以上的SName或没有,所以它会对做什么感到困惑。”如果您可以更清楚地了解表格如何与彼此相关以及您所处的位置,那么您将从SO社区获得更多帮助。