当前位置: 首页 > article >正文

Go语言的数据库操作

Go语言的数据库操作数据库操作基础Go语言提供了标准的数据库接口database/sql包用于与各种数据库进行交互。同时需要为特定数据库安装相应的驱动。基本使用安装驱动以MySQL为例安装驱动go get github.com/go-sql-driver/mysql连接数据库package main import ( database/sql fmt _ github.com/go-sql-driver/mysql ) func main() { db, err : sql.Open(mysql, username:passwordtcp(localhost:3306)/database) if err ! nil { fmt.Println(Error connecting to database:, err) return } defer db.Close() // 测试连接 err db.Ping() if err ! nil { fmt.Println(Error pinging database:, err) return } fmt.Println(Connected to database successfully) }执行SQL语句查询数据package main import ( database/sql fmt _ github.com/go-sql-driver/mysql ) type User struct { ID int Name string Age int } func main() { db, _ : sql.Open(mysql, username:passwordtcp(localhost:3306)/database) defer db.Close() rows, err : db.Query(SELECT id, name, age FROM users) if err ! nil { fmt.Println(Error querying database:, err) return } defer rows.Close() var users []User for rows.Next() { var user User err : rows.Scan(user.ID, user.Name, user.Age) if err ! nil { fmt.Println(Error scanning row:, err) return } users append(users, user) } for _, user : range users { fmt.Printf(ID: %d, Name: %s, Age: %d\n, user.ID, user.Name, user.Age) } }插入数据package main import ( database/sql fmt _ github.com/go-sql-driver/mysql ) func main() { db, _ : sql.Open(mysql, username:passwordtcp(localhost:3306)/database) defer db.Close() result, err : db.Exec(INSERT INTO users (name, age) VALUES (?, ?), John, 30) if err ! nil { fmt.Println(Error inserting data:, err) return } id, err : result.LastInsertId() if err ! nil { fmt.Println(Error getting last insert ID:, err) return } fmt.Printf(Inserted user with ID: %d\n, id) }更新数据package main import ( database/sql fmt _ github.com/go-sql-driver/mysql ) func main() { db, _ : sql.Open(mysql, username:passwordtcp(localhost:3306)/database) defer db.Close() result, err : db.Exec(UPDATE users SET age ? WHERE id ?, 31, 1) if err ! nil { fmt.Println(Error updating data:, err) return } rowsAffected, err : result.RowsAffected() if err ! nil { fmt.Println(Error getting rows affected:, err) return } fmt.Printf(Updated %d rows\n, rowsAffected) }删除数据package main import ( database/sql fmt _ github.com/go-sql-driver/mysql ) func main() { db, _ : sql.Open(mysql, username:passwordtcp(localhost:3306)/database) defer db.Close() result, err : db.Exec(DELETE FROM users WHERE id ?, 1) if err ! nil { fmt.Println(Error deleting data:, err) return } rowsAffected, err : result.RowsAffected() if err ! nil { fmt.Println(Error getting rows affected:, err) return } fmt.Printf(Deleted %d rows\n, rowsAffected) }使用事务package main import ( database/sql fmt _ github.com/go-sql-driver/mysql ) func main() { db, _ : sql.Open(mysql, username:passwordtcp(localhost:3306)/database) defer db.Close() tx, err : db.Begin() if err ! nil { fmt.Println(Error starting transaction:, err) return } // 执行多个SQL语句 _, err tx.Exec(INSERT INTO users (name, age) VALUES (?, ?), John, 30) if err ! nil { tx.Rollback() fmt.Println(Error inserting user:, err) return } _, err tx.Exec(INSERT INTO orders (user_id, product) VALUES (?, ?), 1, Product 1) if err ! nil { tx.Rollback() fmt.Println(Error inserting order:, err) return } // 提交事务 err tx.Commit() if err ! nil { fmt.Println(Error committing transaction:, err) return } fmt.Println(Transaction completed successfully) }使用预处理语句package main import ( database/sql fmt _ github.com/go-sql-driver/mysql ) func main() { db, _ : sql.Open(mysql, username:passwordtcp(localhost:3306)/database) defer db.Close() // 准备预处理语句 stmt, err : db.Prepare(SELECT id, name, age FROM users WHERE age ?) if err ! nil { fmt.Println(Error preparing statement:, err) return } defer stmt.Close() // 执行预处理语句 rows, err : stmt.Query(25) if err ! nil { fmt.Println(Error executing statement:, err) return } defer rows.Close() for rows.Next() { var id int var name string var age int err : rows.Scan(id, name, age) if err ! nil { fmt.Println(Error scanning row:, err) return } fmt.Printf(ID: %d, Name: %s, Age: %d\n, id, name, age) } }数据库连接池package main import ( database/sql fmt _ github.com/go-sql-driver/mysql ) func main() { db, _ : sql.Open(mysql, username:passwordtcp(localhost:3306)/database) defer db.Close() // 配置连接池 db.SetMaxOpenConns(25) // 最大打开连接数 db.SetMaxIdleConns(5) // 最大空闲连接数 fmt.Println(Connection pool configured successfully) }示例完整的数据库操作package main import ( database/sql fmt log _ github.com/go-sql-driver/mysql ) type User struct { ID int Name string Age int } func main() { // 连接数据库 db, err : sql.Open(mysql, username:passwordtcp(localhost:3306)/database) if err ! nil { log.Fatal(Error connecting to database:, err) } defer db.Close() // 测试连接 err db.Ping() if err ! nil { log.Fatal(Error pinging database:, err) } // 创建表 _, err db.Exec(CREATE TABLE IF NOT EXISTS users ( id INT AUTO_INCREMENT PRIMARY KEY, name VARCHAR(255) NOT NULL, age INT NOT NULL )) if err ! nil { log.Fatal(Error creating table:, err) } // 插入数据 result, err : db.Exec(INSERT INTO users (name, age) VALUES (?, ?), John, 30) if err ! nil { log.Fatal(Error inserting data:, err) } id, _ : result.LastInsertId() fmt.Printf(Inserted user with ID: %d\n, id) // 查询数据 rows, err : db.Query(SELECT id, name, age FROM users) if err ! nil { log.Fatal(Error querying data:, err) } defer rows.Close() var users []User for rows.Next() { var user User err : rows.Scan(user.ID, user.Name, user.Age) if err ! nil { log.Fatal(Error scanning row:, err) } users append(users, user) } fmt.Println(Users:) for _, user : range users { fmt.Printf(ID: %d, Name: %s, Age: %d\n, user.ID, user.Name, user.Age) } // 更新数据 _, err db.Exec(UPDATE users SET age ? WHERE id ?, 31, id) if err ! nil { log.Fatal(Error updating data:, err) } // 删除数据 _, err db.Exec(DELETE FROM users WHERE id ?, id) if err ! nil { log.Fatal(Error deleting data:, err) } fmt.Println(Database operations completed successfully) }总结Go语言的database/sql包提供了统一的数据库操作接口支持多种数据库。通过合理使用连接池、预处理语句和事务可以编写高效、安全的数据库操作代码。

相关文章:

Go语言的数据库操作

Go语言的数据库操作 数据库操作基础 Go语言提供了标准的数据库接口database/sql包,用于与各种数据库进行交互。同时,需要为特定数据库安装相应的驱动。 基本使用 安装驱动 以MySQL为例,安装驱动: go get github.com/go-sql-driver…...

Cursor 10大实战技巧:高效开发秘籍

Cursor 10 大核心实战技巧(附步骤 + 示例) 技巧 :全项目上下文注入:解决 AI「失忆」,让 AI 懂你的整个项目 核心价值:Cursor 默认只能理解当前打开的文件,通过上下文注入,让 AI 理解项目架构、已有代码,生成的代码完全贴合项目,不会出现「重复造轮子」「路径错误」。…...

Scroll Reverser:macOS设备独立滚动方向智能解决方案

Scroll Reverser:macOS设备独立滚动方向智能解决方案 【免费下载链接】Scroll-Reverser Per-device scrolling prefs on macOS. 项目地址: https://gitcode.com/gh_mirrors/sc/Scroll-Reverser 在macOS生态系统中,多输入设备共存带来了一个长期困…...

Android 14/15抓包实战:从系统证书注入到应用进程级捕获

1. Android 14/15抓包的核心挑战 最近在给公司做安全测试时,遇到了一个头疼的问题:新采购的一批Android 14/15设备死活抓不到HTTPS包。折腾了整整两天才发现,原来是系统证书存储机制发生了重大变化。传统方法把证书放到/system/etc/security/…...

TimesFM时间序列预测:谷歌基础模型让零样本预测变得如此简单

TimesFM时间序列预测:谷歌基础模型让零样本预测变得如此简单 【免费下载链接】timesfm TimesFM (Time Series Foundation Model) is a pretrained time-series foundation model developed by Google Research for time-series forecasting. 项目地址: https://gi…...

新手小白实战教程:用 TRAE 从零创建一个“个人日记本”网页应用

本教程将带你手把手、一步步,使用 TRAE 完成你的第一个小项目。我们会像搭积木一样,从创建一个空文件夹开始,直到做出一个能运行、能记日记的简单网页。请严格按顺序操作,不要跳步。 第一步:项目启动与规划 (5分钟) 目…...

PCB设计老鸟的AD21 DRC设置清单:如何为你的高速板与低速板定制专属检查规则

PCB设计高手必备:AD21 DRC规则定制化配置实战指南 在PCB设计领域,DRC(设计规则检查)就像是一位严格的质检员,它能帮我们提前发现设计中潜在的问题。但很多工程师都面临一个困境:面对不同类型的设计项目&…...

《TRAE从入门到精通全攻略》,零基础也能快速上手,助力你快速成长为程序员

TRAE 从入门到精通:一站式完整指南 本指南将带你从零开始,系统性地掌握字节跳动推出的智能编程助手 TRAE。我们将按照“获取-安装-认识-使用-精通”的路径,逐一解析其所有核心功能与界面。 第一部分:获取与安装 1. 系统要求与下…...

MDAnalysis解决方案:分子动力学模拟分析效能提升框架

MDAnalysis解决方案:分子动力学模拟分析效能提升框架 【免费下载链接】mdanalysis MDAnalysis is a Python library to analyze molecular dynamics simulations. 项目地址: https://gitcode.com/gh_mirrors/md/mdanalysis 问题痛点引入:分子动力…...

国民技术 N32G452CCL7 LQFP-48 单片机

特性32位ARM Cortex-M4内核 FPU,单周期硬件乘除法指令,支持DSP指令和MPU内置8KB指令Cache缓存,支持Flash加速单元执行程序0等待最高主频144MHz,180DMIPS高达512KByte片内Flash,支持加密存储、多用户分区管理及数据保护…...

宝塔面板卸载后网站数据还在吗?保姆级清理与重装避坑指南

宝塔面板卸载后数据安全完全指南:从残留清理到重装避坑全解析 每次面对服务器环境重构时,最令人头疼的莫过于那些"看不见的数据幽灵"——你以为已经卸载干净的软件,实际上在系统深处留下了各种配置文件、日志和缓存。作为国内使用率…...

3分钟搞定!Windows包管理器Winget一键安装终极方案

3分钟搞定!Windows包管理器Winget一键安装终极方案 【免费下载链接】winget-install Install WinGet using PowerShell! Prerequisites automatically installed. Works on Windows 10/11 and Server 2019/2022. 项目地址: https://gitcode.com/gh_mirrors/wi/win…...

War3地图编辑器进阶:利用炮火攻击实现混乱伤害技能的完整指南

War3地图编辑器进阶:炮火攻击实现混乱伤害技能的深度解析 在魔兽争霸3地图编辑器的世界里,创造独特技能是每位地图作者的必修课。传统技能往往受限于固定伤害值或特定攻击类型,而今天我们要探讨的是一种突破常规的方法——利用炮火攻击地面机…...

Dify聊天框太丑?手把手教你从嵌入代码到Docker镜像的完整UI定制流程

Dify聊天框太丑?手把手教你从嵌入代码到Docker镜像的完整UI定制流程 当你第一次将Dify聊天机器人嵌入到自己的网站时,可能会对那个蓝色气泡和千篇一律的对话框感到失望。作为开发者或产品经理,你一定希望这个智能助手能完美融入品牌风格&…...

【计算机网络 实验报告2】网络常用命令与基本配置

上一篇:【计算机网络 实验报告1】Wireshark软件的使用 目录 实验目的 二、实验环境 三、实验内容 四、实验过程与结果 五、习题 实验目的 学习网络常用命令学习Packet Tracer软件的使用学习网络的基本配置方法 二、实验环境 设备名称 DESKTOP-F3VC3QK 处…...

RevokeMsgPatcher:Windows平台微信/QQ/TIM防撤回解决方案深度解析

RevokeMsgPatcher:Windows平台微信/QQ/TIM防撤回解决方案深度解析 【免费下载链接】RevokeMsgPatcher :trollface: A hex editor for WeChat/QQ/TIM - PC版微信/QQ/TIM防撤回补丁(我已经看到了,撤回也没用了) 项目地址: https:/…...

TurboVNC完整安装与配置指南:高性能远程桌面解决方案

TurboVNC完整安装与配置指南:高性能远程桌面解决方案 【免费下载链接】turbovnc Main TurboVNC repository 项目地址: https://gitcode.com/gh_mirrors/tu/turbovnc TurboVNC是一个专为高性能图形应用优化的远程桌面系统,特别适合3D渲染、视频处理…...

大模型修炼秘籍 第十章:多才多艺——多任务微调

第十章:多才多艺——多任务微调多任务修多才艺,混合数据需平衡。【本章导读】 真正的大模型应该文能提笔安天下,武能上马定乾坤。多任务微调让模型学会多种技能,成为全能选手。一、一专多能 【任务类型】任务类型描述示例文本生成…...

遗传算法实战:解码带时间窗约束的车辆路径规划(VRPTW)

1. 当物流遇上时间窗:VRPTW问题到底有多难? 想象一下你是一家生鲜电商的物流调度员,早上6点打开系统,屏幕上突然弹出16个新订单:王阿姨要7:30-8:00收到活鱼,李大爷要求8:15-8:45配送新鲜蔬菜,而…...

2026届必备的六大AI写作平台横评

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 人工智能技术发展势头迅猛,速度极快,为毕业论文写作带来了全新的辅助…...

从MODE到INTERCONNECT:环形谐振器电路级仿真全流程解析(含Lumerical脚本示例)

从MODE到INTERCONNECT:环形谐振器电路级仿真全流程解析 硅光集成设计中最令人着迷的挑战之一,是如何将精确的光学仿真结果无缝转化为电路级设计语言。想象一下,当你花费数小时在FDTD中优化出一个Q值超过10000的环形谐振器后,却发…...

建站系统怎么选?2026年SaaS平台与开源CMS对比分析

建站系统是指用于创建、管理和维护网站的软件平台或工具集,其核心目标是通过标准化模块降低网站开发的技术门槛,让用户无需从零编写代码即可完成网站搭建与内容管理。从技术架构与部署模式角度,当前建站系统主要分为两大类别:一、…...

从寄存器配置到数据解析:基于STM32与MAX31856的E型热电偶测温实战

1. 工业测温场景下的E型热电偶方案选型 在工业温度测量领域,热电偶因其宽量程、高可靠性和快速响应等特点成为首选传感器。E型热电偶(镍铬-铜镍)在0-900℃范围内具有最高的灵敏度(68μV/℃),特别适合中低温…...

2025年八大网盘直链下载工具LinkSwift完整使用指南:告别限速,实现全速下载

2025年八大网盘直链下载工具LinkSwift完整使用指南:告别限速,实现全速下载 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 ,支持 百度网盘 / …...

LIS3DHTR三轴加速度计:从智能穿戴到工业监测的全场景应用解析

1. LIS3DHTR三轴加速度计的核心特性解析 第一次接触LIS3DHTR时,我完全被这个小芯片的"反差萌"震惊了——尺寸只有3x3x1mm的LGA封装里,竟然藏着能感知16g加速度的精密机械结构。这款意法半导体的明星产品采用MEMS工艺,内部其实是个&…...

平衡树的本质的庖丁解牛

它的本质是:通过引入额外的维护成本(旋转、变色、重新平衡),强制将二叉搜索树 (BST) 的高度控制在 O(log⁡n)O(\log n)O(logn) 级别,从而保证在最坏情况下,查找、插入、删除操作的时间复杂度依然稳定。它是…...

从论文到GitHub:手把手复现TCom顶会混合波束成形MMSE算法(含Python/Matlab代码解析)

从论文到工程实践:混合波束成形MMSE算法的代码级拆解与性能优化 在毫米波通信系统中,混合波束成形技术因其在硬件复杂度和系统性能间的平衡而备受关注。当我们从论文转向实际代码实现时,理论公式与工程实践之间往往存在巨大鸿沟。本文将带您深…...

网安人必藏!Web 安卓 APP 软件逆向知识点

那么说到这我们更通俗的来表达一下,正向就像工厂生产一个产品,而逆向了就像你小时候败家的样子,总喜欢把一些玩具或者电子电器拆开研究一下他里面有啥,他是怎么运行的,当然绝大多数情况下,你一定挨了不少骂…...

STM32-结构体对齐与内存池实战优化

1. 为什么STM32开发者必须掌握结构体对齐与内存池 第一次在STM32上实现CAN总线通信时,我遇到了一个诡异的问题:接收到的数据总是错位。调试了整整两天才发现,问题出在结构体成员没有按4字节对齐,导致DMA传输时数据地址不符合硬件要…...

Node.js实战:手把手教你调用EduCoder实训平台API(附完整封装代码)

Node.js实战:从零封装EduCoder平台API的完整指南 在编程学习过程中,实训平台扮演着至关重要的角色。EduCoder作为国内知名的在线编程实训平台,提供了丰富的编程练习和项目实战机会。但对于开发者而言,如何通过程序化方式与平台交互…...