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错误翻译。
🏷️

标签

➡️

继续阅读