一、啟用gorm的打印sql功能
默認(rèn)情況下,gorm并沒有開啟打印sql功能。在使用gorm的過(guò)程中,有時(shí)我們需要查看gorm真正執(zhí)行的sql語(yǔ)句,這時(shí)我們就需要開啟gorm的打印sql功能。我們可以通過(guò)gorm提供的LogMode方法來(lái)開啟、關(guān)閉打印sql功能。當(dāng)打印sql功能開啟時(shí),gorm會(huì)將真實(shí)執(zhí)行的sql語(yǔ)句打印到控制臺(tái)中。
//開啟打印sql功能
db.LogMode(true)
//關(guān)閉打印sql功能
db.LogMode(false)
在這里,我們首先需要打開數(shù)據(jù)庫(kù)連接,然后通過(guò)設(shè)置LogMode方法來(lái)開啟、關(guān)閉打印sql功能。開啟打印sql功能后,我們可以看到控制臺(tái)中顯示的sql語(yǔ)句,這樣我們就可以更好地了解gorm執(zhí)行的sql語(yǔ)句。
二、打印sql語(yǔ)句的格式
我們可以通過(guò)gorm提供的Debug方法來(lái)打印sql語(yǔ)句,這樣我們就可以更好地調(diào)試gorm的相關(guān)功能。當(dāng)我們使用Debug方法來(lái)打印sql語(yǔ)句時(shí),gorm會(huì)按照一定的格式來(lái)打印sql語(yǔ)句,方便我們?cè)诳刂婆_(tái)中查看。
gorm打印sql語(yǔ)句的格式如下:
[2019-05-09 22:15:25] [LogPrefix] [Level] [message] [args]
各個(gè)字段的含義如下:
[2019-05-09 22:15:25]:時(shí)間戳,表示打印sql語(yǔ)句的時(shí)間。 [LogPrefix]:日志前綴,表示打印sql語(yǔ)句所屬的模塊。 [Level]:日志級(jí)別,表示打印sql語(yǔ)句的級(jí)別??扇≈涤?b>error,warning,info等。 [message]:打印的sql語(yǔ)句。 [args]:sql語(yǔ)句的參數(shù)列表。通過(guò)以上信息,我們可以更好地理解gorm打印sql語(yǔ)句的格式。
三、打印sql語(yǔ)句的條件查詢
條件查詢是gorm中常見的一種查詢方式。在條件查詢中,我們通常需要打印執(zhí)行的sql語(yǔ)句,以方便我們更好地理解和調(diào)試代碼。下面給出一個(gè)示例:
func main() {
db, err := gorm.Open("mysql", "user:password@(127.0.0.1:3306)/db_name?charset=utf8mb4&parseTime=True&loc=Local")
if err != nil {
panic(err)
}
defer db.Close()
db.LogMode(true) // 打印日志
var users []User
db.Where("age > ?", 30).Find(&users) // 條件查詢
// 通過(guò)gorm提供的Debug方法來(lái)打印sql語(yǔ)句
db.Debug().Where("age > ?", 30).Find(&users)
}
在這個(gè)示例中,我們可以看到我們通過(guò)db.Where("age > ?", 30).Find(&users)來(lái)進(jìn)行條件查詢。在執(zhí)行該語(yǔ)句時(shí),我們可以通過(guò)打印sql語(yǔ)句來(lái)了解gorm所執(zhí)行的sql語(yǔ)句。
四、打印sql語(yǔ)句的更新操作
更新操作是數(shù)據(jù)庫(kù)中常見的一種操作,gorm中也提供了更新的相關(guān)操作。在執(zhí)行更新操作時(shí),我們也可以通過(guò)打印sql語(yǔ)句來(lái)了解gorm所執(zhí)行的sql語(yǔ)句。下面給出一個(gè)示例:
func main() {
db, err := gorm.Open("mysql", "user:password@(127.0.0.1:3306)/db_name?charset=utf8mb4&parseTime=True&loc=Local")
if err != nil {
panic(err)
}
defer db.Close()
db.LogMode(true) // 打印日志
// 更新操作
db.Model(&user).Where("name = ?", "jinzhu").Update("age", 18)
// 通過(guò)gorm提供的Debug方法來(lái)打印sql語(yǔ)句
db.Debug().Model(&user).Where("name = ?", "jinzhu").Update("age", 18)
}
在這個(gè)示例中,我們可以看到我們通過(guò)db.Model(&user).Where("name = ?", "jinzhu").Update("age", 18)來(lái)進(jìn)行更新操作。在執(zhí)行該語(yǔ)句時(shí),我們也可以通過(guò)打印sql語(yǔ)句來(lái)了解gorm所執(zhí)行的sql語(yǔ)句。
五、打印sql語(yǔ)句的刪除操作
刪除操作是數(shù)據(jù)庫(kù)中常見的一種操作,gorm中也提供了刪除的相關(guān)操作。在執(zhí)行刪除操作時(shí),我們也可以通過(guò)打印sql語(yǔ)句來(lái)了解gorm所執(zhí)行的sql語(yǔ)句。下面給出一個(gè)示例:
func main() {
db, err := gorm.Open("mysql", "user:password@(127.0.0.1:3306)/db_name?charset=utf8mb4&parseTime=True&loc=Local")
if err != nil {
panic(err)
}
defer db.Close()
db.LogMode(true) // 打印日志
// 刪除操作
db.Where("age = ?", 20).Delete(&user)
// 通過(guò)gorm提供的Debug方法來(lái)打印sql語(yǔ)句
db.Debug().Where("age = ?", 20).Delete(&user)
}
在這個(gè)示例中,我們可以看到我們通過(guò)db.Where("age = ?", 20).Delete(&user)來(lái)進(jìn)行刪除操作。在執(zhí)行該語(yǔ)句時(shí),我們也可以通過(guò)打印sql語(yǔ)句來(lái)了解gorm所執(zhí)行的sql語(yǔ)句。