当前位置:首页 > 文章列表 > Golang > Go教程 > 从Mysql服务器读取数据

从Mysql服务器读取数据

来源:dev.to 2024-07-29 08:15:39 0浏览 收藏

来到golang学习网的大家,相信都是编程学习爱好者,希望在这里学习Golang相关编程知识。下面本篇文章就来带大家聊聊《从Mysql服务器读取数据》,介绍一下,希望对大家的知识积累有所帮助,助力实战开发!

从Mysql服务器读取数据

导入所需的包,然后准备一个与数据库中tb_student表的示例具有相同架构的结构体,稍后该结构体将用作查询结果数据类型的容器。

package main
import "fmt"
import "database/sql"
import _ "github.com/go-sql-driver/mysql"


type student struct {
 id string,
 name string,
 age int,
 grade int,
}

使用的数据库驱动需要使用_号导入,因为尽管database/sql包需要它,但我们并不直接与驱动交互。

接下来,创建一个连接数据库的函数。

func connect() (*sql.db, error) {
 db, err := sql.open("mysql","root:@tcp(127.0.0.1:3306)/db_learn_go")
 if err != nil {
  return nil, err
 }
 return db, nil
}

我们使用的mysql驱动的连接字符串方案非常独特,下面的root@tcp(127.0.0.1:3306)/db_learn_go是一个可以在go mysql driver驱动上使用的连接字符串方案,如果你使用另一个mysql ,根据所使用的驱动程序,连接方案可能会有所不同。

user:password@tcp(host:port)/dbname
user@tcp(host:port)/dbname

下面是对 connect() 函数中使用的连接字符串的解释。

root@tcp(127.0.0.1:3306)/db_learn_go
// user => root
// password =>
// host => 127.0.0.1 atau localhost
// port => 3306
// dbname => db_learn_go

连接数据库的功能创建完成后,就可以练习从数据库服务器读取数据的过程了。准备函数
sqlquery() 具有以下代码。

func sqlQuery() {
 db, err := connect()
 if err != nil {
 fmt.Println(err.Error())
 return
 }
 defer db.Close()
 var age = 27
 rows, err := db.Query("select id, name, grade from tb_student where age = ?
 if err != nil {
 fmt.Println(err.Error())
 return
 }
 defer rows.Close()
 var result []student
 for rows.Next() {
 var each = student{}
 var err = rows.Scan(&each.id, &each.name, &each.grade)
 if err != nil {
 fmt.Println(err.Error())
 return
 }
 result = append(result, each)
 }
 if err = rows.Err(); err != nil {
 fmt.Println(err.Error())
 return
 }
 for _, each := range result {
 fmt.Println(each.name)
 }
}

每次创建新连接时,不要忘记始终关闭连接实例。您可以使用 defer 关键字,如上面的代码所示,defer
db.close() .
db.query()函数用于执行sql查询。该函数的第二个参数是可变参数,因此可以留空。在上面的代码中,您可以看到其中一个where子句的值为问号(?)。

该符号将被其后面的参数中的值(年龄变量的值)替换。强烈推荐这种类型的查询编写技术,以防止 sql 注入。该函数生成一个 sql.*rows 类型的实例,当不再使用时也需要将其关闭( defer rows.close() )。接下来,准备一个元素类型为 struct student 且名称为 result 的数组。稍后查询结果将存储在变量中。然后执行循环,条件引用为 rows.next() 。该循环执行的次数与记录总数相同,从第一条记录到最后一条记录依次执行。 sql.rows 的 scan() 方法用于检索正在迭代的记录的值,并将其存储在指针变量中。根据查询中选择的字段,用于存储记录字段的变量被顺序写入为可变参数。请参阅下面的比较以了解更多详细信息。 // 查询
选择id、姓名、年级...
// 扫描
rows.scan(&each.id, &each.name, &each.grade ...
然后将获得的记录数据通过语句附加到结果切片中
结果 = 附加(结果,每个).
好的,现在只需在 main 中调用 sqlquery() 函数,然后运行程序即可。

func main() {
sqlquery()
}

我只是一个普通的博客作者。如果还有太多不足之处还请见谅

终于介绍完啦!小伙伴们,这篇关于《从Mysql服务器读取数据》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

版本声明
本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
Nextjs 获取数据时的缓存问题Nextjs 获取数据时的缓存问题
上一篇
Nextjs 获取数据时的缓存问题
使用 TailwindCSS 制作动画
下一篇
使用 TailwindCSS 制作动画
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • SEO标题协启动:AI驱动的智能对话与内容生成平台 - 提升创作效率
    协启动
    SEO摘要协启动(XieQiDong Chatbot)是由深圳协启动传媒有限公司运营的AI智能服务平台,提供多模型支持的对话服务、文档处理和图像生成工具,旨在提升用户内容创作与信息处理效率。平台支持订阅制付费,适合个人及企业用户,满足日常聊天、文案生成、学习辅助等需求。
    7次使用
  • Brev AI:零注册门槛的全功能免费AI音乐创作平台
    Brev AI
    探索Brev AI,一个无需注册即可免费使用的AI音乐创作平台,提供多功能工具如音乐生成、去人声、歌词创作等,适用于内容创作、商业配乐和个人创作,满足您的音乐需求。
    7次使用
  • AI音乐实验室:一站式AI音乐创作平台,助力音乐创作
    AI音乐实验室
    AI音乐实验室(https://www.aimusiclab.cn/)是一款专注于AI音乐创作的平台,提供从作曲到分轨的全流程工具,降低音乐创作门槛。免费与付费结合,适用于音乐爱好者、独立音乐人及内容创作者,助力提升创作效率。
    6次使用
  • SEO标题PixPro:AI驱动网页端图像处理平台,提升效率的终极解决方案
    PixPro
    SEO摘要PixPro是一款专注于网页端AI图像处理的平台,提供高效、多功能的图像处理解决方案。通过AI擦除、扩图、抠图、裁切和压缩等功能,PixPro帮助开发者和企业实现“上传即处理”的智能化升级,适用于电商、社交媒体等高频图像处理场景。了解更多PixPro的核心功能和应用案例,提升您的图像处理效率。
    6次使用
  • EasyMusic.ai:零门槛AI音乐生成平台,专业级输出助力全场景创作
    EasyMusic
    EasyMusic.ai是一款面向全场景音乐创作需求的AI音乐生成平台,提供“零门槛创作 专业级输出”的服务。无论你是内容创作者、音乐人、游戏开发者还是教育工作者,都能通过EasyMusic.ai快速生成高品质音乐,满足短视频、游戏、广告、教育等多元需求。平台支持一键生成与深度定制,积累了超10万创作者,生成超100万首音乐作品,用户满意度达99%。
    9次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码