go 通过sql操作mysql

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: go 通过sql操作mysql

前言

表格

结果

go代码

package main

import (
  "database/sql"
  "fmt"
  "time"

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

var db *sql.DB   //全局变量client

func initMySQL() (err error) {
  dsn := "root:123456@tcp(127.0.0.1:3306)/test"
  db, err = sql.Open("mysql", dsn)
  if err != nil {
    panic(err)
  }
  err = db.Ping() //检测是否连接成功
  if err != nil {
    return
  }
  db.SetMaxOpenConns(200)                 //最大连接数
  db.SetMaxIdleConns(10)                  //连接池里最大空闲连接数。必须要比maxOpenConns小
  db.SetConnMaxLifetime(time.Second * 10) //最大存活保持时间
  db.SetConnMaxIdleTime(time.Second * 10) //最大空闲保持时间
  return
}

func main() {
  if err := initMySQL(); err != nil {
    fmt.Printf("connect to db failed,err:%v\n", err)
  } else {
    fmt.Println("connect to db success")
  }

  sqlStr := "SELECT id, name FROM sys_user WHERE id=?"
  var u user
  //非常重要:确保QueryRow之后调用Scan方法,否则持有的数据库链接不会被释放
  err := db.QueryRow(sqlStr, 1).Scan(&u.id, &u.name)
  if err != nil {
    fmt.Printf("scan failed, err: %v\n", err)
    return
  }
  fmt.Printf("id:%d,name:%s,age:%d\n", u.id, u.name)

  defer db.Close()

}

//user结构体
type user struct {
  id int
  name string
}

sql

database: test

CREATE TABLE `sys_user` (
  `id` int(11) NOT NULL,
  `name` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;


汇总-增删改查

结果:

package main

import (
  "database/sql"
  "fmt"
  "time"

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

var db *sql.DB

func initMySQL() (err error) {
  dsn := "root:1234qwer@tcp(bj-cdb-mw08tjgs.sql.tencentcdb.com:60042)/test"
  db, err = sql.Open("mysql", dsn)
  if err != nil {
    panic(err)
  }
  err = db.Ping()
  if err != nil {
    return
  }
  db.SetMaxOpenConns(200)                 //最大连接数
  db.SetMaxIdleConns(10)                  //连接池里最大空闲连接数。必须要比maxOpenConns小
  db.SetConnMaxLifetime(time.Second * 10) //最大存活保持时间
  db.SetConnMaxIdleTime(time.Second * 10) //最大空闲保持时间
  return
}

func main() {
  if err := initMySQL(); err != nil {
    fmt.Printf("connect to db failed,err:%v\n", err)
  } else {
    fmt.Println("connect to db success")
  }
  select_one()
  queryMultiRowDemo()
  insertRowDemo()
  updateRowDemo()
  deleteRowDemo()
  defer db.Close()

}

type user struct {
  id int
  // age  int
  name string
}

//查询
func select_one() {
  sqlStr := "SELECT id, name FROM sys_user WHERE id=?"
  var u user
  //非常重要:确保QueryRow之后调用Scan方法,否则持有的数据库链接不会被释放
  err := db.QueryRow(sqlStr, 1).Scan(&u.id, &u.name)
  if err != nil {
    fmt.Printf("scan failed, err: %v\n", err)
    return
  }
  fmt.Printf("id:%d,name:%s\n", u.id, u.name)
}

// 查询多条数据示例
func queryMultiRowDemo() {
  sqlStr := "SELECT id,name FROM sys_user WHERE id>?"
  var u user
  rows, err := db.Query(sqlStr, 0)
  if err != nil {
    fmt.Printf("query failed, err:%v\n", err)
    return
  }
  //非常重要,关闭rows释放持有的数据库链接
  defer rows.Close()
  for rows.Next() {
    err := rows.Scan(&u.id, &u.name)
    if err != nil {
      fmt.Printf("scan failed, err: %v\n", err)
      return
    }
    fmt.Printf("id:%d,name:%s\n", u.id, u.name)
  }
}

//插入数据
func insertRowDemo() {
  sqlStr := "INSERT INTO sys_user(id,name) VALUES(?,?)"
  ret, err := db.Exec(sqlStr, 23, "javapub")
  if err != nil {
    fmt.Printf("insert failed, err:%v\n", err)
    return
  }
  var theID int64
  theID, err = ret.LastInsertId()
  if err != nil {
    fmt.Printf("get lastinsert ID failed,err:%v\n", err)
    return
  }
  fmt.Printf("insert success, the id is %d\n", theID)
}

//更新数据
func updateRowDemo() {
  sqlStr := "UPDATE sys_user SET name=? WHERE id=?"
  ret, err := db.Exec(sqlStr, "i love javapub", 23)
  if err != nil {
    fmt.Printf("updated failed,err:%v\n", err)
    return
  }
  var n int64
  n, err = ret.RowsAffected()
  if err != nil {
    fmt.Printf("get rowsAffected failed,err:%v\b", err)
    return
  }
  fmt.Printf("updated success, the rows affected is %d\n", n)
}

//删除数据
func deleteRowDemo() {
  sqlStr := "DELETE FROM sys_user WHERE id=?"
  ret, err := db.Exec(sqlStr, 1)
  if err != nil {
    fmt.Printf("delete failed,err:%v\n", err)
    return
  }
  var n int64
  n, err = ret.RowsAffected()
  if err != nil {
    fmt.Printf("get RowsAffected failed, err:%v\n", err)
    return
  }
  fmt.Printf("delete success, affected rows:%d\n", n)
}

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
2天前
|
SQL 存储 关系型数据库
MySQL数据库进阶第二篇(索引,SQL性能分析,使用规则)
MySQL数据库进阶第二篇(索引,SQL性能分析,使用规则)
|
2天前
|
SQL 关系型数据库 MySQL
MySQL数据库基础第一篇(SQL通用语法与分类)
MySQL数据库基础第一篇(SQL通用语法与分类)
|
2天前
|
SQL 关系型数据库 MySQL
|
3天前
|
关系型数据库 MySQL Go
Go语言介绍以及如何在Go语言中操作MySQL数据库
Go语言介绍以及如何在Go语言中操作MySQL数据库
17 3
|
3天前
|
Java 关系型数据库 流计算
实时计算 Flink版操作报错合集之配置cats进行从MySQL到StarRocks的数据同步任务时遇到报错,该怎么办
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
161 0
|
3天前
|
关系型数据库 MySQL 数据库
实时计算 Flink版操作报错合集之下载了mysql的cdc的demo,在本地调试时,报错:找不到这个包,该怎么办
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
3天前
|
消息中间件 关系型数据库 MySQL
实时计算 Flink版操作报错合集之同步MySQL数据并EP(复杂事件处理)时,编译报错,如何解决
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
3天前
|
存储 自然语言处理 关系型数据库
✅生产问题之Emoji表情如何操作存储,MySQL是否支持
MySQL支持存储Emoji表情,需使用UTF8MB4编码。UTF8MB3,MySQL早期的UTF-8实现,不支持部分Unicode字符包括Emoji,已被弃用。推荐使用UTF8MB4,它支持全部Unicode字符。转换时,现有UTF8MB3表需转换为UTF8MB4,列和表都需设置相应字符集。
|
1天前
|
中间件 Go
go语言后端开发学习(三)——基于validator包实现接口校验
go语言后端开发学习(三)——基于validator包实现接口校验
|
1天前
|
存储 Go 开发工具
go语言后端开发学习(二)——基于七牛云实现的资源上传模块
go语言后端开发学习(二)——基于七牛云实现的资源上传模块