草庐IT

动态sql

全部标签

sql - Golang 中函数的泛化

我想编写一个处理SQL查询的通用函数。Sqlx模块提供函数StructScan(),自动将结果扫描到struct字段中。typePlacestruct{CountrystringCitysql.NullStringTelephoneCodeint`db:"telcode"`}rows,err:=db.Queryx("SELECT*FROMplace")forrows.Next(){varpPlaceerr=rows.StructScan(&p)}因此,建议的函数签名如下所示:funcQuery(db*sql.DB,query){rows,err:=db.Queryx("SELECT*F

go - 如何在 slice 中分配动态类型

我制作了一个应用程序来反转slice/数组。用我自己的类型制作slice时遇到问题。这里不行typemytypeintfuncmain(){//[]mytypedoesn'twork//varslice=[]mytype{11,22,33,44}但是如果我将mytype更改为int它将起作用//[]intItworksvarslice=[]int{11,22,33,44}错误说panic:接口(interface)转换:接口(interface){}是*[]main.mytype,而不是*[]int我发现错误来自这一行sliceType:=*slice.(*[]int)因为我将slic

mysql - 使用 Golang 将 SQL 查询结果放入嵌套结构中

下面是程序的全部代码。它是一种转发请求的服务。正在工作。我想要做的是摆脱当前存储所有配置的yml文件并将它们移动到db。我不想弄乱代码,所以我的想法是将数据库数据简单地存储在相同的结构中。//ConfigcontainsconfigurationforthisservicetypeInstancestruct{Userstring`json:"user"`Passwordstring`json:"password"`InstanceIdstring`json:"instance_id"`InstanceTypestring`json:"instance_type"`InstanceMo

sql - Go 和多行参数 hell

当我遇到一个相当烦人的事情时,我正在写一个包装器/验证器overpgingo...传递非常长的字符串作为参数。基本上我有这个字符串:"UPDATE"+m["table"]+"_tagsSETkeys=keys||,"+strconv.Itoa(key)+"WHEREtag="+t+";"+"INSERTINTO"m["table"]+"_tags(tag,keys)SELECT'"+t+"','"+strconv.Itoa(key)+")WHERENOTEXISTS(SELECT1FROM"+m["table"]"_tagsWHEREtag="+t+");"好吧,又大又笨重,充满了'和

sql - 为什么我不能在 golang 中使用多个参数 我的 sql 查询有什么问题?

我有多个参数的问题,我无法用sql查询实现2个参数。而且我仍然收到错误,错误显示mssql:“SequenceID”附近的语法不正确。我的查询sql有什么问题,或者我的代码有什么问题?packagemainimport("database/sql""fmt"_"github.com/denisenkom/go-mssqldb""github.com/gin-gonic/gin""net/http""time")funcmain(){db,err:=sql.Open("sqlserver","sqlserver://sa:@localhost:1433?database=CONFINS&

sql - 不能插入超过 150 行

我正在使用go-sql-driver/mysql从OMDB数据转储中插入大量电影。我正在解析数据并使用以下代码将其插入:_,err=database.Query("INSERTINTO`movies`(`name`,`year`,`release_date`,`full_plot`,`genre`,`imdb_id`)VALUES(?,?,?,?,?,?)",movie.Name,movie.Year,movie.ReleaseDate,movie.FullPlot,movie.Genre,movie.IMDBID)iferr!=nil{returnfalse,nil}returntr

sql - 像 python 风格一样获取行

在python中,它是一个简单的db.query("SELECTid,login,passwordFROMUsers")和返回列表[(1,'root','password'),(2,'toor','密码')]。我可以简单地迭代它foruserinresponse:print("id:%s,login:%s,password:%s",%(user[0],user[1],user[2]))但是在Golang中我找不到相关的简单方法的例子。我知道python有动态类型,golang是静态的。所以我在寻找答案,也许有些图书馆提供这样的功能?黑客?谢谢解答! 最佳答案

json - 动态分配结构

我有一个结构:typepersonstruct{FirstN[10]byteLastName[10]byteAddress[15]bytezip[6]byte}然后我有mapxyz=[01:aaaaaaaaaabbbbbbbbbbccccccccccccccc123456]这张map和我的结构完全一样。基本上,如果我用map中的字符串覆盖我的结构,它就是完全匹配的。我正在尝试使用Marshal获取此数据的JSON字符串。但是为此(据我所知)我需要将映射中的数据更新到结构中,然后将结构指针传递给Marshal但我无法找到任何方法从map中获取带有键“01”(字符串)的数据并用它初始化我的

go - 在动态结构函数 Golang 中修改结构值

我有带setter函数的结构packagemaintypePersonstruct{NamestringAgeint}func(p*Person)SetName(namestring){p.Name=name}funcSomeMethod(humaninterface{}){//Icallthesetterfunctionhere,butdoesn'tseemsexisthuman.SetName("Johnson")}funcmain(){p:=Person{Name:"Musk"}SomeMethod(&p)}报错如下:human.SetNameundefined(typeinte

arrays - 如何在 golang 中创建具有动态长度而不是 slice 的数组?

比如:我想用reflect把一个slice的数据作为一个数组来操作。funcinject(data[]int){sh:=(*reflect.SliceHeader)(unsafe.Pointer(&data))dh:=(*[len(data)]int)(unsafe.Pointer(sh.Data))printf("%v\n",dh)}此函数将发出编译错误,因为len(data)不是常量。我该如何解决? 最佳答案 添加到@icza的注释,您可以使用&data[0]轻松提取底层数组——假设data是一个初始化的slice。IOW,这里