草庐IT

避免全表扫描

全部标签

sql - 使用 Go 和数据库/sql 扫描 nil 浮点值时出错

我正在编写一个程序,需要在对该表执行一些插入和更新之前确定该表的开盘值。有问题的表(在本例中为PostgreSql)最初可能有零行。当我选择期初值时,如果行数为零,则余额值的总和将返回为零。这会导致扫描失败并显示消息:Erroronscanoftest01openingRowCount.Error=sql:Scanerroroncolumnindex1:convertingstring""toafloat64:strconv.ParseFloat:parsing"":invalidsyntax虽然我可以通过做两个选择来“解决”问题,一个选择COUNT(*)另一个选择SUM()如果行数超

go - 改进多个 map 访问并避免不正确的类型转换

我的项目中有这段代码://data.Objectsisamap[string]interface{}corporateName:=data.Objects["corporateName"].(string)dba:=data.Objects["dba"].(string)licence:=data.Objects["licence"].(string)resaleCert:=data.Objects["resaleCert"].(string)einNumber:=data.Objects["einNumber"].(string)phoneNumber:=data.Objects["

networking - 尝试在 go 中实现端口扫描器

我最近开始学习围棋。唯一的原因是goroutine似乎只存在于这种语言中(我有java背景,老实说,永远不会完全切换到go)。我想实现一个简单的端口扫描器,它可以在给定的网络范围内找到每个http服务器(打开端口80的主机)。以下是我的做法:packagemainimport("net""fmt""regexp""strconv""time")//nexttwofunctionsareshamelesslycopiedfromsomewherefuncip2long(ipstrstring)(ipuint32){r:=`^(\d{1,3})\.(\d{1,3})\.(\d{1,3})\

go - 扫描到 gorm 模型的结构

我正在尝试将查询结果扫描到由gorm模型组成的结果结构中。代码构建且查询通过,但结果数组由如下默认值组成:{{0000000001-01-0100:00:00+0000UTC0001-01-0100:00:00+0000UTC00001-01-0100:00:00+0000UTC{假}}{0000{0假}{0假}{0假}0001-01-0100:00:00+0000UTC假{0假}{0假}{假}{错误的}}}此外,结果数组的长度与查询结果的长度完全相同(当我通过pgadmin手动尝试时),但它们没有正确映射。这是可能的还是一个gorm错误。代码:主要包import("fmt""test

go - 如何避免通过 Go 提供模板文件

我正在用Go写一个小网站,我发现了一些我不知道如何解决的问题。所以...基本思想是为主题创建一个单独的文件夹,称为/themes/,我们将在其中放置所有主题,例如经典、现代等。目录树将如下所示:/themes/classic/index.htmlheader.htmlfooter.htmlcss/style.cssjs/lib.jsmodern/index.htmlheader.htmlfooter.htmlcss/style.cssjs/lib.js所以,我的http处理程序:funcmain(){reloadConfig()http.HandleFunc("/",homeHandl

mysql - 在golang中扫描到结构时得到错误的时间戳

我做了什么:1.execsql查询并在dbddl之后扫描到结构时获取错误的时间戳数据。数据库:SELECTstate,round,remark,ctimeFROMarchive_trackWHEREaid=?按id降序排序结构:typeArchivestruct{Timestamptime.Time`json:"timestamp"`Stateint`json:"state"`Roundint`json:"round"`Remarkstring`json:"remark,omitempty"`}去代码:a:=&Archive{}rows.Scan(&a.State,&a.Round,&

go - 如何避免同时打印字母数字的死锁

我是golang的新手,我只想打印出10个字母数字组合数字范围和字符范围的元素。我决定同时进行,但我遇到了有关死锁的错误。packagemainimport("fmt""math/rand""sync""time")typealphanumericstruct{anAlphabetstringaNumberstring}func(someStructalphanumeric)pairAlphanumeric()string{returnsomeStruct.aNumber+someStruct.anAlphabet}funcmain(){varwgsync.WaitGroupnumbe

go - 如何在匿名函数中逐行扫描文件并将其传递到 channel

我想编写一个函数,从文件中读取行,然后将其发送到channel以进行进一步处理。我是Go的新手,这里是我根据教科书示例想出的阅读器功能:funcreader(filestring)在main()函数中,我将文件指针传递给读取器函数,并尝试按如下方式排出输出channel:funcmain(){out:=reader(*f)forrangeout{fmt.Println(我没有收到编译或运行时错误,但是输出为空。如果我不将for循环放入goroutine中,我可以使用reader()函数打印文件而不会出现任何问题。我还尝试将reader()函数中的扫描器、channel或两者传递给匿名函

go - Golang扫描函数中 "ERROR: IOError: closed stream"如何处理?

我在Golang代码中使用knifebootstrap命令来引导节点。有时食谱中有等待,等待超过10分钟。在这种情况下,我收到错误“错误:IOStream关​​闭”。有什么办法可以增加时间限制吗?我也在不断地从cmd的输出和错误流中读取日志。funcexecuteCMDWorkstation(cmd*exec.Cmd,projectId,cr_idstring)bool{stdout,err3:=cmd.StdoutPipe()iferr3!=nil{utils.Info.Println(err3)returnfalse}deferstdout.Close()stderr,err4:=

go - 在 Ragel 中使用带有扫描仪 block 的堆栈的正确方法是什么?

我在Go中使用Ragel6.10。我确定这可能是我的代码有问题,但是当我尝试将堆栈与扫描仪block一起使用时,我遇到了一些奇怪的错误。我正在尝试设置括号匹配,我的代码大致如下所示;ObjectValues:=|*#otherstuff'}'=>{fret;};*|main:=('{'@{fcallObjectValues;})*;查看指南中的第46页,看起来这应该是可能的。当我运行Ragelragel-G2-Zmain.rl时。当我尝试编译时出现以下错误(它只发生在-G2FSM生成时);graphql_collections.rl:47[/Users/nathanfisher/wor