草庐IT

动态sql

全部标签

sql - Golang sql 包查询比 PostgreSQL SQL 查询慢

我正在使用GolangSQL包来调用我的数据库。我正在使用准备好的语句,并且在列上有索引stmtHas:=db.Prepare(`SELECTvalueFROM`+tableName+`WHEREkey=$1;`)now:=time.Now()err:=db.stmtGet.QueryRow(key).Scan(&value)elapsed:=time.Since(now)fmt.Println(elapsed)这会打印-40.874782ms然而,与此相比,原始SQL查询花费的时间要少得多。EXPLAIN(ANALYZE,BUFFERS)SELECTvalueFROMtableNam

go - 您可以通过 json 键字段动态迭代 Go 中的结构字段吗?

typeParamsstruct{MyNumstring`json:"req_num"`}所以我需要将MyNum的值分配给另一个变量,给定一个“req_num”字符串键,用于我在beego框架。这在Go中是否可行?如果可行,如何实现?我查看了反射库,找不到方法。这是我正在尝试做的一个例子。params是一个Params类型的变量,MyNum的值初始化为“123”让我们说。f目前没有得到“123”。当我将其记录到控制台时,它显示""。b:="req_num"r:=reflect.ValueOf(params)f:=reflect.Indirect(r).FieldByName(b)编辑:

html - 使用 golang 的 DataTable 中的动态 URL

我正在尝试使用golang在DataTable中创建动态URL想法是用一些图标从表格中删除一个元素Screenshotofthetable列是通过直接传递链接在Controller中创建的所有这些都是在咨询了BDD之后其中连接在字符串中的变量“id”代表每个元素cadenaS:=""cadenaT:=""his=append(his,History{ID:ID,Email:Email,Search:Search,Tipo:Tipo,Visited:Visited,Icon:&Icon{Search:cadenaS,Trash:cadenaT}})为了展示它,调用只是用响应json进行的

arrays - 动态数组json解析

我正在尝试解析json以进行langstruck,但一些对象如何返回空:Json对象:`{"names":[{"David":{"id":"100","country":"usa","group":["A1","A2"]}},{"John":{"id":"1","country":"uk","group":["A1","A2"]}}]}`GoLang结构:typeDatastruct{Names[]Names`json:"names"`}typeNamesstruct{IDstring`json:"id"`Countrystring`json:"country"`Group[]stri

Go:将许多慢速 API 查询引导到单个 SQL 事务中

我想知道下面的惯用方法是什么。我有N个慢速API查询和一个数据库连接,我想要一个缓冲channel,响应将来自该channel,以及一个我将用来写入数据的数据库事务。我只能想出以下化妆示例的信号量:funcmyFunc(){//10concurrentAPIcallssem:=make(chanbool,10)//AconcurrentsafemapasbuffervarmyMapMyConcurrentMapfori:=0;i我几乎可以肯定有更简单、更干净、更合适的解决方案,但对我来说似乎很难掌握。编辑:好吧,我提出了以下解决方案,这样我就不需要缓冲区映射,所以一旦数据到达respc

go - 如何在go中动态更改函数参数类型

关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭3年前。Improvethisquestion我有一个程序如下。我正在尝试动态更改函数参数的类型,因为我正在使用的另一个库需要传递具有具体类型的myMethod签名而不是该接口(interface)来进行正确的解码。在Go中是否有可能动态生成一个函数或匿名函数,其参数类型是动态生成的,或者可能更改函数的参数类型?packagemainimport("fmt""reflect")typeMyTypeinterface{doThis()}type

go - 使用go-sql-driver时如何区分连接错误和其他错误

funcmainloop(db*sql.DB){typepushTaskstruct{TaskIdstringUristring}stmt,err:=db.Prepare("INSERTINTOErrPushCache(TaskId,Uri)VALUES(?,?)")iferr!=nil{log.Fatal("db.PrepareFailed",err)}var(mysqlOkbool=truetaskpushTask)for{task.TaskId=RandStringRunes(8)task.Uri=RandStringRunes(16)res,err:=stmt.Exec(tas

go - 使用 gin 路由器处理 golang 中的动态子域的最佳方法是什么

大家好,我正在做一个项目,我需要用路由设置多个子域。我尝试了包含两个子域的代码,但在我的例子中是100个子域。我为此尝试了以下代码:packagemainimport("github.com/gin-gonic/gin""net/http""strings")typeSubdomainsmap[string]http.Handlerfunc(subdomainsSubdomains)ServeHTTP(whttp.ResponseWriter,r*http.Request){domainParts:=strings.Split(r.Host,".")ifmux:=subdomains[

GoLang 和打开 MS SQL Compact 文件 (.sdf)

如标题所示,我正在尝试在GoLang中打开SDF/MSSQLCE数据库。这可能吗?我发现的GoLang库似乎不支持MSSQLCE数据库连接。我希望这不是重复的,但我在网上找不到信息 最佳答案 恐怕几乎不可能直接使用这些文件,因为它们只是磁盘上的存储格式,请注意各种类型的MSSQL数据库都使用.sdf作为扩展名他们数据库的文件名,所以它们本身没有任何意义。OTOH,解决此问题的一种直接方法是使用OLEDBlayer. 关于GoLang和打开MSSQLCompact文件(.sdf),我们在S

odbc - golang : CSV file to MS SQL does not work properly without placing fmt. Printf() 到 for 循环结束

我正在使用Go读取CSV文件并使用go-odbc将记录保存在MSSQL数据库中。它工作得很好,但我有一些记录(大约10条记录)没有被存储的问题。这是一个随机问题,有时3条没有保存,其他时候2条,等等。保存所有记录的唯一时间是当我将fmt.Printf("")放在末尾时循环。请注意,它必须打印一个空格,它不能只是fmt.Printf("")。我不确定我没有做错什么。任何建议表示赞赏。此外,没有产生任何错误,程序正常终止。我包含了相关问题的代码,如果您需要我发布完整代码,请告诉我。Go版本:go1.1windows/amd64for{record,err:=c.Read()iferr==i