gpt4 book ai didi

PHP 银条 ORM : Duplicate key value violates unique constraint for DataObject write

转载 作者:可可西里 更新时间:2023-10-31 22:09:12 25 4
gpt4 key购买 nike

我的网站上有一个功能,可以非常快速地将一堆值保存到相同的 DataObject 类型。大多数时候没问题,但偶尔会出错

ERROR: duplicate key value violates unique constraint ...

通读我看到的文档:

SilverStripe does not use the database's built-in auto-numbering system. Instead, it will generate a new ID by adding 1 to the current maximum ID

之前查看代码,它看起来像是从主键中检索最大数量,插入具有该 ID 的记录,然后设置 DataObject 的值并再次写入。在我的负载平衡环境中,当发送这些多个条目时,我相信插入是使用相同的主键发生的,因此出现错误。

据我所知,这是一个我无法回避的问题。来自其他questions和 doco 我无法设置复合主键。我唯一能想到的就是为使用数据库内置自动编号系统的创建运行自定义 sql。

是否有更好的方法来处理此错误或我可以设置复合主键的方法?

编辑

完整的错误是

Query failed: ERROR: duplicate key value violates unique constraint 'TABLE_pkey'
DETAIL: Key ('ID')=(136) already exists.

声明:

INSERT INTO "TABLE" ("ClassName", "Name", "MemberID", "OtherTabeID", "Value", "LastEdited", "Created", "ID") VALUES ($1, $2, $3, $4, $5, $6, $7, $8),Array) 

我读到这篇文章是因为它从先前确定的值中插入 ID,而不是依赖于 DB 自动递增。对吗?

编辑 2

查看日志,它看起来像 INSERT 首先用 Created 字段完成,然后完成 select 语句以获取 ID:

SELECT last_value FROM "TABLENAME_ID_seq"

然后 UPDATE 完成并保存额外的详细信息。

我觉得这可能是一种竞争条件,会导致保存到不正确的行,但不会导致我目前遇到的情况。理想情况下,任何 INSERT 都会有一个 返回“ID”,用于更新命令。

编辑 3

上述过程与我的堆栈跟踪相反,堆栈跟踪显示插入不仅包括 Created:

pg_query_params(Resource id #154,INSERT INTO "TABLENAME" ("ClassName", "Name", "MemberID", "OTHERTABLEID", "Value", "LastEdited", "Created", "ID") VALUES ($1, $2, $3, $4, $5, $6, $7, $8),Array) 
PostgreSQLConnector.php:200
PostgreSQLConnector->preparedQuery(INSERT INTO "TABLENAME" ("ClassName", "Name", "MemberID", "OTHERTABLEID", "Value", "LastEdited", "Created", "ID") VALUES (?, ?, ?, ?, ?, ?, ?, ?),Array,256)
Database.php:143
SS_Database->{closure}(INSERT INTO "TABLENAME" ("ClassName", "Name", "MemberID", "OTHERTABLEID", "Value", "LastEdited", "Created", "ID") VALUES (?, ?, ?, ?, ?, ?, ?, ?))
Database.php:193
SS_Database->benchmarkQuery(INSERT INTO "TABLENAME" ("ClassName", "Name", "MemberID", "OTHERTABLEID", "Value", "LastEdited", "Created", "ID") VALUES (?, ?, ?, ?, ?, ?, ?, ?),Closure,Array)
Database.php:146
SS_Database->preparedQuery(INSERT INTO "TABLENAME" ("ClassName", "Name", "MemberID", "OTHERTABLEID", "Value", "LastEdited", "Created", "ID") VALUES (?, ?, ?, ?, ?, ?, ?, ?),Array,256)
DB.php:365
DB::prepared_query(INSERT INTO "TABLENAME" ("ClassName", "Name", "MemberID", "OTHERTABLEID", "Value", "LastEdited", "Created", "ID") VALUES (?, ?, ?, ?, ?, ?, ?, ?),Array)
SQLExpression.php:121

最佳答案

文档中的注释已经过时(即使是 2007 年的 SilverStripe 2.1 也有正确的行为)并且文档描述的方法会导致竞争条件。

复杂的是SilverStripe使用了多表继承,SilverStripe在这种情况下所做的是这样的:

  • 插入 SiteTree 表
  • 获取生成的 ID
  • 使用相同的 ID 插入页表(和其他表)

它也可能对具有相同 ID 的 SiteTree 表进行后续更新写入。

不幸的是,这不一定能帮助您解决问题,但至少可以解决问题的一个可能来源。

关于PHP 银条 ORM : Duplicate key value violates unique constraint for DataObject write,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46596456/

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