首頁 > 軟體

使用Gorm操作Oracle資料庫踩坑記錄

2022-06-14 14:02:15

gorm是目前用得最多的go語言orm庫,但是目前gorm官方並不支援oracle的驅動,需要用到第三驅動,最近有個專案要往oracle寫資料,記錄一下踩到的坑

下載依賴

go get github.com/cengsin/oracle

這個驅動與最新的gorm庫不匹配,要將gorm降級到1.21版本,不然會出現“......github.com/cengsin/oracle@v1.0.0/oracle.go:53:59: unknown field 'WithReturning' in struct literal of type callbacks.Config” 錯誤

專案結構

包含main.go和一個model目錄。

|——oracle_test
|    |——model
|        |——model.go
|    |——main.go
|    |——go.mod

編輯go.mod將gorm降級

module oracle_test
 
go 1.16
 
require (
    github.com/cengsin/oracle v1.0.0
    gorm.io/gorm v1.21.16
)

執行go mod tidy命令生效

定義model型別

假設資料庫裡有張商店資訊的表shops,包含ID和店名兩個欄位,編寫如下model.go檔案。其中結構體方法TableName指定改型別對應的資料表。

package model
 
type ShopInfo struct {
    ShopId   string `gorm:"column:SHOPID;not null"`
    ShopName string `gorm:"column:SHOPNAME;not null"`
}
 
func (s *ShopInfo) TableName() string {
    return "shops"
}

連線資料庫 

連線名"database/password@127.0.0.1:1521/XE"中database是資料庫名,password是密碼,XE是服務名。LogLevel為logger.Warn會列印大多數sql語句,設為logger.Error只會列印執行出錯的sql語句。

package main
 
import (
    "fmt"
    "log"
    "os"
    "time"
 
    "oracle_test/model"
 
    "github.com/cengsin/oracle"
    "gorm.io/gorm"
    "gorm.io/gorm/logger"
)
 
func test() {
    log.Println("initial database connect……")
    db, err := gorm.Open(oracle.Open("database/password@127.0.0.1:1521/XE"), &gorm.Config{
        Logger: logger.New(log.New(os.Stdout, "rn", log.LstdFlags), logger.Config{
            SlowThreshold: 1 * time.Millisecond,
            LogLevel:      logger.Warn, //列印級別
            Colorful:      true,
        }),
        //SkipDefaultTransaction: true,
    })
 
    if err != nil {
        log.Fatalln(err)
    }
 
    if e := db.AutoMigrate(&model.ShopInfo{}); e != nil {
        log.Fatalln(e.Error())
    }
    shopInfo := new(model.ShopInfo)
    db.First(shopInfo)
    fmt.Print(*shopInfo)
}

測試執行

go run ./main.go

到此這篇關於使用Gorm操作Oracle資料庫踩坑記錄的文章就介紹到這了,更多相關Gorm操作Oracle內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com