GO数据库

Golang 数据库操作

Golang 数据库 MySQL

Golang支持DB操作位于database包下,支持基本CRUD操作、事务和Prepared Statement,本文以MySQL为例。

MySQL驱动安装

使用数据库之前,必须安装相关MySQL数据驱动[1],如果未安装驱动或者没有引入驱动库会报以下错误:

failed to open database: sql: unknown driver "mysql" (forgotten import?)

安装golang mysql driver

go get github.com/go-sql-driver/mysql

代码中还需注册数据库驱动,通过引入空白倒入[2]mysql包来完成

import(

"database/sql"

// 引入数据库驱动注册及初始化

_ "github.com/go-sql-driver/mysql" )

这段空白倒入代码实际执行mysql包的初始化代码,位于%GOPATH%/github.com/go-sql-driver/mysql/driver.go

func init() {

sql.Register("mysql", &MySQLDriver{})

}

准备测试数据

连接MySQL

mysql -uroot -p

选择数据库test

use test

创建测试用的users表和order表,并插入测试数据

#创建user表

DROP TABLE IF EXISTS `order`;

DROP TABLE IF EXISTS `user`;

CREATE TABLE IF NOT EXISTS `user` (`uid` SERIAL PRIMARY KEY, `name`
VARCHAR(20) NOT NULL, `password` VARCHAR(20) NOT NULL) ENGINE=`innodb`,
CHARACTER SET=utf8;

#创建order表

CREATE TABLE IF NOT EXISTS `order`(`oid` SERIAL PRIMARY KEY, `uid`
 BIGINT(20) UNSIGNED NOT NULL, `date` TIMESTAMP NOT NULL DEFAULT
CURRENT_TIMESTAMP, FOREIGN KEY (`uid`) REFERENCES
`user`(`uid`))ENGINE=innodb,CHARACTER SET=utf8;

#插入测试数据

INSERT INTO  `user`(`name`,`password`) VALUES(‘nick‘, ‘nick‘),(‘jacky‘, ‘jacky‘);

INSERT INTO `order`(`uid`) VALUES(1),(2);

连接数据库

连接数据的DSN格式为:

username:[email protected](address)/dbname?param=value

示例代码:

db, err := sql.Open("mysql", "root:[email protected](127.0.0.1:3306)/test?charset=utf8")

if err != nil {

fmt.Println("failed to open database:", err.Error())

return

}

if err := db.Ping(); err != nil {

fmt.Println("%s error ping database: %s", err.Error())

return

}

defer db.Close()

返回的DB对象,实际封装了一个数据库连接池,对于goroutine是线程安全的,可以放心使用。这个数据库连接池由"database/sql"包负责自动创建和回收。连接池的大小可以由SetMaxIdleConns指定。

需要注意的是,创建DB对象成功,并不代表已经成功的连接了数据库,数据库连接只有在真正需要的时候才会被创建。因此如果,在创建DB对象后想验证数据库连接是否有效,可以调用Ping()或者通过

关闭数据库

defer db.Close()

关闭数据库并释放全部已打开的资源。实际上,很少需要进行关闭操作,DB对象实际上长期存活并在所有的goroutine之间共享

CRUD

DB中执行SQL通过Exec和Query方法,查询操作是通过Query完成,它会返回一个sql.Rows的结果集,包含一个游标用来遍历查询结果;Exec方法返回的是sql.Result对象,用于检测操作结果,及被影响记录数

查询

// 获取USERS表中的前十行记录

rows, err := db.Query("SELECT * FROM user")

if err != nil {

fmt.Println("fetech data failed:", err.Error())

return

}

defer rows.Close()

for rows.Next() {

var uid int

var name, password string

rows.Scan(&uid, &name, &password)

fmt.Println("uid:", uid, "name:", name, "password:", password)

}

注意:rows必须进行关闭否则会导致数据库连接无法关闭,长时间运行会导致"too many connections"

插入

// 插入一条新数据

result, err := db.Exec("INSERT INTO `user`(`name`,`password`) VALUES(‘tom‘, ‘tom‘)")

if err != nil {

fmt.Println("insert data failed:", err.Error())

return

}

id, err := result.LastInsertId()

if err != nil {

fmt.Println("fetch last insert id failed:", err.Error())

return

}

fmt.Println("insert new record", id)

更新

// 更新一条数据

result, err = db.Exec("UPDATE `user` SET `password`=? WHERE `name`=?", "tom_new_password", "tom")

if err != nil {

fmt.Println("update data failed:", err.Error())

return

}

num, err := result.RowsAffected()

if err != nil {

fmt.Println("fetch row affected failed:", err.Error())

return

}

fmt.Println("update recors number", num)

删除

// 删除数据

result, err = db.Exec("DELETE FROM `user` WHERE `name`=?", "tom")

if err != nil {

fmt.Println("delete data failed:", err.Error())

return

}

num, err = result.RowsAffected()

if err != nil {

fmt.Println("fetch row affected failed:", err.Error())

return

}

fmt.Println("delete record number", num)

事务支持

sql.Tx用来支持事务处理

// 事务处理

// 完全删除用户编号为2的用户数据

tx, err := db.Begin()

result, err = tx.Exec("DELETE FROM `order` WHERE uid=? ", 2)

if err != nil {

fmt.Println("delete data failed:", err.Error())

return

}

num, err = result.RowsAffected()

if err != nil {

fmt.Println("fetch row affected failed:", err.Error())

return

}

fmt.Println("delete record number", num)

result, err = tx.Exec("DELETE FROM `user` WHERE uid=? ", 2)

if err != nil {

fmt.Println("delete data failed:", err.Error())

return

}

num, err = result.RowsAffected()

if err != nil {

fmt.Println("fetch row affected failed:", err.Error())

return

}

fmt.Println("delete record number", num)

// 根据条件回滚或者提交

// tx.Rollback()

tx.Commit()

Prepared Statement

sql.Stmt支持预备表达式,可以用来优化SQL查询提高性能,减少SQL注入的风险, DB.Prepare()和Tx.Prepare()都提供了对于预备表达式的支持。

// 预备表达式

stmt, err := db.Prepare("DELETE FROM `order` WHERE `oid`=?")

if err != nil {

fmt.Println("fetch row affected failed:", err.Error())

return

}

result, err = stmt.Exec(1)

if err != nil {

fmt.Println("delete data failed:", err.Error())

return

}

num, err = result.RowsAffected()

if err != nil {

fmt.Println("fetch row affected failed:", err.Error())

return

}

fmt.Println("delete record number", num)

时间: 2024-10-16 22:42:30

GO数据库的相关文章

数据库介绍与分类

目录 数据库介绍与分类... 1 1.1 数据库介绍... 2 1.1.1什么是数据库... 2 1.2数据库的种类... 2 1.2.1关系型数据库介绍... 2 1.2.2非关系型数据库介绍... 3 1.3 常用关系型数据库产品介绍... 4 1.3.1 Oracle数据库... 4 1.3.2 MySQL数据库... 5 1.3.3 MariaDB数据库... 5 1.3.4 SqlServer数据库... 6 1.3.5 Access数据库... 6 1.3.6 其他不常用数据库...

win7 64位系统 PB连接oracle数据库出现“oracle library oci.dll could not be loaded”问题的解决方法

今天与大家分享一个自己的学习笔记,希望能给遇到同样问题的人带来帮助. 不知道大家在win7 64位系统下用 PB连接oracle数据库时,是否遇到过“oracle library oci.dll could not be loaded”问题. 今天,在win7 64位系统下用 PB连接oracle数据库时,一直出现上述错误,在百度上找了很久,都没有找到一个完整的解决方案,咨询了很多人,(他们都说是我的PB和oracle没装好,但我装的时候没出现任何问题,一切都很顺利,而且PB和oracle都能正

C#与数据库访问技术总结(八)之ExecuteNonQuery方法

ExecuteNonQuery方法 ExecuteNonQuery方法主要用来更新数据. 通常使用它来执行Update.Insert和Delete语句. 该方法返回值意义如下: 对于Update.Insert和Delete语句,返回值为该命令所影响的行数. 对于所有其他类型的语句,返回值为-1. Command对象通过ExecuteNonQuery方法更新数据库的过程非常简单,需要进行的步骤如下: (1)创建数据库连接. (2)创建Command对象,并指定一个SQL Insert.Update

Oracle 10g通过创建物化视图实现不同数据库间表级别的数据同步

摘自:http://blog.csdn.net/javaee_sunny/article/details/53439980 目录(?)[-] Oracle 10g 物化视图语法如下 实例演示 主要步骤 在A节点创建原表和物化视图日志 在B节点创建连接A节点的远程链接 在B节点处创建目标表和与目标表名称相同的物化视图 在B节点处刷新物化视图 升级采用存储过程定时任务JOB方式定时刷新物化视图 进一步优化 文章更新记录 参考文章 Oracle 10g 物化视图语法如下: create materia

Linux环境下MySQL数据库用SQL语句插入中文显示 “问号或者乱码 ” 问题解决!

问题: 在普通用户权限下执行 mysql -u root -p进入mysql数据库,中间步骤省略,插入数据:insert into 库名(属性)values('汉字'); 会出现如下提示:  Query OK, 1 row affected, 1 warning (0.00 sec)    表明出现错误,没有插入成功,然后执行select * from 表名   就会出现如下的问题:显示的表中出现乱码或者问号. 如图: 解决方案: 首先重新打开一个终端窗口(方便操作),进入root用户模式 执行

WEB页面,WEB环境版本,数据库,整站备份脚本

#!/bin/bash # #WEB页面,WEB环境版本,数据库,整站备份脚本 #当发生某个原因导致整个服务器无法恢复时,利用上面备份的相关数据即可重做一台一样的服务器 date_a=`date +%Y%m%d-%H%M%S` mkdir -p /web_bak/${date_a}/conf &> /dev/null mkdir -p /web_bak/${date_a}/web &> /dev/null mkdir -p /web_bak/${date_a}/mysql &a

MySQL数据库基础知识

day02 MySQL数据库基础知识 一.基础知识概述: 基础决定你这门课程的学习成败!只有学习好这些基础知识以后,你才能真正的运用自如.才能够对数据库有更深入的了解,道路才会越走越远. 二.基础知识: 1.数据库(database):数据库就好比是一个物理的文档柜,一个容器,把我们整理好的数据表等等归纳起来. 创建数据库命令:        create database 数据库名; 2.查看数据库         show databases; 3.打开指定的数据库         use 

PL/SQL developer 连接oracle数据库报错“initialization error could not load oci.dll”

声明:PL/SQL 版本:PL/SQL Developer 9.0.6 (http://files.allroundautomations.com/plsqldev906.exe) 报错提示如图: 原因:PL/SQL只对32位OS进行支持,解决方法是额外加载一个oci.dll文件 解决办法:1.下载OCI.DLL相关库文件.地址: (需注册Oracle账号) http://www.oracle.com/technetwork/topics/winsoft-085727.html ----->  

Linux环境下启动MySQL数据库出现找不到mysqld.sock的解决办法!

问题: 在普通用户权限下运行:mysql -u root -p,回车之后如果会出现如下错误:ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2) 此错误的意思就是没有找到mysqld.sock文件. 解决办法: 首先进入超级用户root权限  sudo -i 或者su - root 切换到默认目录 cd /var/lib/mysql  下查看

Java精品高级课,架构课,java8新特性,P2P金融项目,程序设计,功能设计,数据库设计,第三方支付,web安全,视频教程

36套精品Java架构师,高并发,高性能,高可用,分布式,集群,电商,缓存,性能调优,设计模式,项目实战,P2P金融项目,大型分布式电商实战视频教程 视频课程包含: 高级Java架构师包含:Spring boot.Spring  cloud.Dubbo.Elasticsearch,Redis.ActiveMQ.Nginx.Mycat.Spring.MongoDB.ZeroMQ.Git.Nosql.Jvm.Mecached.Netty.Nio.Mina.java8新特性,P2P金融项目,程序设计,