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

iris(golang)连接mysql数据库

连接mysql数据库

安装依赖

go get github.com/go-sql-driver/mysql
func LinkMySQL(){DB,_ := sql.Open("mysql","root:123456@tcp(127.0.0.1:3306)/webgo_accout")//设置数据库最大连接数DB.SetConnMaxLifetime(100)//设置上数据库最大闲置连接数DB.SetMaxIdleConns(10)//验证连接if err := DB.Ping(); err != nil {fmt.Println("open database fail")return}fmt.Println("connnect success")
}

查询表文件(多个文件)

create database webgo_accout;use webgo_accout;create table users(`uid` bigint not null AUTO_INCREMENT primary key,
`accout` varchar(255) not null,
`password` varchar(255) not null,
`username` varchar(255) not null default '用户名1'
);insert into users(`accout`,`password`,`username`) values ('admin','admin','admin');#测试是否是数组显示添加的数据,可以不写
insert into users(`accout`,`password`,`username`) values ('test','test','test');
//定义结构体
type User struct{Uid int `json:"uid"`Accout string `json:"accout"`PassWord string `json:"password"`UserName string `json:"username"`
}
//查询方法
func MySQLFindAll() []User{var user User //结构体数据users := []User{} //结构体数组DB,_ := sql.Open("mysql","root:123456@tcp(127.0.0.1:3306)/webgo_accout") //mysql数据库连接rows,err := DB.Query("select * from users") //sql查询语句if err != nil {fmt.Println("select error",err)}for rows.Next() {//添加数据rows.Scan(&user.Uid,&user.Accout,&user.PassWord,&user.UserName)//查看数据是否添加fmt.Printf("uid:%d\n",user.Uid)fmt.Printf("accout:%s\n",user.Accout)users = append(users,user) //添加数据,结构: 结构体数组1 = append(结构体数组1,数据)}defer rows.Close()return users
}

iris与数据库进行连接显示

注意,这个是不同包下的文件

  • 连接数据库部分
  • 需要go mod init link添加go.mod
  • go get github.com/go-sql-driver/mysql也是在此文件夹下添加,会生成go.sum
package linkimport ("fmt""database/sql"_ "github.com/go-sql-driver/mysql"
)func LinkMySQL(){DB,_ := sql.Open("mysql","root:123456@tcp(127.0.0.1:3306)/webgo_accout")//设置数据库最大连接数DB.SetConnMaxLifetime(100)//设置上数据库最大闲置连接数DB.SetMaxIdleConns(10)//验证连接if err := DB.Ping(); err != nil {fmt.Println("open database fail")return}fmt.Println("connnect success")
}type User struct{Uid int `json:"uid"`Accout string `json:"accout"`PassWord string `json:"password"`UserName string `json:"username"`
}
func MySQLFindAll() []User{var user Userusers := []User{}DB,_ := sql.Open("mysql","root:123456@tcp(127.0.0.1:3306)/webgo_accout")rows,err := DB.Query("select * from users")if err != nil {fmt.Println("select error",err)}for rows.Next() {rows.Scan(&user.Uid,&user.Accout,&user.PassWord,&user.UserName)fmt.Printf("uid:%d\n",user.Uid)fmt.Printf("accout:%s\n",user.Accout)users = append(users,user)}defer rows.Close()return users
}func LinkMongo(){fmt.Print("测试:你好")
}
  • iris部分

main主包下的go.mod

module accoutgo 1.21.0require (//...(go get xxx 自行添加的)
)require (com.chentianyu.learn/link v1.0.0
)replace (com.chentianyu.learn/link => ./link
)
package mainimport ("github.com/kataras/iris/v12""com.chentianyu.learn/link"
)func linkMy(){link.LinkMySQL()
}func main() {app := iris.New()linkMy() //连接数据库//查询数据库中的数据api(测试,正式要换成Post)  http://localhost:8089/mysql_findapp.Get("/mysql_find",func(ctx iris.Context){user1 := link.MySQLFindAll()ctx.JSON(user1)})//首页,根目录: http://localhost:8089/app.Get("/",func(ctx iris.Context){ctx.Text("welcome this is accout api")})//设置端口app.Listen(":8089")
}
http://www.lryc.cn/news/187762.html

相关文章:

  • C现代方法(第1、2章)笔记
  • 练[CISCN2019 华东南赛区]Double Secret
  • 『Linux - gcc / g++』c程序翻译过程
  • 苹果遭遇安全危机,应用商店曝出不良APP,或影响iPhone的销售
  • docker 基本操作
  • ARM:使用汇编完成三个灯流水亮灭
  • 嵌入式养成计划-33--数据库-sqlite3
  • 什么是大数据运维?大数据运维的职责
  • 解决方案:AI赋能工业生产3.0,从工业“制造”到“智造”
  • Android KeyStore 秘钥导入
  • TDengine+OpenVINO+AIxBoard,助力时序数据分类
  • 设计模式——16. 迭代器模式
  • flink redis connector需要防止包冲突
  • socket can查看详细信息 命令 ip -details -statistics link show can0
  • 打造虚拟企业展厅,开启商务活动新时代
  • 03黑马店评-添加商户缓存和商户类型的缓存到Redis
  • LabVIEW玩转魔方
  • 大数据学习(1)-Hadoop
  • 常用时序模型
  • 阿里云/腾讯云国际站:私服服务器:什么是游戏虚拟服务器及用途讲解?
  • ssti 前置学习
  • uni-app:服务器端数据绘制echarts图标(renderjs解决手机端无法显示问题)
  • Python集合魔法:解锁数据去重技巧
  • flutter开发实战-inappwebview实现flutter与Javascript的交互JSBridge
  • 私有云盘:lamp部署nextcloud+高可用集群
  • 在线制作课程表
  • 聊聊分布式架构06——[NIO入门]简单的Netty NIO示例
  • H5逆向之远程RPC
  • 解决Ubuntu18.04安装好搜狗输入法后无法打出中文的问题
  • Ubuntu LabelMe AI 识别