go访问oracle数据库,golang利用oci8库访问Oracle数据库 | 码农网
golang利用oci8库访问 Oracle 数据库例子。package mainimport ("fmt""log""database/sql"_ "github.com/mattn/go-oci8")func sqlExec(db *sql.DB, sqlStmt string) error {res, err := db.Exec(sqlStmt)if err != nil {return
golang利用oci8库访问 Oracle 数据库例子。
package main
import (
"fmt"
"log"
"database/sql"
_ "github.com/mattn/go-oci8"
)
func sqlExec(db *sql.DB, sqlStmt string) error {
res, err := db.Exec(sqlStmt)
if err != nil {
return err
}
num, err := res.RowsAffected()
if err != nil {
return err
}
log.Printf("SQL Execute success rows affected %d\n", num)
return nil
}
func sqlQuery(db *sql.DB, sqlStmt string) error {
rows, err := db.Query(sqlStmt)
if err != nil {
return err
}
defer rows.Close()
var n int
for rows.Next() {
var name string
var age int
if err := rows.Scan(&name, &age); err != nil {
return err
}
n ++
log.Printf("row[%d], name=[%s], age=[%d]\n", n, name, age)
}
err = rows.Err()
if err != nil {
return err
}
log.Printf("SQL Query success rows queried %d\n", n)
return nil
}
func main() {
db, err := sql.Open("oci8", fmt.Sprintf("%s/%s@%s", "scott", "tiger", "bej301420.cn.oracle.com:1522/orcl.cn.oracle.com"))
if err != nil {
log.Fatal(err)
}
defer db.Close()
if err := db.Ping(); err != nil {
log.Fatal(err)
}
if err := sqlExec(db, "create table mytest(name varchar2(10), age int, primary key(name))"); err != nil {
log.Fatal(err)
}
if err := sqlExec(db, "insert into mytest(name, age) values('Tom', 20)"); err != nil {
log.Fatal(err)
}
if err := sqlExec(db, "insert into mytest(name, age) values('Jerry', 20)"); err != nil {
log.Fatal(err)
}
if err := sqlQuery(db, "select name, age from mytest"); err != nil {
log.Fatal(err)
}
if err := sqlExec(db, "drop table mytest"); err != nil {
log.Fatal(err)
}
}
运行结果如下:
2019/01/19 12:19:36 SQL Execute success rows affected 0
2019/01/19 12:19:36 SQL Execute success rows affected 1
2019/01/19 12:19:36 SQL Execute success rows affected 1
2019/01/19 12:19:36 row[1], name=[Tom], age=[20]
2019/01/19 12:19:36 row[2], name=[Jerry], age=[20]
2019/01/19 12:19:36 SQL Query success rows queried 2
2019/01/19 12:19:36 SQL Execute success rows affected 0
魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐



所有评论(0)