久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > 詳解gorm打印sql語(yǔ)句

詳解gorm打印sql語(yǔ)句

來(lái)源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-11-22 20:37:59 1700656679

一、啟用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ǔ)句。

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
C++ sort頭文件詳解

一、sort頭文件介紹C++ sort頭文件是C++標(biāo)準(zhǔn)庫(kù)中的一個(gè)重要頭文件,用來(lái)排序(主要是升序)數(shù)組或序列。通過(guò)對(duì)sort函數(shù)的調(diào)用,C++ sort頭文件...詳情>>

2023-11-22 22:15:11
如何清除svchost病毒

一、了解svchost病毒svchost病毒是一種比較常見的惡意軟件,它通過(guò)偽裝成系統(tǒng)進(jìn)程的方式進(jìn)行隱藏,進(jìn)而竊取用戶的個(gè)人信息和系統(tǒng)信息。而且svch...詳情>>

2023-11-22 22:04:23
Photoscan建模教程

一、環(huán)境搭建在使用Photoscan進(jìn)行建模前,需要先安裝好相關(guān)軟件并進(jìn)行配置。首先,需要安裝好Photoscan軟件,可以從官網(wǎng)下載。安裝完成后,需要...詳情>>

2023-11-22 22:00:47
LayUI表格重載用法介紹

一、表格重載的基本概念LayUI表格是前后端分離情況下傳統(tǒng)的業(yè)務(wù)前端頁(yè)面非常常見的一種組件。一個(gè)表格的數(shù)據(jù)是以一定格式結(jié)構(gòu)的Json數(shù)據(jù),表格...詳情>>

2023-11-22 21:53:35
torch.add函數(shù)詳解

一、torch.add()介紹torch.add是PyTorch中重要的數(shù)學(xué)函數(shù)之一,該函數(shù)用于將兩個(gè)張量的元素相加。使用add可以用于在模型的正向傳播過(guò)程中將兩個(gè)...詳情>>

2023-11-22 21:28:23