您好,登錄后才能下訂單哦!
本篇內容主要講解“如何使用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
module oracle_test go 1.16 require ( github.com/cengsin/oracle v1.0.0 gorm.io/gorm v1.21.16 )
運行go mod tidy命令生效
假設數據庫里有張商店信息的表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數據庫”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。