使用Gorm操作Oracle数据库踩坑记录

Ophelia ·
更新时间:2024-11-10
· 1428 次阅读

目录

下载依赖

项目结构

编辑go.mod将gorm降级

定义model类型

连接数据库 

测试运行

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, "\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数据库踩坑记录的文章就介绍到这了,更多相关Gorm操作Oracle内容请搜索软件开发网以前的文章或继续浏览下面的相关文章希望大家以后多多支持软件开发网!



gorm oracle数据库 Oracle

需要 登录 后方可回复, 如果你还没有账号请 注册新账号