golang 连接oracle 11g数据库

1.安装Oracle的OCI套件(确定系统是否安装gcc和libaio1) 下载地址:

Instant Client for Linux x86-64 (64-bit)

2.下载版本实例

instantclient-basic-linux.x64-12.2.0.1.0.zip

instantclient-sdk-linux.x64-12.2.0.1.0.zip

instantclient-sqlplus-linux.x64-12.2.0.1.0.zip

3.按顺序解压到同一目录

11g: instantclient_12_2

4.root权限移动文件夹到目录 /usr/lib 下

5.root权限执行以下命令 11g:

ln /usr/lib/instantclient_12_2/libclntsh.so.12.1 /usr/lib/libclntsh.so

ln /usr/lib/instantclient_12_2/libocci.so.12.1 /usr/lib/libocci.so

ln /usr/lib/instantclient_12_2/libociei.so /usr/lib/libociei.so

ln /usr/lib/instantclient_12_2/libnnz12.so /usr/lib/libnnz12.so

以下两条是为了运行sqlplus

ln /usr/lib/instantclient_12_2/libsqlplusic.so /usr/lib/libsqlplusic.so

ln /usr/lib/instantclient_12_2/libsqlplus.so /usr/lib/libsqlplus.so

6.把 OCI路径加入系统加载动态库的路径中,并重新加载一次 11g:

echo /usr/lib/instantclient_12_2 >> /etc/ld.so.conf ldconfig

7.安装pkg-config

8.在/usr/lib 目录下创建pkgconfig 目录

9..在/usr/lib/pkgconfig 目录下创建文件oci8.pc,内容如下 11g:

prefix= /usr/lib/instantclient_12_2

libdir=${prefix}

includedir=${prefix}/sdk/include/

Name: oci8

Description: Oracle database engine

Version: 12.2

Libs: -L${libdir} -lclntsh

Libs.private:

Cflags: -I${includedir}

10.在~/.bashrc 文件中添加环境变量 11g:

OCI安装目录

export ORACLE_HOME=/usr/lib/instantclient_12_2

#tnsnames.ora 文件地址需要创建network和admin目录(此步骤也可以省略)

#export TNS_ADMIN=$ORACLE_HOME/network/admin

#OCI安装目录加入动态库加载路径

export LD_LIBRARY_PATH=$ORACLE_HOME

#oci8.pc文件所在路径

export PKG_CONFIG_PATH=/usr/lib/pkgconfig

11.tnsnames.ora 文件的内容(如果export TNS_ADMIN=$ORACLE_HOME/network/admin 没有设置则不需操作此步骤)内容如下:

awsdb=

(DESCRIPTION =

(ADDRESS_LIST =

(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.0.126)(PORT = 1521))

)

(CONNECT_DATA =

(SERVICE_NAME = awsdb)

)

)

EXTPROC_CONNECTION_DATA =

(DESCRIPTION =

(ADDRESS_LIST =

(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1))

)

(CONNECT_DATA =

(SID = PLSExtProc)

(PRESENTATION = RO)

)

)

12.安装go-oci8 (准备条件为:安装了git和go语言运行环境)

可连接网络:

go get github.com/mattn/go-oci8

不可连接网络:

13.在Gopath 下创建sql.go 测试连接文件

Sql.go

package main

import (

"database/sql"

"fmt"

_ "github.com/mattn/go-oci8"

"log"

"os"

)

func main() {

if len(os.Args) != 2 {

log.Fatalln(os.Args[0] + " user/password@host:port/sid")

}

db, err := sql.Open("oci8", os.Args[1])

if err != nil {

log.Fatalln(err)

}

defer db.Close()

rows, err := db.Query("select user from dual")

if err != nil {

log.Fatalln(err)

}

defer rows.Close()

for rows.Next() {

var data string

rows.Scan(&data)

fmt.Println(data)

}

if err = rows.Err(); err != nil {

log.Fatalln(err)

}

}

14.编译并运行测试文件

编译:go build --o sql sql.go

运行:./sql system/oracle@192.168.0.150:1521/testpdb

错误提示处理

1 error while loading shared libraries: libaio.so.1: cannot open shared object file: No such file or directory

sudo yum install libaio

相关推荐
一个有梦有戏的人3 小时前
软考架构师:数据库的范式
数据库·oracle
朱小弟cs64 小时前
Orange的运维学习日记--41.Ansible基础入门
linux·运维·学习·ci/cd·自动化·ansible·devops
CIb0la5 小时前
kali linux 2025.2安装WPS并设置无报错的详细步骤
linux·运维·wps
醉方休6 小时前
Node.js 精选:50 款文件处理与开发环境工具库
linux·运维·node.js
代码老y7 小时前
从裸机到云原生:Linux 操作系统实战进阶的“四维跃迁”
linux·运维·云原生
菜菜子爱学习7 小时前
Nginx学习笔记(二)——环境准备(VMware CentOS版)
笔记·学习·nginx·centos·运维开发
CMCST7 小时前
CentOS 7.9 升级 GLibc 2.34
linux·运维·centos
xiep14383335108 小时前
Rocky Linux 10 部署 Kafka 集群
linux·运维·kafka
笨鸟要努力11 小时前
Ubuntu 全盘备份
linux·运维·ubuntu
ChironW11 小时前
Ubuntu 22.04 离线环境下完整安装 Anaconda、CUDA 12.1、NVIDIA 驱动及 cuDNN 8.9.3 教程
linux·运维·人工智能·深度学习·yolo·ubuntu