gorm 中 MySQL 错误码映射与主键冲突错误处理
💡
原文中文,约2400字,阅读约需6分钟。
📝
内容提要
在处理`gorm`错误返回时,有一些错误无法直接使用`errors.Is`判断,如主键冲突错误。`gorm.io/driver/mysql`包中的`error_translator`文件将mysql错误码转化为gorm错误码。通过将`Dialector`接口替换为`gorm.io/driver/mysql`包中的`Dialector`,可以使用`errors.Is(err, gorm.ErrDuplicatedKey)`判断插入冲突。
🎯
关键要点
- 处理gorm错误返回时,主键冲突错误无法直接使用errors.Is判断。
- gorm.io/driver/mysql包中的error_translator文件将mysql错误码转化为gorm错误码。
- 通过替换Dialector接口为gorm.io/driver/mysql包中的Dialector,可以使用errors.Is判断插入冲突。
- Translate函数用于将mysql错误转化为gorm错误,主要在AddError函数中使用。
- 在创建gorm.DB时传入gorm.io/driver/mysql的Dialector实例,可以启用mysql错误翻译。
➡️