草庐IT

mysql-community-test

全部标签

mysql - 在go中连接到db mysql

我目前正在一个go项目中工作。我需要连接到mysql数据库并做一些事情。目前,我遇到了连接问题。首先,我从各种可能的来源(CLI、配置文件或启动参数,视情况而定)加载并存储数据库凭证dbCredentials=DatabaseCredentials{DRIVER_NAME,BOT_LOGIN_NAME+":"+BOT_PASSWORD+"@tcp("+HOST_NAME+")/"+NAME_OF_DB}稍后我尝试打开连接:db,err:=sql.Open(dbCredentials.driverName,dbCredentials.dataSourceName)checkErr(err

mysql - 参数化表名

这是我的问题:我想检查名称已参数化的表中的行,例如table_X。X的值来自另一个表,因此例如在我的主表中,我有一个列c_id和一个X列,要连接的表的名称为table_X,它毫无疑问存在,并且它有我将加入的同一列c_id,以检查该表中是否有c_id的值。我试过View,但没有成功,因为我无法在View中放置参数化表名。我可以参数化where子句和其他东西,但不能参数化表名。我试过一个程序,用SET@q=CONCAT('selectblablafromtable_',X);PREPAREstmtFROM@q;EXECUTEstmt;但是程序不能返回值,而我需要它,因为我需要知道参数化表中

mysql - 在子程序中处理数据库打开和关闭

我正在实现一个代码,我需要在固定的时间间隔内执行一些操作。其中很少与从mysql数据库中获取数据有关。为了以固定的时间间隔安排这些操作,我使用了gocron。它运行良好。对于数据库,截至目前,我在主程序开始时创建一个实例并将其传递给子例程。我正在使用https://github.com/jmoiron/sqlx与DB一起工作。代码流程是:i-初始化资源。例如db=sql.Open;将DB放在公共(public)结构中以传递给所有子例程ii-使用gocron的scheduleActions(根据需要传递资源)iii-Action是使用给定资源(例如数据库)根据需要执行任务的特定子例程我很

mysql - 如何在 Go 中为 MySQL 构建 RESTful API?

我的任务是将JSON负载插入到表中。(固定的)SQL表结构定义如下:$echo"describeut_invitation_api_data\G;"|mysql-hauroradb.dev.unee-t.com-P3306-ubugzilla--password=$(aws--profileuneet-devssmget-parameters--namesMYSQL_PASSWORD--with-decryption--queryParameters[0].Value--outputtext)bugzilla|grepFieldmysql:[Warning]Usingapassword

mysql - Beego QueryRows 映射失败

beegoRaw().QueryRows()的映射规则是什么这是我使用的结构:typeProcessingNetworkDataProviderConfigstruct{IdintNetworkIdintDataProviderIdintDistributorIdintEnableTargetingintEnableReportingintUsePrivateDataintUseExternalUserIdintUseUserMappingintUseUserAttributesintUserExchangeUrlstringEnableCacheintEnableBloomFilte

testing - 测试后清理数据

我编写测试,在这个测试中我使用一些保存的数据文件、数据库记录等。我应该在测试结束前删除这些数据吗?例如,我检查userfinderfunc(IDint)User(*User){//myfinderhere}在测试之前,我必须为数据库创建User。那么,我是否应该做类似的事情deferdb.Clean()???与文件相同*os.File 最佳答案 为了让我们都在同一个页面上,有许多不同形式的测试。这里我们将考虑单元测试和集成测试。如果您进行单元测试,我希望仅使用模拟,而不与文件交互。所以我假设这是为了某种集成测试。Thisisalin

testing - 我如何在 Go 中查看或测试优雅重启?

我通过gin's提供HTTPhttps://github.com/fvbock/endless.我想看看与基本HTTP服务器的区别。我发送了syscall.SIGUSR1信号:syscall.Kill(getPid(),syscall.SIGUSR1)应用程序没有退出,但我无法检测到重启。我要做的是在toml配置文件更改时为应用程序初始化新配置。我的代码如下:packagemainimport("os""fmt""syscall""github.com/gin-gonic/gin""github.com/fvbock/endless""github.com/BurntSushi/tom

unit-testing - 用于文件创建的表驱动测试

我从@volker那里得到了一个关于表驱动测试的例子,如下所示但目前我想念我应该在真正的测试中放什么,这个测试使用字节,目前我不确定在args和expected[]byte中放什么,例如我想检查文件中是否有2换行然后是application条目,我该怎么做而不需要创建真实文件并解析它?typeModelsstruct{namestringvtypestringcontentTypestring}funcsetFile(fileio.Writer,appStrModels){fmt.Fprint(file,"1.0")fmt.Fprint(file,"Created-By:applica

testing - Go gRPC 服务器使集成测试失败

我最近又开始玩go,我现在的任务是实现一个服务(将运行在k8s上),它应该充当gRPC服务器。根据要求,目前,为了满足k8s上的readinessProbe,我需要为我的服务实现一个健康检查端点,并且应该对其进行测试:我所做的是:funcmain(){server:=startHTTPServer()deferserver.Close()c:=make(chanos.Signal,1)signal.Notify(c,os.Interrupt,syscall.SIGTERM,syscall.SIGINT)我按照thisarticle这样测试的:funcTestMain(m*testing

unit-testing - 数据库连接get的单元测试策略

被测代码中有一个方法,它只是尝试获取数据库连接,如果无法连接则返回错误。它,以及涉及的结构体定义如下:typeDatabaseContextstruct{ContextDatabaseDatabaseSt}////GetInfoReturnsthecontext.//func(c*DatabaseContext)GetInfo()*Context{//return&c.Context//}//GetDBGetsthedatabaseconnectionfromtheconnectionstring.func(c*DatabaseContext)GetDB()(*sql.DB,*erro