Oracle数据库是业界领先的关系型数据库之一,它的数据安全性和可靠性备受赞誉。许多企业都在使用Oracle数据库来保存和管理海量的数据。而现在,随着Go语言的兴起和应用,越来越多的人开始探索如何在Go语言中使用Oracle。
Oracle官方提供了适用于Go语言的驱动程序,即“go-oci8”。在本文中,我们将介绍如何安装驱动程序、初始化连接和执行查询、删除和插入操作。
安装Oracle驱动程序
首先,我们需要安装go-oci8驱动程序。该驱动程序通过CGO调用Oracle数据库客户端库,因此在安装之前需要检查是否安装了Oracle客户端库。
立即学习“go语言免费学习笔记(深入)”;
下载安装包:https://oracle.github.io/odpi/doc/installation.html#linux
安装过程很简单,只需解压并运行安装脚本。在完成安装后,就可以安装go-oci8驱动程序了。使用以下命令:
go get -v -u gopkg.in/goracle.v2
初始化连接
驱动程序安装并配置好之后,我们就可以在Go语言中连接Oracle数据库了。可以使用如下代码进行初始化连接:
package main
import (
"database/sql"
"fmt"
_ "gopkg.in/goracle.v2"
)
func main() {
// 格式:[账号]/[密码]@[主机名]:[端口号]/[SID]
connectionString := "scott/tiger@(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=192.168.1.101)(PORT=1521)))(CONNECT_DATA=(SERVICE_NAME=orcl)))"
db, err := sql.Open("goracle", connectionString)
if err != nil {
fmt.Println("Connection Failed : ", err)
return
}
defer db.Close()
fmt.Println("Connected successfully")
}我们需要提供Oracle数据库的连接字符串。连接字符串包含以下内容:用户名、密码、主机(或IP地址)、端口和数据库SID。如果您不熟悉Oracle连接字符串,可以参考Oracle官方文档了解更多信息。
运行上述代码后,如果连接成功,输出“Connected successfully”。
查询操作
下面是一个查询Oracle数据库的示例代码:
package main
import (
"database/sql"
"fmt"
_ "gopkg.in/goracle.v2"
)
func main() {
// Initialize connection
connectionString := "scott/tiger@(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=192.168.1.101)(PORT=1521)))(CONNECT_DATA=(SERVICE_NAME=orcl)))"
db, err := sql.Open("goracle", connectionString)
if err != nil {
fmt.Println("Connection Failed : ", err)
return
}
defer db.Close()
// Execute SQL query
rows, err := db.Query("SELECT EMPNO, ENAME, SAL FROM EMP WHERE DEPTNO = :1", 10)
if err != nil {
fmt.Println("Error executing SQL query: ", err)
return
}
defer rows.Close()
// Process rows
for rows.Next() {
var empno int
var ename string
var sal int
if err := rows.Scan(&empno, &ename, &sal); err != nil {
fmt.Println("Error scanning row: ", err)
return
}
fmt.Println(empno, ename, sal)
}
}此代码查询了雇员表中部门编号为10的所有雇员信息。注意,查询中使用了命名参数。如果您需要使用位置参数,请使用“?”代替“:1”。
更新操作
下面是一个更新Oracle数据库的示例代码:
package main
import (
"database/sql"
"fmt"
_ "gopkg.in/goracle.v2"
)
func main() {
// Initialize connection
connectionString := "scott/tiger@(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=192.168.1.101)(PORT=1521)))(CONNECT_DATA=(SERVICE_NAME=orcl)))"
db, err := sql.Open("goracle", connectionString)
if err != nil {
fmt.Println("Connection Failed : ", err)
return
}
defer db.Close()
// Execute SQL update
result, err := db.Exec("UPDATE EMP SET SAL = :1 WHERE EMPNO = :2", 10000, 7369)
if err != nil {
fmt.Println("Error executing SQL update: ", err)
return
}
rowsAffected, err := result.RowsAffected()
if err != nil {
fmt.Println("Error getting affected rows: ", err)
return
}
fmt.Println("Rows affected:", rowsAffected)
}此代码将雇员表中雇员号为7369的薪水更新为10000。
插入操作
下面是一个在Oracle数据库中插入记录的示例代码:
package main
import (
"database/sql"
"fmt"
_ "gopkg.in/goracle.v2"
)
func main() {
// Initialize connection
connectionString := "scott/tiger@(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=192.168.1.101)(PORT=1521)))(CONNECT_DATA=(SERVICE_NAME=orcl)))"
db, err := sql.Open("goracle", connectionString)
if err != nil {
fmt.Println("Connection Failed : ", err)
return
}
defer db.Close()
// Execute SQL insert
result, err := db.Exec("INSERT INTO EMP (EMPNO, ENAME, JOB, MGR, HIREDATE, SAL, COMM, DEPTNO) VALUES (:1, :2, :3, :4, :5, :6, :7, :8)", 1000, "Test", "Test", 7369, "01-JAN-00", 10000, 0, 10)
if err != nil {
fmt.Println("Error executing SQL insert: ", err)
return
}
rowsAffected, err := result.RowsAffected()
if err != nil {
fmt.Println("Error getting affected rows: ", err)
return
}
fmt.Println("Rows affected:", rowsAffected)
}此代码向雇员表中插入一条新记录。
总结
本文介绍了如何在Go语言中使用Oracle数据库。我们了解了如何初始化连接、执行查询、更新和插入操作。此外,我们还介绍了如何安装必要的驱动程序。如果您的应用程序需要与Oracle数据库进行交互,以上方法将非常有用。
以上就是在Go语言中使用Oracle:完整指南的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号