Mysql如何添加多个值(在一个框中)

时间:2013-12-12 21:53:25

标签: mysql

我正在尝试添加多个值

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_IDSName是两个不同表的主键和外键

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或者没有,它对于该怎么做感到困惑。

1 个答案:

答案 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社区获得更多帮助。