[GO] gin 框架gorm下使用logrus记录sql语句

使用gin gorm时 , 默认sql语句是打印在终端的 ,想要记录到文件中 , 可以使用logrus来记录到文件

先把logrus的一些配置做好

package tools

import (
    "fmt"
    "github.com/gin-gonic/gin"
    "github.com/sirupsen/logrus"
    "os"
    "path"
    "time"
)

func Logger() *logrus.Logger {
    now := time.Now()
    logFilePath := ""
    if dir, err := os.Getwd(); err == nil {
        logFilePath = dir + "/logs/"
    }
    if err := os.MkdirAll(logFilePath, 0777); err != nil {
        fmt.Println(err.Error())
    }
    logFileName := now.Format("2006-01-02") + ".log"
    //日志文件
    fileName := path.Join(logFilePath, logFileName)
    if _, err := os.Stat(fileName); err != nil {
        if _, err := os.Create(fileName); err != nil {
            fmt.Println(err.Error())
        }
    }
    //写入文件
    src, err := os.OpenFile(fileName, os.O_APPEND|os.O_WRONLY, os.ModeAppend)
    if err != nil {
        fmt.Println("err", err)
    }

    //实例化
    logger := logrus.New()

    //设置输出
    logger.Out = src

    //设置日志级别
    logger.SetLevel(logrus.DebugLevel)

    //设置日志格式
    logger.SetFormatter(&logrus.TextFormatter{
        TimestampFormat: "2006-01-02 15:04:05",
    })
    return logger
}

在初始化gorm的地方设置logger , 把上面的logger设置进去就可以了

    DB, err = gorm.Open("mysql", dsn)
    if err != nil {
        panic("数据库连接失败!")
    }
    DB.SingularTable(true)
    DB.LogMode(true)
    DB.SetLogger(tools.Logger())
    DB.DB().SetMaxIdleConns(10)
    DB.DB().SetMaxOpenConns(100)

文件中记录的sql

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
使用gingorm框架进行后台开发是指在构建后台应用程序时,采用了gingorm这两个开源框架来帮助实现快速、高效且可靠的开发。 首先,gin是一个轻量级的Web框架,它基于Go语言的net/http包进行封装,并提供了更简洁的API和更快的性能。使用gin框架可以轻松地处理HTTP请求和响应,定义路由和中间件,实现参数绑定和验证,并且具备灵活的扩展性和高并发处理能力。 其次,gorm是一个开源的Go语言ORM(对象关系映射)库,它提供了一种方便的方式来操作数据库,将数据库表和Go语言的结构体进行映射,实现了数据的增删改查操作。使用gorm可以简化数据库操作的代码,提高开发效率,还支持事务处理、查询构造器等高级功能。 使用gingorm框架进行后台开发有以下几个优势: 1. 快速开发:gin框架提供了简洁的API和高性能,可以大大加速开发过程。结合gorm框架的ORM功能,可以方便地进行数据库操作,减少了与数据库交互的代码量,提高了开发效率。 2. 灵活扩展:gin框架支持中间件,在请求的不同阶段插入自定义的处理逻辑,可以实现身份验证、日志记录、错误处理等功能。gorm框架也支持自定义回调函数,可以在数据库操作的前后执行特定的业务逻辑,提供了灵活扩展的能力。 3. 高性能:gin框架底层采用了轻量级的路由引擎和快速的HTTP处理器,以及简洁的API设计,使得性能表现出色。同时,gorm框架通过合理的SQL语句生成和查询优化,能够保证数据库操作的效率。 综上所述,使用gingorm框架进行后台开发可以提供快速、高效、可靠的开发体验,同时拥有灵活的扩展性和良好的性能表现,非常适合构建中小型的后台应用程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值