我目前有这个:
class Committee(models.Model):
# ...some fields...
committee_xml_id = models.IntegerField()
我需要将字段committee_xml_id
设为唯一,即将其设为:
class Committee(models.Model):
# ...some fields...
committee_xml_id = models.IntegerField(unique=True)
我也尝试过这样做:
class Committee(models.Model):
# ...some fields...
committee_xml_id = models.IntegerField(unique=True, db_index=False)
唉,结果是一样的。
运行./manage.py makemigrations
,然后运行./manage.py migrate
,问题是:
django.db.utils.OperationalError: (1061, "Duplicate key name 'appname_committee_committee_xml_id_d1210032_uniq'")
乍一看,似乎问题在于表格中已经存在非唯一数据,但问题恰恰在于没有。表中只有45行,字段committee_xml_id
仅包含唯一条目。
以下查询没有给出结果,正如预期的那样没有重复项:
SELECT
com.committee_xml_id,
COUNT(*)
FROM
appname_committee AS com
GROUP BY
com.committee_xml_id
HAVING
COUNT(*) != 1
严格来说,这里是没有HAVING
条件的相同查询,清楚地表明确实没有重复:
SELECT
com.committee_xml_id,
COUNT(*)
FROM
appname_committee AS com
GROUP BY
com.committee_xml_id
结果是:
# committee_xml_id, COUNT(*)
78, 1
79, 1
124, 1
125, 1
129, 1
130, 1
131, 1
132, 1
133, 1
134, 1
137, 1
139, 1
140, 1
141, 1
142, 1
147, 1
148, 1
149, 1
150, 1
151, 1
152, 1
153, 1
154, 1
160, 1
166, 1
167, 1
168, 1
169, 1
170, 1
176, 1
192, 1
193, 1
194, 1
195, 1
198, 1
199, 1
200, 1
201, 1
202, 1
203, 1
204, 1
205, 1
206, 1
207, 1
216, 1
非常感谢任何帮助。
答案 0 :(得分:2)
错误与表格中的数据无关。如果我们试图插入违反唯一约束的数据,或者如果我们在表格中有重复项时尝试定义UNIQUE键,我们会看到不同的错误:
错误代码1062:重复输入...
当我们尝试定义新密钥时,会发生1061
错误,并且该密钥已经存在。
作为示范:
create table foo2 (id int);
0 row(s) affected
insert into foo2 (id) values (1),(1);
2 row(s) affected
alter table foo2 add unique key foo2_ux1 (id);
错误代码:1062重复输入' 1'对于密钥' foo2_ux1'
alter table foo2 add key foo2_ix2 (id);
0 row(s) affected
alter table foo2 add key foo2_ix2 (id);
错误代码:1061重复的密钥名称' foo2_ix2'
alter table foo2 add UNIQUE key foo2_ix2 (id);
错误代码:1061重复的密钥名称' foo2_ix2'
SHOW CREATE TABLE
会向我们显示该名称确实存在的密钥
CREATE TABLE `foo2` (
`id` INT(11) DEFAULT NULL,
KEY `foo2_ix2` (`id`)
) ENGINE=InnoDB