草庐IT

动态sql

全部标签

sql - 在 Golang 中重用或复制 *sql.Rows

是否可以在调用*sql.Rows.Next()之后重用相同的*sql.Rows,以便我可以将它传递给另一个函数?rows,err:=db.Query(...)forrows.Next(){//rows.Scan()}anotherFunction(rows)//NOTWORKING:Thisrowsbecameempty.我试图制作另一个*sql.Rows的副本,但没有成功。rows,err:=db.Query(...)anotherRows:=*rows//PANIC:callofloadcopieslockvalue:database/sql.Rowscontainssync.RW

json - 在 Go 中解码动态 json 内容

我有一个动态json对象,我想在我的Go应用程序中对其进行解码。问题是json的某些部分是动态命名的,所以我不知道在struc类型的json标签中放什么。为了说明我的问题,请看这个Playground:https://play.golang.org/p/q8J0VVO7uj如您所见,s1可以完美地解码,因为结构类型确实具有标记description。但是s2无法解码。所以我的问题是:我该如何解决这个问题?我可以在这里使用接口(interface)吗? 最佳答案 为动态键使用映射:typeElvisEventstruct{Timest

mysql - 具有多个参数的 Golang 数据库/sql.DB.QueryRow

我想执行这样的查询(使用MySql):select*fromuserwhereid=5Ex1.这将返回err=sql.ErrNoRows:err:=db.QueryRow("select*fromuserwhere?=?",f,v).Scan(&user.Id,etc...)Ex2.由于上面的方法不起作用,我正在这样做,它起作用但感觉不对:err:=db.QueryRow("select*fromuserwhere"+f+"=?",v).Scan(&user.Id,etc...)Ex中有什么问题?1?Ex2.是一种可以接受的方法吗?编辑从评论中的链接我可以用第三种方式来做。示例3:q:

Golang 如何使用 sql 查询行检查错误

我正在使用postgres数据库,并以用于API的字符串形式从数据库返回Json响应。我的问题是我不知道如何使用QueryRowMethod检查错误。这是我的代码,它工作正常。那只是显示了一个Json响应。但是,我有一个自定义函数,如果代码有错误并且QueryRow不允许我检查错误,我想使用它有什么建议吗?varresultstringdb.QueryRowContext(ctx,"selectjson_build_object('Profile',array_to_json(array_agg(t)))from"+"(selectp.id,p.fullname,z.thirtylat

go - 如何创建动态路线

我想弄清楚如何创建一个动态路由,我可以在其中查询我的结构的某些部分。例如,假设我有以下结构。typeNewsstruct{Idint64`json:"id"`Categorystring`json:"category"`ImageUrlstring`json:"image_url"`Titlestring`json:"title"`Descriptionstring`json:"description"`Sourcestring`json:"source"`}现在,我将如何创建一条路线,例如localhost:1234/news?title="sometitle"&source="so

mysql - App Engine 中的 GoLang 动态 SQL 查询

我想在GoLang中制作动态sql,但似乎找不到正确的方法。基本上,我只想做:query:="SELECTid,email,somethingFROMUser"varparamValues[]stringfilterString:=""ifuserParams.Name!=""{paramString+="WHEREid=?"paramValues=append(paramValues,userParams.Name)}ifuserParams.UserID!=""{iflen(paramString)>0{paramString+="AND"}else{paramString+="W

sql - Go SQL 扫描/值接口(interface)问题

我正在尝试为我的自定义结构添加自动转换的扫描/值接口(interface)。我还能够在bool类型上实现Value()和Scan(),但是当尝试在具有gocql.UUID字段的东西上实现它时,我无法让Scan()工作。如有任何建议,我们将不胜感激!简短示例:typeUidstruct{gocql.UUID}func(u*Uid)Scan(valueinterface{})error{...ifsv,err:=driver.String.ConvertValue(value);err==nil{ifv,ok:=sv.(string);ok{//完整代码:https://play.gola

arrays - 如何在 golang 运行时动态设置数组的索引?

我已经搜索了很多,但找不到合适的解决方案。我想要做的是使用golang中的数组和slice创建以下内容作为最终输出。[11=>[1,2,3],12=>[4,5],]我实现的是:typeIndustriesstruct{IndustryIdint`json:"industry_id"`FormIds[]int`json:"form_ids"`}varIndustrySettingsIndustrySettings_:=json.NewDecoder(c.Request.Body).Decode(&IndustrySettings)varindustryArr[]intfor_,val:=

json - 从 golang Post Form 获取动态数组

我目前在Golang工作,我正在开发一个API,在一个POST处理程序中,我需要在Post表单中接收一个数组,但具有命名位置,我的意思是,像这样:myarray[a]:"someValue"myarray[otherName]:"someOthervalue"myarray[x]:"somethingdifferent"现在我正在尝试在CLI中使用curl发出Post请求。我要发送这个:curl-i-XPOST--urlhttp://localhost:20000/myendpoint-H"Content-Type:application/x-www-form-urlencoded"-

sql - 奇怪的 Golang SQL 错误 - WHERE 子句

我正在使用sqlx库在Golang中运行查询:rows,dbErr:=db.Queryx(`SELECT*FROMtable_aasaINNERJOINtable_bASbONa.b_id=b.id  WHEREb.id='b3c06feb-8bd1-42e1-b516-c1121990ff81';`)查询在语法上是正确的,并且在Postico、终端等中运行良好。但是,当我尝试在Golang中运行此查询时,我收到错误pq:syntaxerroratornear"WHERE"谁能解释这种奇怪的行为? 最佳答案 问题是过时的依赖项。我们