GO语言(三十):访问关系型数据库(上)

GO语言(三十):访问关系型数据库(上),第1张

本教程介绍了使用 Godatabase/sql及其标准库中的包访问关系数据库的基础知识。

您将使用的database/sql包包括用于连接数据库、执行事务、取消正在进行的 *** 作等的类型和函数。

在本教程中,您将创建一个数据库,然后编写代码来访问该数据库。您的示例项目将是有关老式爵士乐唱片的数据存储库。

首先,为您要编写的代码创建一个文件夹。

1、打开命令提示符并切换到您的主目录。

在 Linux 或 Mac 上:

在 Windows 上:

2、在命令提示符下,为您的代码创建一个名为 data-access 的目录。

3、创建一个模块,您可以在其中管理将在本教程中添加的依赖项。

运行go mod init命令,为其提供新代码的模块路径。

此命令创建一个 gomod 文件,您添加的依赖项将在其中列出以供跟踪。

注意: 在实际开发中,您会指定一个更符合您自己需求的模块路径。有关更多信息,请参阅一下文章。

GO语言(二十五):管理依赖项(上)

GO语言(二十六):管理依赖项(中)

GO语言(二十七):管理依赖项(下)

接下来,您将创建一个数据库。

在此步骤中,您将创建要使用的数据库。您将使用 DBMS 本身的 CLI 创建数据库和表,以及添加数据。

您将创建一个数据库,其中包含有关黑胶唱片上的老式爵士乐录音的数据。

这里的代码使用MySQL CLI,但大多数 DBMS 都有自己的 CLI,具有类似的功能。

1、打开一个新的命令提示符。

在命令行,登录到您的 DBMS,如下面的 MySQL 示例所示。

2、在mysql命令提示符下,创建一个数据库。

3、切到您刚刚创建的数据库,以便您可以添加表。

4、在文本编辑器的 data-access 文件夹中,创建一个名为 create-tablessql 的文件来保存用于添加表的 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、请注意驱动程序的包名称 - 此处为githubcom/go-sql-driver/mysql

4、使用您的文本编辑器,创建一个用于编写 Go 代码的文件,并将该文件作为 maingo 保存在您之前创建的数据访问目录中。

5、进入maingo,粘贴以下代码导入驱动包。

在此代码中:

(1)将您的代码添加到main包中,以便您可以独立执行它。

(2)导入 MySQL 驱动程序githubcom/go-sql-driver/mysql。

导入驱动程序后,您将开始编写代码以访问数据库。

现在编写一些 Go 代码,让您使用数据库句柄访问数据库。

您将使用指向结构的指针sqlDB,它表示对特定数据库的访问。

编写代码

1、进入 maingo,在import您刚刚添加的代码下方,粘贴以下 Go 代码以创建数据库句柄。

在此代码中:

(3)使用 MySQL 驱动程序Config和FormatDSN类型以收集连接属性并将它们格式化为连接字符串的 DSN。

该Config结构使代码比连接字符串更容易阅读。

(4)调用sqlOpen 初始化db变量,传递 FormatDSN。

(5)检查来自 的错误sqlOpen。例如,如果您的数据库连接细节格式不正确,它可能会失败。

为了简化代码,您调用logFatal结束执行并将错误打印到控制台。在生产代码中,您会希望以更优雅的方式处理错误。

(6)调用DBPing以确认连接到数据库有效。在运行时, sqlOpen可能不会立即连接,具体取决于驱动程序。您在Ping此处使用以确认 database/sql包可以在需要时连接。

(7)检查来自Ping的错误,以防连接失败。

(8)Ping如果连接成功,则打印一条消息。

文件的顶部现在应该如下所示:

3、保存 maingo。

1、开始跟踪 MySQL 驱动程序模块作为依赖项。

使用go get 添加 githubcom/go-sql-driver/mysql 模块作为您自己模块的依赖项。使用点参数表示“获取当前目录中代码的依赖项”。

2、在命令提示符下,设置Go 程序使用的DBUSER和DBPASS环境变量。

在 Linux 或 Mac 上:

在 Windows 上:

3、在包含 maingo 的目录中的命令行中,通过键入go run来运行代码。

连接成功了!

接下来,您将查询一些数据。

开始本文之前,我们看一段Go连接数据库的代码:

本文内容我们将解释连接池背后是如何工作的,并 探索 如何配置数据库能改变或优化其性能。

转自:>

字段标签允许您将元信息附加到可以使用反射获取的字段上。通常,它用于提供有关如何将结构域编码为另一种格式(或从另一种格式存储(或从数据库中检索))的转换信息,但是您可以使用它存储想要存储的任何元信息,这些元信息既可以用于另一种包装或供您自己使用。

如的文档所述reflectStructTag,按照惯例,标记字符串的值是用空格分隔的key:"value"成对列表,如:

type User struct {

Name string `json:"name" xml:"name"`

}

的key通常表示包,随后的"value"是,如json密钥被处理/使用的encoding/json包。

如果要在中传递多个信息"value",通常通过用逗号(',')隔开来指定它,如

Name string `json:"name,omitempty" xml:"name"`

通常用破折号('-')"value"表示将字段从过程中排除(如,在这种情况下,json表示不封送或取消封送该字段)。

使用反射访问自定义标签的示例

我们可以使用反射(reflect包)来访问结构字段的标记值。基本上,我们需要获取Type结构的,然后可以使用TypeField(i

int)或查询字段TypeFieldByName(name

string)。这些方法返回的值StructField描述/表示一个struct字段;并且StructFieldTag是StructTag描述/表示标记值的类型值。

以前我们谈论过 “惯例” 。该公约的手段,如果你遵循它,你可以使用StructTagGet(key

string)它解析变量的值,并返回该方法"value"的key指定。该公约实施/内置到这个Get()方法。如果不遵守约定,Get()将无法解析key:"value"对并找到您要查找的内容。这也不是问题,但是随后您需要实现自己的解析逻辑。

还有StructTagLookup()(在Go17中添加了),它 “类似于,Get()但是将不包含给定键的标签与将空字符串与给定键相关联的标签区分开”。因此,看一个简单的示例:

type User struct {

Name  string `mytag:"MyName"`

Email string `mytag:"MyEmail"`}

u := User{"Bob", "bob@mycompanycom"}

t := reflectTypeOf(u)for _, fieldName := range []string{"Name", "Email"} {

field, found := tFieldByName(fieldName)    if !found {        continue

}

fmtPrintf("\nField: User%s\n", fieldName)

fmtPrintf("\tWhole tag value : %q\n", fieldTag)

fmtPrintf("\tValue of 'mytag': %q\n", fieldTagGet("mytag"))

}

输出(在Go Playground上尝试):

Field: UserName

Whole tag value : "mytag:\"MyName\""

Value of 'mytag': "MyName"Field: UserEmail

Whole tag value : "mytag:\"MyEmail\""

Value of 'mytag': "MyEmail"

GopherCon 2015上有一个关于struct标签的演示,名为:结构标签的许多面孔(幻灯片)

(和视频)以下是常用标签键的列表:

json-由encoding/json包装使用,详细说明jsonMarshal()

xml-由encoding/xml包装使用,详细说明xmlMarshal()

bson-由gobson使用,详细说明bsonMarshal()

protobuf-由githubcom/golang/protobuf/proto,在软件包doc中有详细说明

yaml-由gopkgin/yamlv2包装使用,详细说明yamlMarshal()

db-由githubcom/jmoiron/sqlx包装使用;也被githubcom/go-gorp/gorp包装使用

orm-由githubcom/astaxie/beego/orm包装使用,在“ 型号– Beego ORM”中有详细说明

gorm-由githubcom/jinzhu/gorm软件包使用,示例可在其文档中找到:模型

valid-由githubcom/asaskevich/govalidator软件包使用,示例可以在项目页面中找到

datastore-由appengine/datastore(Google App Engine平台,数据存储区服务)使用,在“ 属性”中有详细说明

schema-用于通过HTML表单值githubcom/gorilla/schema填充(struct包文档中有详细说明)

asn-由encoding/asn1包装使用,详细说明在asn1Marshal()和asn1Unmarshal()

csv-由githubcom/gocarina/gocsv包装使用

以上就是关于GO语言(三十):访问关系型数据库(上)全部的内容,包括:GO语言(三十):访问关系型数据库(上)、使用Go实现一个数据库连接池、Go中标签的用途是什么等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9506990.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-29
下一篇 2023-04-29

发表评论

登录后才能评论

评论列表(0条)

保存