中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何使用Gorm操作Oracle數據庫

發布時間:2022-06-14 13:45:07 來源:億速云 閱讀:805 作者:iii 欄目:開發技術

本篇內容主要講解“如何使用Gorm操作Oracle數據庫”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“如何使用Gorm操作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, "\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)
}

測試運行

go run ./main.go

到此,相信大家對“如何使用Gorm操作Oracle數據庫”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

锦屏县| 高州市| 裕民县| 三原县| 工布江达县| 扬州市| 兴安盟| 特克斯县| 同心县| 甘孜| 普陀区| 左权县| 布尔津县| 南部县| 清新县| 科尔| 赣榆县| 沾益县| 庆城县| 庄河市| 福清市| 岳阳县| 金堂县| 普格县| 巫溪县| 渑池县| 齐齐哈尔市| 青州市| 五华县| 开化县| 灌云县| 密云县| 拉萨市| 长垣县| 黑河市| 新疆| 易门县| 东乡县| 彩票| 西昌市| 大石桥市|