设为首页 收藏本站
查看: 1353|回复: 0

[经验分享] golang连接orcale

[复制链接]

尚未签到

发表于 2018-9-19 12:29:47 | 显示全部楼层 |阅读模式
  使用glang有一段时间了,最开始其实并不太喜欢他的语法,但是后来熟悉之后发现用起来还挺爽的。之前数据库一直使用mysql,连接起来没有什么问题,github上有很多完善的驱动,所以以为连接其他数据库也应该没什么问题,近日听说其连接orcale比较麻烦,所以就试了试。
  之所以连接orcale比较麻烦是因为orcale并没有提供golang的驱动,所以并不能像java那样引入个驱动包就能连接,也不能像mysql之类的开源数据库可以自己实现驱动。不过正所谓天无绝人之路,既然纯go实现不了,那么还可以用cgo实现,c语言总该支持了吧。
  
    网上有很多方法,不过都是使用oci实现的,这里我们使用go-oci8(https://github.com/wendal/go-oci8)



一、安装MinGW

  
    首先我们先来配置环境,由于cgo需要gcc支持,所以需要配置gcc环境,如果是linux下一般可以跳过该步骤,win下则需要自己安装了,这里我们使用MinGW,可以到官网现下载,不过官网直接提供的安装程序需要安装时联网下载,很可能会失败,所以几经搜索之后找到如下网址:




  • MinGW下载地址相关:http://blog.csdn.net/mecho/article/details/24305369
  
    里边详细介绍了MinGW各版本的不同,可根据自己情况下载,由于我是64位,这里下载64位的POSIX版本
  
    具体的安装过程就不费话了,直接解压即可。


二、安装OCI

  
    由于没有对应驱动包,我们不能直接连接,所以需要通过orcale提供OCI接口(有点像odbc),里边包含需要的类库。下载直接官网就行,找到系统对应版本:




  • oci下载地址:http://www.oracle.com/technetwork/topics/winsoft-085727.html
  
    需下载Basic和SDK,下载后解压Basic到instantclient_11_1,然后将SDK解压到instantclient_11_1\sdk下。
  
    在instantclient_11_1下建立\network\admin\目录,添加tnsnames.ora(这个就不解释了吧),内容根据自己的orcale设置。


三、配置go-oci8

  直接go get github.com/wendal/go-oci8(报错不用管),然后到go\src\github.com/wendal\go-oci8\windows下,将pkg-config.exe拷贝到MinGW\bin下,将oci8.pc复制到MinGW\lib\pkg-config\下,并且编辑oci8.pc:
  

# Package Information for pkg-config  
prefix=修改为instantclient_11_1目录,如F:/dev/instantclient_11_1
  
exec_prefix=修改为instantclient_11_1目录,如F:/dev/instantclient_11_1
  
libdir=${exec_prefix}
  
includedir=${prefix}/sdk/include/
  

  
Name: OCI
  
Description: Oracle database engine
  
Version: 11.2
  
Libs: -L${libdir} -loci
  
Libs.private:
  
Cflags: -I${includedir}
  


四、设置环境变量
  环境变量path下添加instantclient_11_1和mingw\bin的路径
  
    添加PKG_CONFIG_PATH=C:\mingw\lib\pkg-config
  
    添加TNS_ADMIN=F:\dev\instantclient_11_1\network\admin\


五、测试

  在此执行go get github.com/wendal/go-oci8,如果没错那说明大功告成。具体测试代码见github.com\wendal\go-oci8\example下的oracle.go,注意要把里边import中的mattn改成wendal。一下是我的代码:
  

package main  

import (  

"database/sql"  
_
"github.com/wendal/go-oci8"  
"log"
  
)
  
func query() {
  
// 为log添加短文件名,方便查看行数
  
log.SetFlags(log.Lshortfile | log.LstdFlags)
  
// 用户名/密码@实例名  跟sqlplus的conn命令类似
  
db, err := sql.Open("oci8", "username/pwd@ORCL")
  
if err != nil {
  
log.Fatal(err)
  
}
  
defer db.Close()
  

  
rows, err := db.Query("select name from FUB_B")
  
if err != nil {
  
log.Fatal(err)
  
}
  

  
for rows.Next() {
  
var name string
  
rows.Scan(&name)
  
log.Printf("Name = %s, len=%d", name, len(name))
  
}
  
rows.Close()
  
}
  

  
func update() {
  
// 为log添加短文件名,方便查看行数
  
log.SetFlags(log.Lshortfile | log.LstdFlags)
  
// 用户名/密码@实例名  跟sqlplus的conn命令类似
  
db, err := sql.Open("oci8", "username/pwd@ORCL")
  
if err != nil {
  
log.Fatal(err)
  
}
  
defer db.Close()
  

  
stmt, _ := db.Prepare(`UPDATE FUB_B set name ='cnm'`)
  
result, err := stmt.Exec()
  
if err != nil {
  
log.Fatal(err)
  
}
  
count, _ := result.RowsAffected()
  
log.Printf("result count:%d", count)
  
}
  

  
func main() {
  
update()
  
}
  




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-594267-1-1.html 上篇帖子: 老虞要学GoLang 下篇帖子: Golang哲学思想
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表