博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
第一个go程序连接mysql读取数据
阅读量:4035 次
发布时间:2019-05-24

本文共 1307 字,大约阅读时间需要 4 分钟。

1、开发工具:GoLand

安装破解及汉化方法,参考:

2、Go的SDK安装

直接去官网下载即可,

我下载的是

下载完安装即可。安装过程中,该勾选的地方都勾选上即可,尤其是设置环境变量那里。

3、相关Go的我都安装到了D:/Go目录下了。

在Go目录下创建workspace文件夹,里面建三个文件夹:bin、pkg、src

此处参考:

 

4、go连接mysql的话,需要额外下载mysql驱动包

在src文件夹下,打开cmd命令,执行go get -t github.com/go-sql-driver/mysql

下载成功后如图

 

5、打开GoLand,新建一个Go工程。

然后再新建一个go文件,在文件中输入如下内容:

package mainimport (	"database/sql"	"fmt"	_ "github.com/go-sql-driver/mysql"	"strings")func IsErr(err error){	if err != nil{		fmt.Printf("程序错误:%s", err)	}}const (	userName = "root"	password = "root"	ip = "127.0.0.1"	port = "3306"	dbName = "test")type Users struct {	id int	vname string}func main(){	//初始化数据库	path := strings.Join([]string{userName, ":", password, "@tcp(",ip, ":", port, ")/", dbName, "?charset=utf8"}, "")	db, err := sql.Open("mysql",path)	rows, err := db.Query("select * from student")	IsErr(err)	//循环读取结果	var users []Users	for rows.Next(){		var user Users		//将每一行的结果都赋值到一个user对象中		err := rows.Scan(&user.id, &user.vname)		if err != nil {			fmt.Println("rows fail")		}		//将user追加到users的这个数组中		users = append(users, user)		fmt.Println(user.id,user.vname)	}	fmt.Println("===========================")	fmt.Println(len(users))}

输出结果如下:

 

Tips:mysql数据库需要自行安装并创建好相应的表

至此结束。

个人感觉go语言的语法相对来讲,跟C的比较相似,跟java的相差还是有点大。个人感觉java的语法不论是变量命名、方法定义还是其他的,都比较符合人性。 而go语言的很多命名定义就感觉比较反人类。 可能用的习惯的问题吧,不喜勿碰。

转载地址:http://tqcdi.baihongyu.com/

你可能感兴趣的文章
iOS 序列化与反序列化(runtime) 01
查看>>
iOS AFN 3.0版本前后区别 01
查看>>
iOS ASI和AFN有什么区别
查看>>
iOS QQ侧滑菜单(高仿)
查看>>
iOS 扫一扫功能开发
查看>>
iOS app之间的跳转以及传参数
查看>>
iOS __block和__weak的区别
查看>>
Android(三)数据存储之XML解析技术
查看>>
Spring JTA应用之JOTM配置
查看>>
spring JdbcTemplate 的若干问题
查看>>
Servlet和JSP的线程安全问题
查看>>
GBK编码下jQuery Ajax中文乱码终极暴力解决方案
查看>>
Oracle 物化视图
查看>>
PHP那点小事--三元运算符
查看>>
解决国内NPM安装依赖速度慢问题
查看>>
Brackets安装及常用插件安装
查看>>
Centos 7(Linux)环境下安装PHP(编译添加)相应动态扩展模块so(以openssl.so为例)
查看>>
fastcgi_param 详解
查看>>
Nginx配置文件(nginx.conf)配置详解
查看>>
标记一下
查看>>