草庐IT

自定义sql

全部标签

json - 为什么编码 JSON 结构成员不调用自定义 MarshalJSON?

在Golang中,我有一个结构体,其成员是具有常量值的自定义int类型。基本上,自定义类型是一个逻辑枚举。typeFlavorintconst(VanillaFlavor=iotaChocolateStrawberry)func(f*Flavor)MarshalJSON()([]byte,error){return[]byte(strconv.Quote(f.String())),nil}自定义类型定义了MarshalJSON和UnmarshalJSON函数,因此当我将自定义类型序列化为JSON时,我希望在序列化输出中获得值的string,而不是int值。我的问题是,如果我有一个指向包

go - 为什么golang自定义错误变量有多种类型

我是一个新的地鼠,如果我定义了一个自定义错误,我真的被变量类型搞糊涂了import("fmt""reflect")//customerrorstypemyErrorstruct{msgstring}func(m*myError)Error()string{returnm.msg}funcerrorGen()error{return&myError{"customerror"}}产生一个新的错误并检查它的类型funcmain(){e:=errorGen()fmt.Println(reflect.TypeOf(e).Kind())//type=pointer//firsttypeasser

go - 存在的方法显示为未定义的 golang

我试图从不同的目录调用一个方法,但收到一条错误消息,指出该方法不存在。我有首字母大写的方法。我有以下目录结构[laptop@laptopsrc]$tree.├──hello│  ├──hello.go├──remote_method│  └──remoteMethod.go我的main在hello.go中并尝试调用remote_method包中的函数packagemainimport("remote_method")funcmain(){mm:=remote_method.NewObject()mm.MethodCall()}remoteMethod.go有以下内容packagerem

http - 有什么方法可以自定义 HTTP 响应状态?

我需要在我的Web服务器的处理程序中自定义HTTP状态,但我发现golang似乎不支持完全自定义的HTTP响应。例如:w.WriteHeader(999)这是curl结果:$curl-vk-ilocalhost:9898/hello*Trying::1...*TCP_NODELAYset*Connectedtolocalhost(::1)port9898(#0)>GET/helloHTTP/1.1>Host:localhost:9898>User-Agent:curl/7.54.0>Accept:*/*>结果中的statuscode似乎无法修改..但是,我想定义自己的状态,比如BadR

logging - 是否可以修改其他包中定义的类型的方法集?

内置的log和log.Logger不提供Error或Warning方法,例如Python.所以我想用下面的代码为内置的Logger类型写一个:func(l*Logger)Error(vinterface{}){info:=fmt.Sprintf("ERROR:%v",v)l.Println(info)}然后我将上面的代码放在GOPATH/src/log下的文件morelog.go中。在main.go中我写道:logger:=log.New(os.Stdout,"Test",1)logger.Error("Errorinmain.")当我运行gobuild时,我得到:./main.go:

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

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

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

go - monorepo 和自定义目录结构中的多个 Go 模块

我有2个可能相关的问题。我有一个测试monorepo设置,有2个子目录(mod1和mod2)。它们中的每一个都有一个go.mod文件,每个模块都有一个包含基本打印代码的.go文件。在mod2中有一个子目录mod2_lib(其中包含一个带有基本打印代码的简单.go文件),因为我阅读了Go模块基本上是他们自己的小GOPATH。我想从mod1调用包mod2/mod2_lib中的函数Run(),但我得到的只是构建github.com/account_name/test/mod1:找不到路径github.com/account_name/test/mod2/mod2_lib的模块。这是我用来解决

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

go - 用未定义的整数键入 map

我正在为我的处理程序使用Gorillamux,并使用mux.Vars。我正在尝试为使用mux.Vars的处理程序之一编写测试,所以我所做的是varvars=map[string]string{"id":user.ID,}context.Set(req,0,vars)在mux中,键(整数)未定义,因此默认为0。我在mux.Vars被调用时记录了键,它打印了0。我应该能够键入此映射map[0:map[id:522d14f5b1b92235d6000002]]通过执行map[key]但返回nil。但是,如果我对map[0]进行硬编码,我会得到正确的值。有什么想法吗?