草庐IT

动态sql

全部标签

go - 在 Go 中解析动态时间格式

我正在使用一个外部API,如果最后一个值为零,它有时会缩短返回的时间戳。layout:="2006-01-02T15:04:05.000"opened,err:=time.Parse(layout,externallyFormattedTimestamp)iferr!=nil{fmt.Println("somethingwentwrongparsingthetimestamp")fmt.Println(err.Error())}如果返回的externallyFormattedTimestamp是2018-11-05T06:19:59.827,这将毫无问题地解析。但如果返回的时间以零结尾

go - 填充作为参数给出的接口(interface)类型的一部分(例如,为数据库/sql 实现 ScanAll)

我们如何实现一个函数,该函数将返回SQL查询产生的所有行并将它们转换为dest这是一个接口(interface)数组(可能无法像Scan一样工作)?我假设目标数组必须作为函数的参数给出。但是,我仍然不知道我应该如何完成实现:funcGetAll(querystring,destinterface{})error{rows,err:=s.db.Query(query)iferr!=nil{returnerr}deferrows.Close()forrows.Next(){vardestRow???/*donothaveatype.usingreflect.TypeOf(dest).Ele

go - 使用 make 为不同的体系结构构建动态目标?

我正在寻找一种方法来基本上迭代架构列表并使用make构建独特的架构。例如,我有一个包含所有架构的变量,以及当前的静态目标。下面是我的(简化的)逻辑。ALL_ARCHES=amd64armarm64VERSION=$(shellgitsymbolic-ref--shortHEAD)-$(shellgitrev-parse--shortHEAD)cmd/mything/mything:cmd/mything/*.goCGO_ENABLED=0GOOS=linuxGOARCH=amd64gobuild-ldflags"-Xmain.version=$(VERSION)"-o$@cmd/myt

mysql - Go:sql RowsAffected with ON DUPLICATE KEY UPDATE

我很难找到一些合适的文档来描述RowsAffected值的语义,除此之外:RowsAffectedreturnsthenumberofrowsaffectedbyanupdate,insert,ordelete.Noteverydatabaseordatabasedrivermaysupportthis.我正在使用带有ONDUPLICATEKEYUPDATE的查询,更新后RowsAffected的值为2。是因为删除和插入减少到执行吗?服务器是MySql服务器Ver8.0.12forosx10.13onx86_64 最佳答案 mysq

oracle - 从 Go 应用程序到 Oracle 数据库的 SQL 查询引发错误?

我接下来使用article将Golang应用程序与远程Oracle数据库连接起来。应用程序在库的帮助下成功连接到数据库goracle.我也ping通了。当我进行sql查询时,应用程序引发错误。哪里错了?我注意到,如果从Controller文件(organizations.go)中删除所有代码到连接文件(Oracle.go),它会起作用。我究竟需要如何重构?错误:2019/03/1318:15:47http:panicserving[::1]:28363:runtimeerror:invalidmemoryaddressornilpointerdereferencegoroutine54

postgresql - 如何从 Go 中的 Cloud Function 连接到 Cloud-SQL?

对于一个项目,我正在尝试将云功能连接到云sql数据库设置,如thisquickstartguide中所述。.该功能配置在同一区域,服务帐户具有角色CloudSQL-Client。我通过我的计算机调用函数是这样的:gcloudfunctionscall--region=--data'{"recipient":"hello","requester":"hello","message":"test"}'与函数的连接正常,似乎只是对数据库的身份验证不起作用,但我不知道我失败的地方。我多次检查了密码、用户和连接名,重设了密码,还是不行。我发现了问题here与将云功能连接到云sql相关。我尝试用单

go - 如何将 web 模板变量设置为动态 html 和 golang 代码?

我在golang上有两个网页,我想将这个页面代码嵌入到{{.content}}变量(在templates/main.html中定义),根据即将到来的请求动态变化。例如,如果客人进入用户注册页面,我希望{{.content}}变量将是用户注册代码,否则是用户配置文件代码。templates/userregister.html页面代码;{{define"userregister"}}...{{.specialmessage}}...{{end}}templates/userprofile.html页面代码;{{define"userprofile"}}...{{.specialmessag

json - 在 golang 中动态地从 JSON 中删除 key

我有一个可变的JSON架构(json.RawMessage),它可以具有任意格式。我不知道编译时的格式。在golang中,我想检查root-JSON对象中是否存在一个键,如果存在,则完全删除该键并反序列化。例如,如果“foo”存在,我需要将其删除{"foo":[1,2,3],"bar123":"baz"}->{"bar123":"baz"}{"foo":"test","bar123":"baz"}->{"bar123":"baz"}{"foo":{"bar":"bar2"},"bar123":"baz"}->{"bar123":"baz"}{"bar123":"baz"}->{"bar

sql - 在插入或更新时返回数据时,我还需要使用 `Exec` 吗?

根据GoDatabaseSQL,它说要使用Exec来修改数据,而Query是错误的,因为在调用Rows.Close()之前底层连接一直保持打开状态.但是,我能想到两种情况,询问正确的模式是什么。1)使用sql.Tx进行多次更新,这将保持连接直到Tx.Rollback或Tx.Commit。在这种情况下,这重要吗?2)在更新、插入或删除时返回数据(尤其是在使用非基于整数的行ID时,如UUID)。在这种情况下,QueryRow似乎是合适的,尤其是因为它返回的Row没有Close只是Scan.然而,一个Tx可以打开写入然后立即读取,但这通常是很多额外的工作。我是否遗漏了这两个案例?我使用的是P

sql - 如果未找到行,QueryRow().Scan() 将返回错误。怎么解决?

我花了很多时间试图解决这个问题。我有一个结构:typeTokenstruct{Id*int64`db:"id"`Email*string`db:"email"`OperationType*string`db:"operation_type"`Token*string`db:"token"`ExpirationDate*time.Time`db:"expiration_date"`}我有一个通过电子邮件找到一个token的函数:func(rRepo2)FindOneByEmail(ctxcontext.Context,emailstring,ct*Token)error{row:=r.D