golang xorm日志寫入文件中的操作
golang訪問數(shù)據(jù)庫記錄SQL語句:
使用的包為:
1:github.com/arthurkiller/rollingwriter //寫入日志包
2: github.com/go-xorm/xorm //xorm包
具體實(shí)現(xiàn)為:
package main
import (
"time"
"github.com/arthurkiller/rollingwriter"
_ "github.com/go-sql-driver/mysql"
"github.com/go-xorm/xorm"
)
func main() {
var conn string = "root:123456@tcp(127.0.0.1)/logsdemo?charset=utf-8"
Engine, err := xorm.NewEngine("mysql", conn)
if err != nil {
panic("mysql connect fail")
}
config := rollingwriter.Config{
LogPath: "./logs", //日志路徑
TimeTagFormat: "060102150405", //時(shí)間格式串
FileName: "mysql_exec", //日志文件名
MaxRemain: 3, //配置日志最大存留數(shù)
RollingPolicy: rollingwriter.VolumeRolling, //配置滾動(dòng)策略 norolling t
imerolling volumerolling
RollingTimePattern: "* * * * * *", //配置時(shí)間滾動(dòng)策略
RollingVolumeSize: "1M", //配置截?cái)辔募孪薮笮?
WriterMode: "none",
BufferWriterThershould: 256,
// Compress will compress log file with gzip
Compress: true,
}
writer, err := rollingwriter.NewWriterFromConfig(&config)
if err != nil {
panic(err)
}
var logger *xorm.SimpleLogger = xorm.NewSimpleLogger(writer)
Engine.SetLogger(logger)
Engine.ShowSQL(true)
logger.Info("ts info code")
Engine.Exec("select * from cp_order where id = ? ", 3)
time.Sleep(1 * time.Second)
}
rollingwriter 實(shí)現(xiàn)一個(gè) io.Writer傳入到xorm.NewSimpleLogger 中 在xorm中實(shí)現(xiàn)日志的寫入,在rollingwriter中保存日志到文件中
依賴包:https://github.com/robfig/cron
補(bǔ)充: golang xorm Model 模型文件模板
* Record.go
package models
import (
"fmt"
"github.com/go-xorm/xorm"
"time"
)
// 用戶首次登錄
type FirstLoginRecord struct {
Id int64 `xorm:"not null pk autoincr INT(11)"`
UserID int64 `json:"userid" xorm:"int(11) not null 'userid'"`
IP string `json:"logonip" xorm:"varchar(45) not null 'logonip'"`
CreatedAt time.Time `json:"logontime" xorm:"timestamp not null 'logontime'"`
UpdatedAt time.Time `json:"logofftime" xorm:"timestamp not null 'logofftime'"`
Source int `json:"source" xorm:"tinyint(3) not null"`
IsCharged int `json:"ischargeaccount" xorm:"tinyint(3) unsigned not null 'ischargeaccount'"`
}
func (*FirstLoginRecord) TableName() string {
return "W_UserFirstLogonRec"
}
func (*FirstLoginRecord) DB() *xorm.Engine {
return DbDefault()
}
func (t *FirstLoginRecord) Save() error {
var err error
var engine = t.DB()
if t.Id == 0 {
t.Id, err = engine.Insert(t)
return err
}
var rowsAffected int64
rowsAffected, err = engine.Id(t.Id).Update(t)
fmt.Printf("@table: %s: %d rows affected", t.TableName(), rowsAffected)
return err
}
// 用戶id唯一約束
func (this *FirstLoginRecord) AddDistinct() error {
var err error
var engine = this.DB()
var has bool
var ent = FirstLoginRecord{UserID: this.UserID }
has, err = engine.Get(&ent)
if has {
return nil
}
this.Id, err = engine.Insert(this)
return err
}
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
解析golang 標(biāo)準(zhǔn)庫template的代碼生成方法
這個(gè)項(xiàng)目的自動(dòng)生成代碼都是基于 golang 的標(biāo)準(zhǔn)庫 template 的,所以這篇文章也算是對使用 template 庫的一次總結(jié),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2021-11-11
詳解Go如何基于現(xiàn)有的context創(chuàng)建新的context
在?Golang?中,context?包提供了創(chuàng)建和管理上下文的功能,那么在GO語言中如何基于現(xiàn)有的context創(chuàng)建新的context,下面小編就來和大家詳細(xì)聊聊2024-01-01
golang中http請求的context傳遞到異步任務(wù)的坑及解決
這篇文章主要介紹了golang中http請求的context傳遞到異步任務(wù)的坑及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
Go語言中init函數(shù)與匿名函數(shù)使用淺析
這篇文章主要介紹了Go語言中init函數(shù)與匿名函數(shù)使用淺析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2023-01-01
golang高并發(fā)限流操作 ping / telnet
這篇文章主要介紹了golang高并發(fā)限流操作 ping / telnet,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12
golang開啟mod后import報(bào)紅的簡單解決方案
這篇文章主要給大家介紹了關(guān)于golang開啟mod后import報(bào)紅的簡單解決方案,文中通過圖文將解決的辦法介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2024-01-01

