草庐IT

文档数据库

全部标签

go - 如何只让go文档的一部分出现在godocs中

我正在使用godocs来记录我用go/golang编写的API,我正在使用godocs来记录它,因为我生成了整个main.go文件的HTML页面,其中包含用于创建我的API的所有函数。但是,我不想显示有关我的所有辅助函数的信息,我只想显示有关文件中某些函数的标题信息。有没有办法只允许文件中的某些函数成为文档的一部分,或者我是否必须为我的所有辅助函数创建另一个文件?现在我正在本地端口8000上测试它:godoc-http=:8000 最佳答案 命令godoc及其堂兄弟godoc的默认行为,显示导出声明的包文档.奇怪的是,我没有找到一个

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

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

elasticsearch - 如何在 elasticsearch 中只存储有限数量的文档。

我只需要在特定索引下存储10个数字文档。第11项应替换旧项,即第1项。这样我在任何时候都只有10个文档。我在golang中使用elacticsearch 最佳答案 如果您只想存储10个文档,那么您应该应用algo=(documentno%10)+1。返回值是您的elasticsearch_id字段算法仅返回1到10。并始终对其进行索引。 关于elasticsearch-如何在elasticsearch中只存储有限数量的文档。,我们在StackOverflow上找到一个类似的问题:

mysql - 在 GORM 中,哪个是管理多个 mysql 数据库名称的最佳方法?

在我的用例中,每个用户都有一个数据库(我知道这不是最好的决定,而是项目要求)。我想打开一个连接并为每个查询更改数据库名称。我可以使用db.Exec("useclientdatabase;");在执行每个查询之前更改数据库,但如果同时另一个查询到达或正在执行可能会出现问题,因为所有应用程序都使用相同的数据库连接。也许,我可以使用每个客户端/数据库的连接映射,其中最大元素数为映射并删除旧连接。即使我可以为每个查询创建一个连接,但如果一个客户端有多个查询,这可能会浪费时间。 最佳答案 我找到了重用具有不同数据库名称的相同连接的方法。我的解

mongodb - 无法解析行 #126 : mongo. 数据库 = mongo_db_test

我正在学习本教程Golang+Revelwebframework+MongodbRESTFulgeneratorfor(revel_mgo)一步一步来,但是当我最终结束它并尝试运行它时,它抛出了这个错误CRIT16:11:18revel_container.go:139:无法加载配置文件error="C:\Users\Userx\go\src\RevelApp\conf\app.conf:无法解析第126行:mongo.database=RevelApp"第126行是这样的:[dev]126-mongo.database=mongo_db_test127-mongo.path=127.

go - 如何使用 testify/mock 在 golang 中模拟数据库层

我正在尝试在服务器上运行单元测试,并使用“github.com/strethr/testify/mock”模拟数据库层。将所有代码放在这里会使它变得非常困惑,所以我创建了一个小项目,它将给出我的代码结构的想法以及我真正想要实现的目标“https://github.com/utkarsh17ife/goMockPractice”。您可以提取此代码并运行“gotest./...”(不确定在这里提供github链接是否正确,但我觉得这会让事情变得更容易)Serverstruct有一个接口(interface)类型的字段db,所以当我们创建一个普通服务器时,db被分配给真实数据库,但在测试时它

go - 如何确定哪些数据库表列需要从修改后的结构中更新?

我面临的问题更多是代码设计,而不是具体的相关问题。我正在构建一个简单的CRUD应用程序,除了更新部分之外,一切似乎都很顺利:我有一个简单的结构类型:typeUserstruct{IDstringNamestringPasswordstring}和数据存储层的接口(interface):typeStoreinterface{...Update(user*User)error...}问题是,对于大多数数据库驱动程序,您不能只传递整个结构实例并希望他们的系统知道哪些字段被修改,整个文档/行被替换。我应该如何跟踪哪些字段被修改(以便我可以相应地在存储层中更新它们)?也许将我想修改的所有字段作为

GoLang 和 MySQL 数据库

是否有使用github.com/go-sql-driver/mysql包在Go中执行MySQL命令的更简单方法?基本上这是我正在使用的当前命令:db.Exec("INSERTINTOtable1(id,title,name,dob,address,email,notes)VALUES(?,?,?,?,?,?,?)",id,title,name,dob,address,email,notes)我将如何使用此命令:varpeople[]peoplefor_,person:=rangepeople{db.Exec("INSERTINTOtable1(id,title,name,dob,add

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.

go - 共享数据库全局处理程序时遇到问题

我的代码如下:packagemainimport("database/sql""fmt"_"github.com/mattn/go-sqlite3""log")vardb*sql.DBfuncmain(){fmt.Println("Startingtest...")db,err:=sql.Open("sqlite3","./data.db")checkErr(err)err=db.Ping()checkErr(err)fmt.Println(getNames())}funccheckErr(errerror){iferr!=nil{log.Fatal(err)}}funcgetName