环境:
这是我的(简化的)域类
class Cluster {
String name
String slug
static constraints = {
name blank: false, unique: true
slug blank: false, unique: true, validator: { return it == it.toLowerCase().replaceAll(/[^\w-]/, '') }
}
static mapping = {
collection 'Cluster'
id name: 'slug'
}
}
如您所见,我映射了
slug
属性为文档_id
.我可以成功地添加一个文档
Cluster cluster = new Cluster(name: 'Dallas', slug: 'dal05')
cluster.insert(failOnError: true)
一切正常。但是如果我执行相同的
insert
再次命令我得到一个重复的键异常:com.mongodb.MongoBulkWriteException: Bulk write operation error on server localhost:27017. Write errors: [BulkWriteError{index=0, code=11000, message='E11000 duplicate key error index: db.Cluster.$_id_ dup key: { : "dal05" }', details={ }}]
虽然我会期待一个简单的验证错误,说明重复的 key 。
然而,虽然
unique
约束失败,其他两个验证被正确触发(空值或例如'Dal05' - 不允许大写字母-)。没有在
slug
上映射 id属性,所以保留默认值 assigned
逻辑上,一切都按预期进行。我错过了什么吗?提前致谢!
最佳答案
看来这实际上是一个错误,计划在即将发布的 GORM 版本 6.1.5 中修复。
引用。问题:https://github.com/grails/grails-data-mapping/issues/951
关于mongodb - 用于 MongoDB 的 Grails 3 和 FORM 6 - 重复键错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44004981/