草庐IT

create-drop-databases-dynamically

全部标签

database - 在 Go 中以及可能在其他语言和其他数据库中比较 mongodb 驱动程序的时间精度问题

我正在学习Go和Mongodb,目前正在使用alphaofficialmongodbdriver.虽然它处于alpha阶段,但我认为它对于基本用法来说非常实用。但是我在这个数据库驱动程序中遇到了一个关于时间转换的有趣问题。基本上,我创建了一个自定义类型的结构对象,并将其编码为bson文档,然后将bson文档转换回结构对象。//checkgithub.com/mongodb/mongo-go-driver/blob/master/bson/marshal_test.gofuncTestUserStructToBsonAndBackwards(t*testing.T){u:=user{Us

go - "too many open files"与 os.Create

我要创建大约220,000个图像文件(.png)。我在尝试创建第1'081个文件时遇到此错误消息:panic:打开/media/Snaps/pics/image1081_0.png:打开的文件太多我添加了deferw.Close()行,但它并没有改变错误。i:=1fori当然可以绕过这个限制吗?也许我没有正确关闭文件? 最佳答案 TheGoProgrammingLanguageSpecificationDeferstatementsA"defer"statementinvokesafunctionwhoseexecutionisde

database - 如何向 PostgreSQL 插入 JSON 数据

我有像blow这样的json字段,我想将其存储在数据库中{id:1name:"testentity1"description:"atestentityforsomeguy'sblog"status:"passed"web_url:"http://localhost:3000"jobs:[{id:"1"name:"test1"status:"passed"},{id:"2"name:"test2"status:"passed"},{id:"3"name:"test3"status:"failed"}]}我继续使用一种方法,例如创建表用途:CREATETABLEtest3(idINTPRI

go - 带有 O_CREATE 标志的 os.OpenFile 抛出没有这样的文件或目录

我正在尝试使用os.OpenFile函数打开带有os包的日志文件,如果此类文件不存在,它应该使用适当的标志创建文件。但它返回非零错误:没有这样的文件或目录。顺便说一句,我正在使用linux并使用1.6。日志文件打开发生在init函数中。这是我的代码:packagemainimport("encoding/json""fmt""log""net/http""os""github.com/gorilla/mux""github.com/gorilla/sessions")//Structsholdsserverconfigurationdatafromconfigjson.typeserv

database - 从数据库获取数据并填充数组的Golang抽象函数

我想创建一个抽象函数,它从数据库中获取数据并用这些数据填充数组。数组的类型可以不同。由于性能问题,我想在没有反射(reflect)的情况下这样做。我只想在任何地方调用一些函数,如GetDBItems()并从数据库中获取所需类型的数据数组。但是我创建的所有实现都很糟糕。这是这个函数的实现:typeAbstractArrayGetterfunc(sizeint)[]interface{}funcGetItems(arrayGetterAbstractArrayGetter){res:=DBResponse{}DB.Get(&res)arr:=arrayGetter(len(res.Rows

database - 如何知道查询中是否检索到行 | Clickhouse 和 Golang

有一种方法可以知道查询是否使用Golang从clickhouse数据库中检索数据?我有这个:dataRows,err:=connect.Query(dbQuery)iferr!=nil{log.Fatal(err)}deferdataRows.Close()我想知道你是否可以这样做:varrowsRetrievedint=dataRows.RowsCount谢谢,非常感谢您的帮助。 最佳答案 假设您只需要知道是否有任何行,您可以这样做:dataRows,err:=connect.Query(dbQuery)iferr!=nil{lo

unit-testing - 如何使用 os.O_RDWR 和 os.O_CREATE 标志测试 file.Open?

我正在尝试为结构构造函数编写单元测试,如果在file.Open期间发生错误,它也可能返回nil。我不知道如何使用标志测试/模拟文件错误:os.O_RDWR|os.O_CREATE|os.O_APPEND我试图在测试中检查nil值,但失败了。构造函数:typeAppstruct{someFieldstringlog*log.Logger}funcNew()*App{app:=&App{}f,err:=os.OpenFile("info.log",os.O_RDWR|os.O_CREATE|os.O_APPEND,0666)iferr!=nil{fmt.Printf("erroropeni

database - 测试数据库交互

我有一个具有存储层的API。它只进行数据库交互并执行CRUD操作。现在我想测试这些功能。在我的路径API/storage/中,我有不同的包,这些包具有与同一数据库中的不同表进行交互的功能。表A、B和C在同一个数据库中。我的文件层次结构如下:--api--storage--A--A.go--A_test.go--B--C--server--A--testData--A.sql--B.sql这样我想用命令测试整个存储层gotest./...我遵循的方法是我有一个函数RefreshTables,它首先截断表,然后用我保存在testData文件夹中的固定测试数据填充它。对于截断我这样做:db.

sql - 使用GoLang包“database/sql”时,是否可以使用通用类型变量检索查询结果

我上一个问题的推论:IsitpossibletoretrieveacolumnvaluebynameusingGoLangdatabase.sql:sql.Rows.scan()需要一个正确键入的变量,该变量正确放置在scan()调用中。这可能很乏味,并且还要求开发人员具有可用的db模式-并不总是可行的。我试图通过所有参数传递一个空的interface{}指针来使其工作。但这到目前为止还不能很好地解决,并且在访问值时还需要类型声明,这将很昂贵。有没有办法做到这一点? 最佳答案 在golang坚果邮件列表中,对此进行了更长的讨论。参见

json - Go 和 JSON : how to dynamically load a field

我知道如何在go中使用JSON和接口(interface)而没有太多问题。我想让用户从JSON字符串中选择一个JSON元素,并将元素模式存储在一个字符串中,以便我以后可以动态加载它。我有以下JSON:{"id":1,"name":"Agreendoor","price":12.50,"tags":["home","green"]}当然,如果我想要我的JSON的id元素,这很容易,因为id是我要保存的字符串。现在假设我想要标签[1]。随着JSON变得越来越复杂,您会发现这变得越来越难。例如,我可能想保存类似于tags[1].data[0].values.id等的模式......基本上,我