使用go xorm来操作mysql的方法实例
2019/7/10 22:17:22
本文主要是介绍使用go xorm来操作mysql的方法实例,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
在golang中要实现对数据库的操作, 一个比较好用的方式就是使用XORM,xorm是一个简单而强大的Go语言ORM库,通过它可以使数据库操作非常简便。 在xorm里面,可以同时存在多个ORM引擎,一个ORM引擎称为Engine,一个Engine一般只对应一个数据库。
golang的连接池配置
这里初始化一个全局的xorm.Engine对象, xorm.Engine通过调用xorm.NewEngine生成在很多其他的API都需要传入该对象作为参数。 这里需要理解这里设定的3个参数的意义:
SetMaxIdleConns()
- 设置连接池中的保持连接的最大连接数。默认也是0,表示连接池不会保持释放会连接池中的连接的连接状态:即当连接释放回到连接池的时候,连接将会被关闭。这会导致连接再连接池中频繁的关闭和创建。
SetMaxOpenConns()
- 设置打开数据库的最大连接数,包含正在使用的连接和连接池的连接。如果你的函数调用需要申请一个连接,并且连接池已经没有了连接或者连接数达到了最大连接数。此时的函数调用将会被block,直到有可用的连接才会返回。设置这个值可以避免并发太高导致连接mysql出现too many connections的错误。该函数的默认设置是0,表示无限制。
SetConnMaxLifetime
- 设置连接可以被使用的最长有效时间,如果过期,连接将被拒绝。
go xorm来操作mysql
很有用,来看下:
package main import ( "fmt" "github.com/go-xorm/xorm" "github.com/go-xorm/core" _ "github.com/go-sql-driver/mysql" ) // 对应数据库的tablename必须为student // 执行mysql时,对应的字段为xxx,yyy,zzz; 也可以省掉,默认的mysql字段为id,username,address type Student struct { Id int `xorm:"INT(11) 'xxx'"` Username string `xorm:"VARCHAR(64) 'yyy'"` Address string `xorm:"VARCHAR(256) 'zzz'"` } func main() { engine, err := xorm.NewEngine("mysql", "root@/taoge?charset=utf8") // dbname是taoge if err != nil{ fmt.Println(err) return } // 如下Ping可以不要 // if err := engine.Ping(); err != nil{ // fmt.Println(err) // return // } //engine.ShowSQL(true) // 显示SQL的执行, 便于调试分析 engine.SetTableMapper(core.SnakeMapper{}) st1 := new(Student) st1.Username = "taoge" st1.Address = "China" affected, err := engine.Insert(st1) fmt.Println(affected) st2 := new(Student) result,err := engine.Where("xxx=?", 1).Get(st2) fmt.Println(result) fmt.Println(st2.Username) fmt.Println(st2.Address) }
创建数据库:
CREATE TABLE `student` ( `xxx` int(11) NOT NULL AUTO_INCREMENT, `yyy` varchar(64) NOT NULL, `zzz` varchar(256) NOT NULL , PRIMARY KEY (`xxx`) ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
运行结果:
1
true
taoge
China
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对找一找教程网的支持。如果你想了解更多相关内容请查看下面相关链接
这篇关于使用go xorm来操作mysql的方法实例的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-10-012024年每个初学者都应该知道的Django十大技巧
- 2024-09-30云原生周刊:Argo CD v2.13 发布候选版本丨2024.9.30
- 2024-09-29哪个更快:OpenAI Whisper、Google TTS 还是 Piper TTS??
- 2024-09-29MLOps 端到端系统在 Google 云平台(I):赋能预测解决方案
- 2024-09-26通过 gcloud CLI 认证从本地脚本写入 Google Sheets
- 2024-09-24GoLand 新建项目 Enable vendoring support automatically 的作用是什么?-icode9专业技术文章分享
- 2024-09-21MongoDB资料:新手入门与初级应用指南
- 2024-09-20MongoDB教程:初学者必备指南
- 2024-09-05MongoDB入门:快速掌握NoSQL数据库基础
- 2024-08-28go 项目中怎么打印调试-icode9专业技术文章分享