发布时间:2023-06-13 12:00
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
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数据库踩坑记录的文章就介绍到这了,更多相关Gorm操作Oracle内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
Pandas如何将Timestamp转为datetime类型
受美制裁,俄罗斯 ClickHouse 能否扛起数据库大旗?
【班级健康码统计小工具】—用python写 班级健康码分类存储及统计工具(图形化界面)(包含OCR文字识别)
插件报错:SLF4J: Failed to load class “org.slf4j.impl.StaticLoggerBinder“.解决方案
【从零开始搭建k8s v1.24集群】Chapter 4 通过外部域名访问kubernetes集群服务
Paper Time 回顾|MB2:为自治数据库建立行为模型