错误处理

在Go语言的应用开发中,特别是在使用GORM与数据库交互时,有效的错误处理是构建稳健应用的基石。 GORM对错误处理的方法,受到其可链式API的影响,需要细致地理解。

基本错误处理

GORM将错误处理集成到其可链式方法语法中。 *gorm.DB实例包含一个Error字段,当发生错误时会被设置。 通常的做法是在执行数据库操作后,特别是在完成方法(Finisher Methods)后,检查这个字段。

在一系列方法之后,检查Error字段是至关重要的:

if err := db.Where("name = ?", "jinzhu").First(&user).Error; err != nil {
// 处理错误...
}

或者

if result := db.Where("name = ?", "jinzhu").First(&user); result.Error != nil {
// 处理错误...
}

ErrRecordNotFound

当使用FirstLastTake等方法未找到记录时,GORM会返回ErrRecordNotFound

err := db.First(&user, 100).Error
if errors.Is(err, gorm.ErrRecordNotFound) {
// 处理未找到记录的错误...
}

处理错误代码

许多数据库返回带有特定代码的错误,这些代码可能表明各种问题,如约束违规、连接问题或语法错误。 在GORM中处理这些错误代码需要解析数据库返回的错误并提取相关代码。

  • 例如:处理MySQL错误代码
import (
"github.com/go-sql-driver/mysql"
"gorm.io/gorm"
)

// ...

result := db.Create(&newRecord)
if result.Error != nil {
if mysqlErr, ok := result.Error.(*mysql.MySQLError); ok {
switch mysqlErr.Number {
case 1062: // MySQL中表示重复条目的代码
// 处理重复条目
// 为其他特定错误代码添加案例
default:
// 处理其他错误
}
} else {
// 处理非MySQL错误或未知错误
}
}

方言转换错误

当启用TranslateError时,GORM可以返回与所使用的数据库方言相关的特定错误,GORM将数据库特有的错误转换为其自己的通用错误。

db, err := gorm.Open(postgres.Open(postgresDSN), &gorm.Config{TranslateError: true})
  • ErrDuplicatedKey

当插入操作违反唯一约束时,会发生此错误:

result := db.Create(&newRecord)
if errors.Is(result.Error, gorm.ErrDuplicatedKey) {
// 处理重复键错误...
}
  • ErrForeignKeyViolated

当违反外键约束时,会遇到此错误:

result := db.Create(&newRecord)
if errors.Is(result.Error, gorm.ErrForeignKeyViolated) {
// 处理外键违规错误...
}

通过启用TranslateError,GORM提供了一种更统一的错误处理方式,将不同数据库的特定错误转换为常见的GORM错误类型。

Errors

要获取GORM可能返回的完整错误列表,请参考GORM文档中的错误列表。

Platinum Sponsors

Gold Sponsors

Platinum Sponsors

Gold Sponsors