时间:2021-05-22
在golang中要实现对数据库的操作, 一个比较好用的方式就是使用XORM,xorm是一个简单而强大的Go语言ORM库,通过它可以使数据库操作非常简便。 在xorm里面,可以同时存在多个ORM引擎,一个ORM引擎称为Engine,一个Engine一般只对应一个数据库。
golang的连接池配置
这里初始化一个全局的xorm.Engine对象, xorm.Engine通过调用xorm.NewEngine生成在很多其他的API都需要传入该对象作为参数。 这里需要理解这里设定的3个参数的意义:
SetMaxIdleConns()
SetMaxOpenConns()
SetConnMaxLifetime
go xorm来操作mysql
很有用,来看下:
package mainimport ( "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,addresstype 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
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
简单的用法packagemainimport(_"github.com/go-sql-driver/mysql""github.com/go-xorm/xorm
前言MySQL是业界常用的关系型数据库,在平时开发中会经常与MySql数据库打交道,所以在接下来将介绍怎么使用Go语言操作MySql数据库。下载MySql连接驱
因使用源码安装的MySQL5.7.28多实例,在导入数据库时会出现问题,所以重新研究使用mysql_multi的方法来管理多实例,经过测试环境验证之后,在各方面
本文实例总结了php随机取mysql记录方法。分享给大家供大家参考。具体分析如下:在php中要随机取mysql记录我们可以直接使用mysql_query来执行m
mysql正常运行的时候,查看table的结构并不是困难的事。但是有时mysql发生故障,这种方法便不再可行。当遇到故障,通常使用新的mysql实例来恢复当前的