亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Go使用XORM操作MySQL的陷阱盤點分析

 更新時間:2023年11月30日 11:26:58   作者:frank  
在?Go?語言開發(fā)中,大家為了方便,通常會選擇使用?ORM?操作數(shù)據(jù)庫,比如使用?XORM?或?GORM?操作?MySQL,本文我們來介紹一下使用?XORM[3]?操作?MySQL?可能會遇到的陷阱

使用 XORM 操作 MySQL 的陷阱

雖然使用 ORM 操作 MySQL 比直接使用標準庫 `sql`[1] 和三方 MySQL 數(shù)據(jù)庫驅動包[2]操作 MySQL 更加方便,但是也會遇到一些陷阱。

類型零值

在 Golang 中,每個數(shù)據(jù)類型都有各自的類型零值,比如 int 的零值是 0,string 的零值是 ''等。

示例代碼:

package main
import (
 "fmt"
 _ "github.com/go-sql-driver/mysql"
 "xorm.io/xorm"
)
func main() {
 // 創(chuàng)建 Engine
 engine, err := xorm.NewEngine("mysql", "root:root@/example?charset=utf8")
 defer func() {
  err = engine.Close()
  if err != nil {
   fmt.Printf("engine close err=%v\n", err)
   return
  }
 }()
 if err != nil {
  fmt.Printf("init xorm engine fail, err=%v\n", err)
  return
 }
 // 更新數(shù)據(jù)
 example := &Example{
  Title: "go",
  View:  0,
 }
 condi := &Example{
  Id: 2,
 }
 affected, err := engine.Update(example, condi)
 if err != nil {
  fmt.Printf("Update err=%v\n", err)
  return
 }
 fmt.Printf("affected=%d\n", affected)
}
type Example struct {
 Id      int    `json:"id" form:"id"`
 Title   string `json:"title" form:"title"`
 View    int    `json:"view" form:"view"`
 Created int    `json:"created" form:"created" xorm:"created"`
 Updated int    `json:"updated" form:"updated" xorm:"updated"`
}

閱讀上面這段代碼,我們可以發(fā)現(xiàn)示例代碼中將 id=2 的數(shù)據(jù) view 字段更新為 0,因為 0 是 int 的類型零值,XORM 的 Update 方法會自動忽略類型零值,所以該數(shù)據(jù) view 字段的值沒有更改。

但是,在實際項目開發(fā)中,我們可能需要將某個字段的值更新為該字段類型的類型零值,此時我們該怎么操作呢?

affected, err := engine.Cols("title", "view").Update(example, condi)

我們可以使用 Cols() 方法,指定需要更新的字段,這樣即便需要更新字段的值是該字段類型的類型零值,也可以正常更改。

提示:建議在設計數(shù)據(jù)庫表時,字段的值盡量使用非類型零值。

自增 id

在插入數(shù)據(jù)時,我們可能需要返回自增 id,我們先看一段代碼:

// 插入數(shù)據(jù)
example := &Example{
  Title: "PHP",
  View:  90,
}
affected, err := engine.Insert(example)
if err != nil {
  fmt.Printf("Insert err=%v\n", err)
  return
}
fmt.Printf("affected=%v\n", affected)

閱讀上面這段代碼,我們插入一條數(shù)據(jù),返回結果是影響行數(shù)和錯誤信息,而不是直接返回該條數(shù)據(jù)的自增 id。

可能有些讀者朋友們會接著使用查詢方法,查詢最新一條數(shù)據(jù)的 id,在并發(fā)請求數(shù)低的場景中,該方法是可以查到新插入數(shù)據(jù)的自增 id。

但是在并發(fā)請求數(shù)高的場景中,該方法查到的最新一條數(shù)據(jù)的 id,未必是我們剛插入的數(shù)據(jù)的自增 id。

id := example.Id
fmt.Printf("affected=%v || id=%d\n", affected, id)

閱讀上面這段代碼,我們想要獲取新插入數(shù)據(jù)的自增 id,直接 example.Id 即可獲取,但是前提條件是結構體中,id 字段使用 xorm:"autoincr" 標簽。

更新 created 字段

我們在結構體中,使用標簽 xorm:created 和 xorm:updated 即可自動插入當前時間。

但是,使用 xorm:created 標簽的字段,只有在第一次插入數(shù)據(jù)時寫入當前時間,此后將不再會更改;使用 xorm:updated 標簽的字段,在第一次插入數(shù)據(jù)時寫入當前時間,此后每次 Update 操作,時間都會更改。

如果我們的業(yè)務需求是需要更改使用 xorm:created 標簽的字段,可以做到嗎?

// 更改數(shù)據(jù)
example := &Example{
  Title: "JavaScript",
  View:  98,
}
condi := &Example{
  Id: 2,
}
affected, err := engine.Update(example, condi)
if err != nil {
  fmt.Printf("Update err=%v\n", err)
  return
}
fmt.Printf("affected=%d\n", affected)

閱讀上面這段代碼,我們發(fā)現(xiàn)執(zhí)行 Update 方法之后,使用 xorm:updated 標簽的字段的值被更改,而使用 xorm:created 標簽的字段的值沒被更改。

我們換一種更新數(shù)據(jù)的方式,代碼如下:

// 更改數(shù)據(jù)
sql := "UPDATE example SET title=?, view=?, created=? WHERE id=?"
res, err := engine.Exec(sql, "Python", 60, time.Now().Unix(), 2)
if err != nil {
  fmt.Printf("Update err=%v\n", err)
  return
}
affected, err := res.RowsAffected()
if err != nil {
  fmt.Printf("RowsAffected err=%v\n", err)
  return
}
fmt.Printf("affected=%d\n", affected)

閱讀上面這段代碼,我們可以發(fā)現(xiàn)使用 Exec 方法執(zhí)行原生 SQL 可以滿足我們的需求。

總結

本文我們介紹了使用 XORM 操作 MySQL 時,新手讀者朋友們可能會遇到的陷阱,希望可以給大家?guī)硪恍椭?,更多關于Go XORM操作MySQL的資料請關注腳本之家其它相關文章!

相關文章

  • 詳解Go語言中獲取文件路徑的不同方法與應用場景

    詳解Go語言中獲取文件路徑的不同方法與應用場景

    在使用?Go?開發(fā)項目時,估計有不少人遇到過無法正確處理文件路徑的問題,本文將嘗試從簡單到復雜,詳細介紹?Go?中獲取路徑的不同方法及應用場景,希望對大家有所幫助
    2024-02-02
  • 在goland中配置gofmt的操作

    在goland中配置gofmt的操作

    這篇文章主要介紹了在goland中配置gofmt的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • go?zero微服務實戰(zhàn)處理每秒上萬次的下單請求

    go?zero微服務實戰(zhàn)處理每秒上萬次的下單請求

    這篇文章主要為大家介紹了go?zero微服務實戰(zhàn)處理每秒上萬次的下單請求示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • Go語言利用time.After實現(xiàn)超時控制的方法詳解

    Go語言利用time.After實現(xiàn)超時控制的方法詳解

    最近在學習golang,所以下面這篇文章主要給大家介紹了關于Go語言利用time.After實現(xiàn)超時控制的相關資料,文中通過示例介紹的非常詳細,需要的朋友可以參考借鑒,下面隨著小編來一起學習學習吧
    2018-08-08
  • 詳解Golang中interface接口的原理和使用技巧

    詳解Golang中interface接口的原理和使用技巧

    interface?接口在?Go?語言里面的地位非常重要,是一個非常重要的數(shù)據(jù)結構。本文主要介紹了Golang中interface接口的原理和使用技巧,希望對大家有所幫助
    2022-11-11
  • Golang 實現(xiàn)Thrift客戶端連接池方式

    Golang 實現(xiàn)Thrift客戶端連接池方式

    這篇文章主要介紹了Golang 實現(xiàn)Thrift客戶端連接池方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • 使用Go語言編寫一個極簡版的容器Container

    使用Go語言編寫一個極簡版的容器Container

    Docker作為一種流行的容器化技術,對于每一個程序開發(fā)者而言都具有重要性和必要性,因為容器化相關技術的普及大大簡化了開發(fā)環(huán)境配置、更好的隔離性和更高的安全性,對于部署項目和團隊協(xié)作而言也更加方便,本文將嘗試使用Go語言編寫一個極簡版的容器
    2023-10-10
  • 淺談golang fasthttp踩坑經(jīng)驗

    淺談golang fasthttp踩坑經(jīng)驗

    本文主要介紹了golang fasthttp踩坑經(jīng)驗,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • Golang Map簡介以及底層原理

    Golang Map簡介以及底層原理

    這篇文章主要介紹了Golang Map簡介以及底層原理的相關資料,Go語言提供的map是一種鍵值對存儲結構,支持基本操作如len、delete等,map是非線程安全的,可用sync.Mutex確保并發(fā)安全,為高效查找和插入,需要的朋友可以參考下
    2024-10-10
  • Golang對struct字段重新排序優(yōu)化數(shù)據(jù)結構性能實踐

    Golang對struct字段重新排序優(yōu)化數(shù)據(jù)結構性能實踐

    這篇文章主要為大家介紹了Golang對struct字段重新排序優(yōu)化數(shù)據(jù)結構性能實踐,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-12-12

最新評論