麻豆黑色丝袜jk制服福利网站-麻豆精品传媒视频观看-麻豆精品传媒一二三区在线视频-麻豆精选传媒4区2021-在线视频99-在线视频a

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > 詳解gorm打印sql語句

詳解gorm打印sql語句

來源:千鋒教育
發布人:xqq
時間: 2023-11-22 20:37:59 1700656679

一、啟用gorm的打印sql功能

默認情況下,gorm并沒有開啟打印sql功能。在使用gorm的過程中,有時我們需要查看gorm真正執行的sql語句,這時我們就需要開啟gorm的打印sql功能。我們可以通過gorm提供的LogMode方法來開啟、關閉打印sql功能。當打印sql功能開啟時,gorm會將真實執行的sql語句打印到控制臺中。


//開啟打印sql功能
db.LogMode(true)
//關閉打印sql功能
db.LogMode(false)

在這里,我們首先需要打開數據庫連接,然后通過設置LogMode方法來開啟、關閉打印sql功能。開啟打印sql功能后,我們可以看到控制臺中顯示的sql語句,這樣我們就可以更好地了解gorm執行的sql語句。

二、打印sql語句的格式

我們可以通過gorm提供的Debug方法來打印sql語句,這樣我們就可以更好地調試gorm的相關功能。當我們使用Debug方法來打印sql語句時,gorm會按照一定的格式來打印sql語句,方便我們在控制臺中查看。

gorm打印sql語句的格式如下:


[2019-05-09 22:15:25]  [LogPrefix]  [Level]  [message]  [args]

各個字段的含義如下:

[2019-05-09 22:15:25]:時間戳,表示打印sql語句的時間。 [LogPrefix]:日志前綴,表示打印sql語句所屬的模塊。 [Level]:日志級別,表示打印sql語句的級別。可取值有error,warning,info等。 [message]:打印的sql語句。 [args]:sql語句的參數列表。

通過以上信息,我們可以更好地理解gorm打印sql語句的格式。

三、打印sql語句的條件查詢

條件查詢是gorm中常見的一種查詢方式。在條件查詢中,我們通常需要打印執行的sql語句,以方便我們更好地理解和調試代碼。下面給出一個示例:


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) // 條件查詢

    // 通過gorm提供的Debug方法來打印sql語句
    db.Debug().Where("age > ?", 30).Find(&users)
}

在這個示例中,我們可以看到我們通過db.Where("age > ?", 30).Find(&users)來進行條件查詢。在執行該語句時,我們可以通過打印sql語句來了解gorm所執行的sql語句。

四、打印sql語句的更新操作

更新操作是數據庫中常見的一種操作,gorm中也提供了更新的相關操作。在執行更新操作時,我們也可以通過打印sql語句來了解gorm所執行的sql語句。下面給出一個示例:


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)

    // 通過gorm提供的Debug方法來打印sql語句
    db.Debug().Model(&user).Where("name = ?", "jinzhu").Update("age", 18)
}

在這個示例中,我們可以看到我們通過db.Model(&user).Where("name = ?", "jinzhu").Update("age", 18)來進行更新操作。在執行該語句時,我們也可以通過打印sql語句來了解gorm所執行的sql語句。

五、打印sql語句的刪除操作

刪除操作是數據庫中常見的一種操作,gorm中也提供了刪除的相關操作。在執行刪除操作時,我們也可以通過打印sql語句來了解gorm所執行的sql語句。下面給出一個示例:


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)

    // 通過gorm提供的Debug方法來打印sql語句
    db.Debug().Where("age = ?", 20).Delete(&user)
}

在這個示例中,我們可以看到我們通過db.Where("age = ?", 20).Delete(&user)來進行刪除操作。在執行該語句時,我們也可以通過打印sql語句來了解gorm所執行的sql語句。

聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
主站蜘蛛池模板: 国产破处在线| 久久国产免费观看精品3| 欧美理伦| 好吊妞免费视频| 国色天香社区高清在线观看| 色噜噜狠狠色综合日日| 野花日本免费观看高清电影8| mm131美女做爽爽爱视频| 老少交欧美另类| 久久精品国产亚洲欧美| 国产精品9999久久久久仙踪林| 精品久久久久国产免费| 久久99精品九九九久久婷婷| 国产精品亚洲精品日韩动图| а√在线地址最新版| 色噜噜狠狠色综合日日| 韩国三级一区| 天天想你在线视频免费观看| 午夜高清视频在线观看| 国产精品爽爽va在线观看网站 | 在线中文字幕第一页| 国产视频一区二| 老张和老李互相换女| 波多野结衣www| 高清欧美一区二区三区| 一级毛片看**在线视频| 亚洲有码转帖| 午夜爽视频| 免费人成在线观看视频播放| 么公的又大又深又硬想要 | 在线成人国产| 88国产精品欧美一区二区三区| 国产网曝门| 小兔子被蛇用两根是什么小说| 日本高清免费不卡在线播放| 美国式禁忌在完整有限中字| 无翼少无翼恶女漫画全彩app| 午夜电影院理论片8888琪琪| 美国式性禁忌| 成a人片亚洲日本久久| 男朋友吃我的妹妹怎么办呢|