gpt4 book ai didi

mysql - Django/MySQL : Making non-unique field unique fails even if field values are unique

转载 作者:行者123 更新时间:2023-11-29 06:51:38 30 4
gpt4 key购买 nike

我目前有这个:

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

非常感谢任何帮助。

最佳答案

该错误与表中的数据无关。如果我们尝试插入违反唯一约束的数据,或者如果我们尝试在表中存在重复项时定义 UNIQUE 键,我们会看到不同的错误:

Error Code 1062: Duplicate entry ...

<小时/>

当我们尝试定义新 key 且该 key 已存在时,会发生 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);

Error Code: 1062 Duplicate entry '1' for key 'foo2_ux1'

  alter table foo2 add key foo2_ix2 (id);

0 row(s) affected

alter table foo2 add key foo2_ix2 (id);

Error Code: 1061 Duplicate key name 'foo2_ix2'

  alter table foo2 add UNIQUE key foo2_ix2 (id);

Error Code: 1061 Duplicate key name 'foo2_ix2'

SHOW CREATE TABLE 将向我们显示该名称的键实际上已经存在

  CREATE TABLE `foo2` (
`id` INT(11) DEFAULT NULL,
KEY `foo2_ix2` (`id`)
) ENGINE=InnoDB

关于mysql - Django/MySQL : Making non-unique field unique fails even if field values are unique,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47192463/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com