golang利用oci8库访问Oracle数据库

栏目: Go · 发布时间: 6年前

内容简介:golang利用oci8库访问Oracle数据库例子。运行结果如下:

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

以上所述就是小编给大家介绍的《golang利用oci8库访问Oracle数据库》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

影响力

影响力

[美] 罗伯特·西奥迪尼 / 陈叙 / 中国人民大学出版社 / 2006-5 / 45.00元

政治家运用影响力来赢得选举,商人运用影响力来兜售商品,推销员运用影响力诱惑你乖乖地把金钱捧上。即使你的朋友和家人,不知不觉之间,也会把影响力用到你的身上。但到底是为什么,当一个要求用不同的方式提出来时,你的反应就会从负面抵抗变成积极合作呢? 在这本书中,心理学家罗伯特·B·西奥迪尼博士为我们解释了为什么有些人极具说服力,而我们总是容易上当受骗。隐藏在冲动地顺从他人行为背后的6大心理秘笈,正是......一起来看看 《影响力》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具