一、安装oracle的OCI套件 1、OCI下载链接页面下载(instantclIEnt-basic,instantclIEnt-sdk)
http://www.oracle.com/technetwork/database/features/instant-clIEnt/index-097480.HTML
2、解压缩到同一个目录下,比如:instantclIEnt_12_1
3、root权限移动文件夹到目录 /usr/lib 下
2、root权限执行以下命
@H_502_22@
@H_502_22@ ## 其实直接cp拷贝过去也是一样的
ln /usr/lib/instantclIEnt_12_1/libclntsh.so.12.1 /usr/lib/libclntsh.so
ln /usr/lib/instantclIEnt_12_1/libocci.so.12.1 /usr/lib/libocci.so
ln /usr/lib/instantclIEnt_12_1/libocIEi.so /usr/lib/libocIEi.so
@H_502_22@ ln /usr/lib/instantclIEnt_12_1/libnnz12.so /usr/lib/libnnz12.so @H_502_22@ ##以下两条是为了运行sqlplus命令 @H_502_22@ ln /usr/lib/instantclIEnt_12_1/libsqlplusic.so/usr/lib/libsqlplusic.so @H_502_22@ ln /usr/lib/instantclIEnt_12_1/libsqlplus.so/usr/lib/libsqlplus.so
## 把OCI路径加入系统加载动态库的路径中,并重新加载一次
echo /opt/oracle/instantclIEnt >> /etc/ld.so.conf
ldconfig
3、安装pkg-config
4、在 /usr/lib/pkgconfig 目录下创建文件 oci8.pc,内容如下:
prefix=<replace instantclIEnt path> // 路径改为/usr/lib/instantclIEnt_12_1
libdir=${prefix}
includedir=${prefix}/sdk/include/
name: OCI
Description: Oracle database engine
Version: 12.1 // 版本改为实际的版本号
libs: -L${libdir} -lclntsh
libs.private:
Cflags: -I${includedir}
@H_502_22@ 5、直接运行步骤6会报libaio不存在的错误,安装libaio库 @H_502_22@
@H_502_22@ sudo apt-get install libaio1 @H_502_22@
@H_502_22@ 6、安装go-oci8
@H_502_22@ go get github.com/mattn/go-oci8 @H_502_22@
@H_502_22@ 7、.bashrc 文件中添加系统变量 @H_502_22@
@H_502_22@ # OCI安装目录
@H_502_22@ @H_502_22@ export ORACLE_HOME=/usr/lib/instantclIEnt_12_1 @H_502_22@ #tnsnames.ora 文件地址
@H_502_22@ export TNS_admin=$ORACLE_HOME/network/admin @H_502_22@ # OCI安装目录加入动态库加载路径
@H_502_22@ export LD_liBRARY_PATH=$ORACLE_HOME @H_502_22@ #oci8.pc文件所在路径
@H_502_22@ export PKG_CONfig_PATH=/usr/lib/pkgconfig @H_502_22@
@H_502_22@ 8、tnsnames.ora 文件的内容 @H_502_22@
@H_502_22@ @H_502_22@ awsdb= 二、使用github.com/mattn/go-oci8 *** 作Oracle数据库
(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)
)
)
@H_502_22@ 2.1、增删改查 @H_502_22@总结
@H_502_22@ package main
import (
"database/sql"
"fmt"
_ "github.com/mattn/go-oci8"
"os"
)
@H_502_22@ func main() { @H_502_22@ // 字符集 os.Setenv("NLS_LANG","AMERICAN_AMERICA.AL32UTF8")
// 注意连接字符串的写法
db,err := sql.Open("oci8","awsdb/awsdb@192.168.0.126:1521/awsdb")
if err != nil {
fmt.Println(err)
return
}
// 事务开启
myTx,err:=db.Begin()
myTx.Commit()
@H_502_22@ @H_502_22@ // 查询与结果遍历 rows,err := db.query("select nodeID,nodename from AA_MT_TEST")
if err != nil {
fmt.Println(err)
return
}
for rows.Next() {
var f1 string
var f2 string
rows.Scan(&f1,&f2)
println(f1,f2) // 3.14 foo
}
rows.Close()
_,err = db.Exec("create table foo(bar varchar2(256))")
_,err = db.Exec("drop table foo")
if err != nil {
fmt.Println(err)
return
}
// 关闭数据库连接
db.Close()
@H_502_22@ } @H_502_22@
@H_502_22@ 2.2、执行了一个存储过程、使用结构保存结果 @H_502_22@
@H_502_22@ package main
import (
"database/sql"
_ "github.com/mattn/go-oci8"
"fmt"
"os"
"sync"
)
var (
db *sql.DB
mux sync.Mutex
)
// 多行字符串的定义
var usertablesql string = `
BEGIN
BEGIN
EXECUTE IMMEDIATE 'DROP table user_profile';
EXCEPTION
WHEN OTHERS THEN
IF sqlCODE != -942 THEN
RAISE;
END IF;
END;
EXECUTE IMMEDIATE 'CREATE table user_profile (ID int PRIMARY KEY,name VARCHAR(20) NOT NulL,created VARCHAR(20) NOT NulL)';
END;
`
@H_502_22@ func init() { @H_502_22@ // 锁 mux.Lock()
defer mux.Unlock()
os.Setenv("NLS_LANG","AMERICAN_AMERICA.ZHS16GBK")
// check
if db != nil {
return
}
// open
oracledb,"awsdb/awsdb@192.168.0.126:1521/awsdb") checkErr(err) // new db db = oracledb // create database table _,err = db.Exec(usertablesql) checkErr(err) } func checkErr(err error) { if err != nil { panic("oracle err:" + err.Error()) } return } func main() { // insert insertsql := `insert into user_profile(ID,name,created) values(1,'viney','2013-03-06')` _,err := db.Exec(insertsql) checkErr(err) // update updatesql := `update user_profile set name='中国人' where ID=1` _,err = db.Exec(updatesql) checkErr(err) // select querysql := `select * from user_profile where ID=1` rows,err := db.query(querysql) type user struct { ID int // 这个地方改成string才不会报错,但是我创建数据库是int类型 name string created string } var u = &user{} for rows.Next() { err = rows.Scan( &u.ID,&u.name,&u.created) checkErr(err) } rows.Close() fmt.Println(*u) // delete deletesql := `delete from user_profile where ID=1` _,err = db.Exec(deletesql) checkErr(err) db.Close() }
以上是内存溢出为你收集整理的GOLANG 在 UBUNTU 14.04 上使用 Oracle 数据库全部内容,希望文章能够帮你解决GOLANG 在 UBUNTU 14.04 上使用 Oracle 数据库所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)