GO语言(三十):访问关系型数据库(上)本教程介绍了使用 Godatabase/sql及其标准库中的包访问关系数据库的基础知识 。
您将使用的database/sql包包括用于连接数据库、执行事务、取消正在进行的操作等的类型和函数 。
在本教程中 , 您将创建一个数据库 , 然后编写代码来访问该数据库 。您的示例项目将是有关老式爵士乐唱片的数据存储库 。
首先,为您要编写的代码创建一个文件夹 。
1、打开命令提示符并切换到您的主目录 。
在 Linux 或 Mac 上:
在 Windows 上:
2、在命令提示符下 , 为您的代码创建一个名为 data-access 的目录 。
3、创建一个模块,您可以在其中管理将在本教程中添加的依赖项 。
运行go mod init命令,为其提供新代码的模块路径 。
此命令创建一个 go.mod 文件,您添加的依赖项将在其中列出以供跟踪 。
注意:在实际开发中,您会指定一个更符合您自己需求的模块路径 。有关更多信息,请参阅一下文章 。
GO语言(二十五):管理依赖项(上)
GO语言(二十六):管理依赖项(中)
GO语言(二十七):管理依赖项(下)
接下来,您将创建一个数据库 。
在此步骤中 , 您将创建要使用的数据库 。您将使用 DBMS 本身的 CLI 创建数据库和表,以及添加数据 。
您将创建一个数据库 , 其中包含有关黑胶唱片上的老式爵士乐录音的数据 。
这里的代码使用MySQL CLI,但大多数 DBMS 都有自己的 CLI,具有类似的功能 。
1、打开一个新的命令提示符 。
在命令行,登录到您的 DBMS , 如下面的 MySQL 示例所示 。
2、在mysql命令提示符下,创建一个数据库 。
3、切到您刚刚创建的数据库,以便您可以添加表 。
4、在文本编辑器的 data-access 文件夹中,创建一个名为 create-tables.sql 的文件来保存用于添加表的 SQL 脚本 。
将以下 SQL 代码粘贴到文件中 , 然后保存文件 。
在此 SQL 代码中:
(1)删除名为album表 。首先执行此命令可以让您更轻松地稍后重新运行脚本 。
(2)创建一个album包含四列的表:title、artist和price 。每行的id值由 DBMS 自动创建 。
(3)添加带有值的四行 。
5、在mysql命令提示符下,运行您刚刚创建的脚本 。
您将使用以下形式的source命令:
6、在 DBMS 命令提示符处,使用SELECT语句来验证您是否已成功创建包含数据的表 。
接下来,您将编写一些 Go 代码进行连接,以便进行查询 。
现在你已经有了一个包含一些数据的数据库,开始你的 Go 代码 。
找到并导入一个数据库驱动程序,该驱动程序会将您通过database/sql包中的函数发出的请求转换为数据库可以理解的请求 。
1、在您的浏览器中,访问SQLDrivers wiki 页面以识别您可以使用的驱动程序 。
2、使用页面上的列表来识别您将使用的驱动程序 。为了在本教程中访问 MySQL,您将使用 Go-MySQL-Driver 。
3、请注意驱动程序的包名称 - 此处为github.com/go-sql-driver/mysql.
4、使用您的文本编辑器,创建一个用于编写 Go 代码的文件,并将该文件作为 main.go 保存在您之前创建的数据访问目录中 。
5、进入main.go , 粘贴以下代码导入驱动包 。
在此代码中:
(1)将您的代码添加到main包中,以便您可以独立执行它 。
(2)导入 MySQL 驱动程序github.com/go-sql-driver/mysql 。
导入驱动程序后 , 您将开始编写代码以访问数据库 。
现在编写一些 Go 代码,让您使用数据库句柄访问数据库 。
您将使用指向结构的指针sql.DB,它表示对特定数据库的访问 。
编写代码
1、进入 main.go,在import您刚刚添加的代码下方,粘贴以下 Go 代码以创建数据库句柄 。
在此代码中:
(3)使用 MySQL 驱动程序Config和FormatDSN类型以收集连接属性并将它们格式化为连接字符串的 DSN 。
该Config结构使代码比连接字符串更容易阅读 。
(4)调用sql.Open 初始化db变量,传递 FormatDSN 。
(5)检查来自 的错误sql.Open 。例如,如果您的数据库连接细节格式不正确,它可能会失败 。
为了简化代码,您调用log.Fatal结束执行并将错误打印到控制台 。在生产代码中 , 您会希望以更优雅的方式处理错误 。
(6)调用DB.Ping以确认连接到数据库有效 。在运行时, sql.Open可能不会立即连接,具体取决于驱动程序 。您在Ping此处使用以确认 database/sql包可以在需要时连接 。
(7)检查来自Ping的错误,以防连接失败 。
(8)Ping如果连接成功 , 则打印一条消息 。
文件的顶部现在应该如下所示:
3、保存 main.go 。
1、开始跟踪 MySQL 驱动程序模块作为依赖项 。
使用go get 添加 github.com/go-sql-driver/mysql 模块作为您自己模块的依赖项 。使用点参数表示“获取当前目录中代码的依赖项” 。
2、在命令提示符下 , 设置Go 程序使用的DBUSER和DBPASS环境变量 。
在 Linux 或 Mac 上:
【go语言获取月份 go语言示例】在 Windows 上:
3、在包含 main.go 的目录中的命令行中,通过键入go run来运行代码 。
连接成功了!
接下来,您将查询一些数据 。
如何学习GO语言?Go语言也称 Golanggo语言获取月份,兼具效率、性能、安全、健壮等特性 。这套Go语言教程(Golang教程)通俗易懂,深入浅出,既适合没有基础go语言获取月份的读者快速入门 , 也适合工作多年的程序员查阅知识点 。
Go 语言
这套教程在讲解一些知识点时,将 Go 语言和其他多种语言进行对比,让掌握其它编程语言的读者能迅速理解 Go 语言的特性 。Go语言从底层原生支持并发 , 无须第三方库、开发者的编程技巧和开发经验就可以轻松搞定 。
Go语言(或 Golang)起源于 2007 年,并在 2009 年正式对外发布 。Go 是非常年轻的一门语言,它的主要目标是“兼具 Python 等动态语言的开发速度和 C/C等编译型语言的性能与安全性” 。
Go语言是编程语言设计的又一次尝试,是对类C语言的重大改进,它不但能让go语言获取月份你访问底层操作系统 , 还提供了强大的网络编程和并发编程支持 。Go语言的用途众多,可以进行网络编程、系统编程、并发编程、分布式编程 。
Go语言的推出,旨在不损失应用程序性能的情况下降低代码的复杂性 , 具有“部署简单、并发性好、语言设计良好、执行性能好”等优势,目前国内诸多 IT 公司均已采用Go语言开发项目 。Go语言有时候被描述为“C 类似语言”,或者是“21 世纪的C语言” 。Go 从C语言继承了相似的表达式语法、控制流结构、基础数据类型、调用参数传值、指针等很多思想 , 还有C语言一直所看中的编译后机器码的运行效率以及和现有操作系统的无缝适配 。
因为Go语言没有类和继承的概念,所以它和 Java 或 C看起来并不相同 。但是它通过接口(interface)的概念来实现多态性 。Go语言有一个清晰易懂的轻量级类型系统,在类型之间也没有层级之说 。因此可以说Go语言是一门混合型的语言 。
此外,很多重要的开源项目都是使用Go语言开发的,其中包括 Docker、Go-Ethereum、Thrraform 和 Kubernetes 。Go 是编译型语言 , Go 使用编译器来编译代码 。编译器将源代码编译成二进制(或字节码)格式go语言获取月份;在编译代码时,编译器检查错误、优化性能并输出可在不同平台上运行的二进制文件 。要创建并运行 Go 程序,程序员必须执行如下步骤 。
使用文本编辑器创建 Go 程序;
保存文件;编译程序;运行编译得到的可执行文件 。
这不同于 Python、Ruby 和 JavaScript 等语言,它们不包含编译步骤 。Go 自带了编译器,因此无须单独安装编译器 。
链乔教育在线旗下学硕创新区块链技术工作站是中国教育部学校规划建设发展中心开展的“智慧学习工场2020-学硕创新工作站 ”唯一获准的“区块链技术专业”试点工作站 。专业站立足为学生提供多样化成长路径 , 推进专业学位研究生产学研结合培养模式改革,构建应用型、复合型人才培养体系 。
Go语言判断某天是否为某个月的最后一天String tempStr = "ssssgoodssss";
int result = tempStr.indexOf("good");返回good在tempStr中go语言获取月份的序号
如果result=-1说明不含有指定go语言获取月份的字符串
go语言是一种什么语言Go语言是谷歌推出go语言获取月份的一种全新的编程语言go语言获取月份,可以在不损失应用程序性能的情况下降低代码的复杂性 。谷歌首席软件工程师罗布派克(Rob Pike)说:我们之所以开发Gogo语言获取月份,是因为过去10多年间软件开发的难度令人沮丧 。
Go是谷歌2009发布的第二款编程语言 。2009年7月份,谷歌曾发布了Simple语言,它是用来开发Android应用
Go Logo
的一种BASIC语言.
北京时间2010年1月10日,Go语言摘得了TIOBE公布的2009年年度大奖 。该奖项授予在2009年市场份额增长最多的编程语言 。
谷歌资深软件工程师罗布·派克(Rob Pike)表示,“Go让我体验到了从未有过的开发效率 。”派克表示 , 和今天的C或C一样,Go是一种系统语言 。他解释道,“使用它可以进行快速开发 , 同时它还是一个真正的编译语言,我们之所以现在将其开源 , 原因是我们认为它已经非常有用和强大 。”
2007年,谷歌把Go作为一个20%项目开始研发,即让员工抽出本职工作之外时间的20%,投入在该项目上 。除了派克外,该项目的成员还有其他谷歌工程师也参与研发 。
派克表示,编译后Go代码的运行速度与C语言非常接近,而且编译速度非常快,就像在使用一个交互式语言 。现有编程语言均未专门对多核处理器进行优化 。Go就是谷歌工程师为这类程序编写的一种语言 。它不是针对编程初学者设计的,但学习使用它也不是非常困难 。Go支持面向对象,而且具有真正的闭包(closures)和反射 (reflection)等功能 。
在学习曲线方面,派克认为Go与Java类似 , 对于Java开发者来说,应该能够轻松学会 Go 。之所以将Go作为一个开源项目发布,目的是让开源社区有机会创建更好的工具来使用该语言 , 例如 Eclipse IDE中的插件 。
在谷歌公开发布的所有网络应用中,均没有使用Go,但是谷歌已经使用该语言开发了几个内部项目 。派克表示 , Go是否会对谷歌即将推出的Chrome OS产生影响,还言之尚早,不过Go的确可以和Native Client配合使用 。他表示“Go可以让应用完美的运行在浏览器内 。”例如,使用Go可以更高效的实现Wave,无论是在前端还是后台 。
Go 同时具有两种编译器,一种是建立在GCC基础上的Gccgo,另外一种是分别针对64位x64和32位x86计算机的一套编译器(6g和8g) 。谷歌目前正在研发其对ARM芯片和Android设备的支持 。派克表示 , “Android手机存在的问题是,我们一直没有一个数学协处理器 。
Go语言是做什么的应用于搭建 Web 服务器,存储集群或类似用途的巨型中央服务器的系统编程语言 。
Go 是谷歌的编程语言,而不是社区的 。在这位博主看来,虽然 Go 语言拥有一个贡献者社区,但是它并不是社区的项目,只是谷歌的一个项目 。所以只要是谷歌反对的东西,没有人可以把这个东西加到 Go 语言中 。
InfoQ 采访人员也第一时间联系了《Go 并发编程实战》作者、前轻松筹大数据负责人郝林,他的观点是:Go 语言是大家的,只有伪爱好者才会谈舍弃 。在郝林看来 , Go 语言官方团队在谷歌内部实属一个很小的团队,但其成员几乎个个都是技术大神 。
很多社区成员为 Go 语言贡献了很多重要并且有价值的东西,这些从贡献者和提交者的多样性就可以看出来 。但谷歌作为整个 Go 社区的守门人,它独自决定什么东西可以被 Go 语言接受,什么不能被接受 。
在 Go 语言模块系统上发生的一件事情,谷歌 Go 语言核心团队的一名成员放弃了由外部 Go 社区开发的一个模块系统 , 因为它使用了另一种不同的模型 。Go 语言拥有一个贡献者社区,但是它并不是一个社区项目 。
go语言获取月份的介绍就聊到这里吧 , 感谢你花时间阅读本站内容,更多关于go语言示例、go语言获取月份的信息别忘了在本站进行查找喔 。
推荐阅读
- 2000能买什么cpu,2000能买什么电子产品
- gis差值怎么改像元大小,arcgis怎么修改像元大小
- gtx显卡怎么分等级的简单介绍
- 网络直播的审美取向是什么,直播的美学特征
- python转文字的函数 python怎样将文字转成字符串
- 电脑战略经营游戏有哪些,电脑经营策略类游戏
- sqlservercpu分配,sqlserver的cpu占用内存大
- go语言慢 go语言效率到底怎么样
- sap界面是什么样的,sap里面的