草庐IT

value_for_database

全部标签

戈朗 : building interfaces for existing types to make code testable

为了使调用sql包的代码可测试,我构建了以下2个接口(interface):typeDatabaseinterface{Close()errorQuery(string,...interface{})(DatabaseRows,error)}typeDatabaseRowsinterface{Close()errorNext()boolScan(...interface{})error}我要测试的实际代码是:funcgetDatabase(connectionStringstring)(dbDatabase,errerror){ifdb,err=sql.Open("mysql",con

database - golang 数据库更新一个不存在的条目

我有一个更新数据库条目的函数,如下所示。逻辑是更新不存在的条目会返回错误。不知何故,我发现代码在错误处理方面有点冗长。有一个更好的方法吗?谢谢。func(adb*AppDB)UpdateTicket(tTicket)error{result,err:=adb.db.NamedExec(`UPDATEticketSETdetail=:detail,start_time=:start_time,end_time=:end_time,priority=:priorityWHEREid=:id;`,&t)iferr!=nil{returnerr}nRows,err:=result.RowsAf

database - 使用 Golang 检索 SQLite Pragma user_version

这是我使用SQLite的第一个项目,在尝试进行半自动模式迁移时,我想使用stackoverflow上许多其他答案所建议的user_versionpragma。我正尝试在Golang中执行此操作,但不确定我是否应该使用Exec、Query或类似的东西来获得此结果,然后如何将其呈现为可用的东西。在sqlite3中我可以运行'PRAGMAuser_version;'它将返回3或我设置的任何值。 最佳答案 当您使用PRAGMAuser_version读取值时,此语句的行为与查询完全相同,即SELECTuser_versionFROMsome

mysql - 使用 GORM for Golang 的一对一关系映射

我想了解GORM如何与MySQL进行一对一的关系映射。我有2个这样的结构:typeUserstruct{Iduint`gorm:"AUTO_INCREMENT"`FirstNamestring`gorm:"column:first_name"`LastNamestring`gorm:"column:last_name"`EncryptedUserIdstring`gorm:"size:255"`Emailstring`gorm:"notnull;unique"`Passwordstring`gorm:"notnull;unique"`CreatedAtint64`gorm:"type(

javascript - 使用来自 WebSocket 的 JSON 的 Golang 模板范围(for 循环)

我正在使用GorillaWebsocket更新一些HTML(imgsrc、文本等);我通过以下方式执行此操作:mt,message,err:=c.ReadMessage()iferr!=nil{log.Println("read:",err)break}[...]app,err:=models.DB.SearchAppStore(ctx,stars,updatedWithin,0)myJson,err:=json.Marshal(app)err=c.WriteMessage(mt,myJson)iferr!=nil{log.Println("write:",err)break}然后我使

JSON 写入创世 block 失败 : invalid character '\\' looking for beginning of object key string

我正在尝试构建genesis,但在构建过程中遇到了很多错误。在同一目录的终端上输入gethinitgenesis.json后,我得到了这个:Caros-MacBook-Pro:testcmycaro$gethinitgenesis.jsonI022318:52:32.817358ethdb/database.go:83]Allotted128MBcacheand1024filehandlesto/Users/caro/Library/Ethereum/geth/chaindataI022318:52:32.976868ethdb/database.go:176]closeddb:/Us

regex - 去正则表达式 : how I can replace named groups by concrete values in source pattern?

也许,你可以帮我。例如,我有像(?P\w+)(?P\w+)这样的正则表达式.我如何使用map[string]string{"name":"Alice","surname":"Cool"}替换组以获得字符串AliceCool?这可能吗?谢谢。 最佳答案 好的,我找到了制作方法。希望它会对某人有所帮助。https://play.golang.org/p/Xz9PtE_bIt 关于regex-去正则表达式:howIcanreplacenamedgroupsbyconcretevaluesins

database - BTrDB 连接失败

我有一个在我的VM上运行的BTrDB容器的副本和一个Go程序,该程序试图通过从CSV中获取数据并将其插入来测试它。不幸的是,我在尝试连接时遇到错误ctx,_:=context.WithDeadline(context.TODO(),time.Now().Add(time.Duration(30)*time.Second))_,err:=btrdb.Connect(ctx,"192.168.99.100:4410")iferr!=nil{log.Fatal("Unexpectedconnectionerror:%v",err)}产量2017/03/1414:09:17transport:

go - for循环中的条件验证

我下面的平方根代码工作正常packagemainimport("fmt""math")funcmain(){fmt.Println(Sqrt(9))}funcSqrt(xfloat64)float64{v:=float64(1)p:=float64(0)for{p=vv-=(v*v-x)/(2*v)fmt.Println(toFixed(p,5),toFixed(v,5))iftoFixed(p,5)==toFixed(v,5){break}}returnv}functoFixed(numfloat64,precisionint)float64{output:=math.Pow(10,

Golang unix 套接字 : registering same type for RPC on different sockets?

我在Go中工作,对使用unix套接字有点陌生。尝试搜索类似的问题,但找不到任何内容,如果之前已经回答过,我们深表歉意。我想用unixsockets模拟一个机器集群进行测试。我正在测试我的Raft实现,所以我想在不同的unix套接字上注册相同类型的多个对象(一个庞大的结构)。但是看我写的一个简单的例子,效果似乎不是我想要的:为同一个导出方法拨不同的套接字似乎在单个端口上崩溃:packagemainimport("net""fmt""net/rpc""log""sync")typeServerstruct{namestring}typeSpeakArgsstruct{}typeSpeakR