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

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐