日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無先后,達(dá)者為師

網(wǎng)站首頁 編程語言 正文

使用Gorm操作Oracle數(shù)據(jù)庫踩坑記錄_Golang

作者:Monkey_D_Newdun ? 更新時間: 2022-08-06 編程語言

gorm是目前用得最多的go語言orm庫,但是目前gorm官方并不支持oracle的驅(qū)動,需要用到第三驅(qū)動,最近有個項目要往oracle寫數(shù)據(jù),記錄一下踩到的坑

下載依賴

go get github.com/cengsin/oracle

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

項目結(jié)構(gòu)

包含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
)

運(yùn)行g(shù)o mod tidy命令生效

定義model類型

假設(shè)數(shù)據(jù)庫里有張商店信息的表shops,包含ID和店名兩個字段,編寫如下model.go文件。其中結(jié)構(gòu)體方法TableName指定改類型對應(yīng)的數(shù)據(jù)表。

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"
}

連接數(shù)據(jù)庫?

連接名"database/password@127.0.0.1:1521/XE"中database是數(shù)據(jù)庫名,password是密碼,XE是服務(wù)名。LogLevel為logger.Warn會打印大多數(shù)sql語句,設(shè)為logger.Error只會打印運(yùn)行出錯的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, "\r\n", 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)
}

測試運(yùn)行

go run ./main.go

原文鏈接:https://blog.csdn.net/Monkey_D_Newdun/article/details/122644097

欄目分類
最近更新