mysql将重复值插入表中

时间:2014-07-29 16:22:57

标签: python mysql sql

我正在尝试使用python将值插入到mysql表中,我有一些值,但我不考虑是否重复键/非重复但我想要插入每个值。

对于我的mysql编码,我应该对插入重复项进行哪些更改?

   for name,hobby in p: 
       print name,hobby

   cursor.execute(
   '''INSERT INTO Details (Names, Hobby)
      VALUES (%s, %s)''',
     (name,hobby))

我收到以下错误!

   IntegrityError: (1062, "Duplicate entry 'Leelal' for key 'PRIMARY'")

请帮我把重复的值放到表格中!

表架构:

Id | Names | Hobby

只要姓名和爱好出现在列表中,有没有办法自动增加Id?

2 个答案:

答案 0 :(得分:2)

如果表中的属性(列)是主键(或唯一),则它永远不会接受重复项。只要您的主键(可能是ID)没有重复项,您几乎可以插入重复项,例如,

ID   |   Name   |   Hobby  |
1        John       Play
2        John       Play
3        Steve      Running
4        Steve      Running

(确保将主键设置为自动增量。以下是教程:http://www.w3schools.com/sql/sql_autoincrement.asp)。

CREATE TABLE Hobbies
(
ID int NOT NULL AUTO_INCREMENT,
Name varchar(255) NOT NULL,
Hobby varchar(255),
PRIMARY KEY (ID)
)

答案 1 :(得分:0)

我认为问题是你的Details表有一个主键设置。为了插入重复项,您需要删除主键,或将其更改为足够独特,以免被视为重复。

看看你的表格创建脚本,我认为你有这样的东西

CREATE TABLE Persons
(
ID int NOT NULL,
Name varchar(255) NOT NULL,
Hobby varchar(255),
PRIMARY KEY (Name)
)

删除PRIMARY KEY。

如果您想将Id作为主要内容,请按照此类

创建表格
CREATE TABLE MyTable
(
ID INTEGER AUTO_INCREMENT PRIMARY KEY
Name varchar(255) NOT NULL,
Hobby varchar(255),
)