mysql在选项卡中插入重复值

2024-09-30 18:23:03 发布

您现在位置:Python中文网/ 问答频道 /正文

我试图使用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,只要列表中有名字和爱好?你知道吗


Tags: nameinid编码forexecutenamesmysql
2条回答

我假设问题是您的Details表有一个主键设置。为了插入重复项,您需要删除主键,或者将其更改为具有足够的唯一性,以便不将其视为重复项。你知道吗

看看你的表创建脚本,我假设你有这样的东西

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

删除主键。你知道吗

如果您想将Id作为主表,请创建如下表

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

如果表中的属性(列)是主键(或唯一键),则它永远不能接受重复项。只要主键(可能是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)
)

相关问题 更多 >