欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2022年06月14日 11:02:00   作者:Monkey_D_Newdun  
gorm是目前用得最多的go語(yǔ)言orm庫(kù),本文主要介紹了使用Gorm操作Oracle數(shù)據(jù)庫(kù)踩坑記錄,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

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

下載依賴(lài)

go get github.com/cengsin/oracle

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

項(xiàng)目結(jié)構(gòu)

包含main.go和一個(gè)model目錄。

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

編輯go.mod將gorm降級(jí)

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類(lèi)型

假設(shè)數(shù)據(jù)庫(kù)里有張商店信息的表shops,包含ID和店名兩個(gè)字段,編寫(xiě)如下model.go文件。其中結(jié)構(gòu)體方法TableName指定改類(lèi)型對(duì)應(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ù)庫(kù) 

連接名"database/password@127.0.0.1:1521/XE"中database是數(shù)據(jù)庫(kù)名,password是密碼,XE是服務(wù)名。LogLevel為logger.Warn會(huì)打印大多數(shù)sql語(yǔ)句,設(shè)為logger.Error只會(huì)打印運(yùn)行出錯(cuò)的sql語(yǔ)句。

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, //打印級(jí)別
            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)
}

測(cè)試運(yùn)行

go run ./main.go

到此這篇關(guān)于使用Gorm操作Oracle數(shù)據(jù)庫(kù)踩坑記錄的文章就介紹到這了,更多相關(guān)Gorm操作Oracle內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論