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

    1. <style id="76ofp"></style>

      <style id="76ofp"></style>
      <rt id="76ofp"></rt>
      <form id="76ofp"><optgroup id="76ofp"></optgroup></form>
      1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構

        手機站
        千鋒教育

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

        千鋒教育

        掃一掃進入千鋒手機站

        領取全套視頻
        千鋒教育

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

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

        詳解gorm打印sql語句

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

        一、啟用gorm的打印sql功能

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

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

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

        二、打印sql語句的格式

        我們可以通過gorm提供的Debug方法來打印sql語句,這樣我們就可以更好地調(diào)試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語句的級別??扇≈涤?b>error,warning,info等。 [message]:打印的sql語句。 [args]:sql語句的參數(shù)列表。

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

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

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

        
        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)來進行條件查詢。在執(zhí)行該語句時,我們可以通過打印sql語句來了解gorm所執(zhí)行的sql語句。

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

        更新操作是數(shù)據(jù)庫中常見的一種操作,gorm中也提供了更新的相關操作。在執(zhí)行更新操作時,我們也可以通過打印sql語句來了解gorm所執(zhí)行的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)來進行更新操作。在執(zhí)行該語句時,我們也可以通過打印sql語句來了解gorm所執(zhí)行的sql語句。

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

        刪除操作是數(shù)據(jù)庫中常見的一種操作,gorm中也提供了刪除的相關操作。在執(zhí)行刪除操作時,我們也可以通過打印sql語句來了解gorm所執(zhí)行的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)來進行刪除操作。在執(zhí)行該語句時,我們也可以通過打印sql語句來了解gorm所執(zhí)行的sql語句。

        聲明:本站稿件版權均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
        10年以上業(yè)內(nèi)強師集結,手把手帶你蛻變精英
        請您保持通訊暢通,專屬學習老師24小時內(nèi)將與您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
        全州县| 林西县| 蒙自县| 泽普县| 香河县| 新巴尔虎左旗| 吴旗县| 惠来县| 宁晋县| 德令哈市| 墨竹工卡县| 洱源县| 永济市| 望都县| 中阳县| 秦安县| 高雄县| 清涧县| 金昌市| 泗阳县| 贵州省| 巴林右旗| 栖霞市| 富裕县| 滁州市| 桐庐县| 梅河口市| 博客| 固镇县| 天长市| 舞钢市| 泰顺县| 台州市| 大丰市| 同仁县| 凭祥市| 安徽省| 绥江县| 台湾省| 衢州市| 灌云县|