草庐IT

connect2db

全部标签

go - 由结构包装的 sql.DB 无法在实例中调用方法

我的目标是使用一个结构来包装sql.DB来做一些比sql.DB更重要的事情。我创建的实例无法运行,运行时出现此错误。DbConn.db.prepareundefined(cannotrefertounexportedfieldormethodsql.(*DB)."".prepare)我的代码是:typeDatabaseConnstruct{driverNamestringdatabaseNamestringuserNamestringpasswordstringdataSourceNamestringdb*sql.DB}func(dDatabaseConn)Open()error{d.

amazon-web-services - 转到 AWS SQS SDK : How to check if session is connected/disconnected

varsvc*sqs.SQS=nilfuncreturnSvcInstance()*sqs.SQS{ifsvc==nil||condition(checkifnotconnected){//checkifitisconnected?sess:=session.New(&aws.Config{Region:aws.String(REGION),Credentials:CREDS,})svc=sqs.New(sess)}returnsvc}我正在编写一个方法,如果实例为nil或未连接则返回实例。如何检查它是否仍然连接? 最佳答案 我的解

go - 为什么 'Open connection failed:sql: unknown driver "mssql“(忘记导入?)”会在 go build 中第一次发生?

我第一次跑https://github.com/denisenkom/go-mssqldb/blob/master/examples/simple.go我收到错误“打开连接失败:sql:未知驱动程序“mssql”(忘记导入?)”我通过更改解决了这个问题导入_“github.com/denisenkom/go-mssqldb”到导入“github.com/denisenkom/go-mssqldb”这给出了一个不同的错误“导入但未使用:“github.com/denisenkom/go-mssqldb”作为mssql”。但是......在改回import_"github.com/deni

mysql - 在没有 gorm 的情况下使用 mysql db 进行 revel

我已将所有内容放入app.go中,数据库可以正确打开,但Index无法访问全局变量。全局变量似乎不是全局变量,因为如果我在InitDB中分配Db后删除它的使用,我会收到错误“Db已声明但未使用”packagecontrollersimport("database/sql""fmt"_"github.com/go-sql-driver/mysql""github.com/revel/revel")varDb*sql.DBtypeAppstruct{*revel.Controller}func(cApp)Index()revel.Result{ifc.Params.Get("id")=="

go - 从 DB golang 查询后收到 304 代码

我现在正在尝试实现一个API,第一步是创建一个session,然后使用get请求查询这个session。有时我会收到304NotModified–结果自上次投票后未修改的响应代码,这对我来说似乎是随机的。在这种情况下,我无法将响应保存到Golang结构中。这是非常令人沮丧的。你有什么见解可能是什么问题?谢谢!client:=&http.Client{Timeout:10*time.Second}req,err:=http.NewRequest("GET",url,nil)q:=req.URL.Query()q.Add("apiKey",apiKey)q.Add("sortorder",

go - 如何捕获 "http: server closed idle connection"错误

在我的go应用程序中,我收到以下错误:“http:服务器关闭空闲连接”。我想捕获它并在遇到它时重试我的http连接。我发现这个错误来自“net/http”包,而且来自传输实现。特别是它定义了here我把它包裹在url.Error中,但这就是我能找到的全部。你知道我怎样才能真正捕捉到这个错误吗?编辑:我正在使用elasticsearchclient,它又使用net/http。我从客户端收到上述错误,并希望重试我的Elasticsearch请求,因为它是暂时的。现在我捕捉暂时性错误的方式是:ifurlErr,ok:=err.(*url.Error);ok&&(urlErr.Temporar

mysql - 从 sphinx db 到有点复杂的 golang 结构的最佳实践

我正在尝试通过MySQL将sphinx查询转换为golang结构,但遇到了困难。看起来这应该是一种常见的问题,但到目前为止,我一直坚持将其转换为map或自己解析输出。具体来说,我在sphinx中有一个模式,看起来像{Source:{ID:string,subId:string,Campaigns:[]{CampaignID:string,Status:string}}}我试过使用简单的rows.scan,但这并不能帮助我解析重复字段,我只是将其作为未解析的字符串获取。在sphinx中,key不在引号中,因此JSON.unmarshal似乎根本没有帮助。并使用sqlx,我尝试构建以下结构

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:

http - 戈朗 : strategies to prevent connection reset by peer errors

该程序同时生成许多goroutines(getStock),我相信这会导致远程服务器立即断开连接。我不是要创建DOS,但我仍然想在不出现“连接重置”错误的情况下积极获取数据。最多只能有N(例如20)个同时连接的策略是什么?golang的Http客户端有内置GET请求队列吗?我仍在学习,如果能了解是否有针对此类代码的更好设计模式,那就太好了。输出$goruns1w.gosl(size):1280body:"AAPL",17.92body:"GOOG",32.13body:"FB",42.02body:"AMZN",195.83body:"GOOG",32.13body:"AMZN",19

database - 无法使 Goose DB Migration 用于 Go 测试

我目前正在学习用于Web编程的Golang,现在我将继续学习数据库、RestAPI和Golang中的测试。现在我遇到了Goose的问题数据库迁移和Go测试集成。我想将goose迁移集成到我的Go测试代码中,我的方案是在测试之前启动所有迁移,然后在测试完成后重置所有数据库。我的问题是我找不到任何文档/示例代码来使用Goose.我也尝试执行goose命令使用exec.Command()但它始终返回exitstatus1这是我在执行测试之前触发迁移的现有代码:funcpretest(){varargs=[]string{os.Getenv("DB_SERVER"),"\"user="+os.