草庐IT

文档数据库

全部标签

mongodb - 如何根据带有整数键的嵌套数组中的值查找文档?

我的查找查询如下所示:bson.M{"_id":oId,"items":bson.M{"$elemMatch":bson.M{"id":theId,"active":true}}}(其中theId是方法中的对象ID)我要做的是选择一个具有匹配id且active设置为true的文档{"_id":ObjectId("5ca0e44acb216df65405dc5f"),"items":{"0":{"id":ObjectId("5c9fbb25e86deef65491c321"),"active":true},"1":{"id":ObjectId("5c9fbb57cb216df65405d

sql - 删除用于测试套件的所有数据库记录的最佳方法是什么?

我有一个测试套件使用从YAML文件读取的种子污染我的数据库。我想知道是否有一种方法可以在运行测试后清理我的数据库(删除用于测试套件的所有记录)。//OpendbandreturnspointerandcloserfuncfuncprepareMySQLDB(t*testing.T)(db*sql.DB,closerfunc()error){db,err:=sql.Open("mysql","user:pass@/database")iferr!=nil{t.Fatalf("openmysqlconnection:%s",err)}returndb,db.Close}//Pollutem

postgresql - GORM 数据库中的自动迁移将不需要的字段添加到 SQL 表

当我在gorm数据库中创建表时,它向表中添加了我不需要的列。我不确定它是如何添加这些额外字段的。这导致我遇到一个错误,“pq:列“user_id”中的空值违反了非空约束”。“user_id”是添加的不需要的列。我正在使用gorm和postgreSQL。我的两个表之间存在多对多关系。我的第一个表已正确创建,第二个表stores是使用提供的字段加上两个不需要的字段创建的:“user_id”和“stores_id”。我尝试删除多对多关系以查看是否是问题所在,我尝试删除表并使用不同的字段重新创建它们。无论如何,我都无法摆脱这两个额外的列。第一个(工作)表:typeUserstruct{gorm

mongodb - 为什么我的更新函数返回新查询但不更新数据库?

我正在创建一个RESTfulAPI,并且正在创建一个更新函数。我使用FindOneAndUpdate,它实际上并没有更新数据库。我尝试了很多东西,但我对这门语言还很陌生,所以我有点迷茫。funcUpdateCompanyEndpoint(responsehttp.ResponseWriter,request*http.Request){response.Header().Set("content-type","application/json")params:=mux.Vars(request)name,_:=params["name"]varcompanyCompany_=json.

sqlite - 模拟对 sqlite 数据库的多个请求作为 goroutine 导致随机 panic

我正在尝试模拟从http.HandleFunc到对sqlite数据库进行更改的函数的多个请求。我假设http.HandleFunc调用的函数实际上是goroutine。见下面的代码:packagemainimport"fmt"import"time"import"code.google.com/p/go-sqlite/go1/sqlite3"import"crypto/rand"import"encoding/base64"funcgetrandomtext()(string){b:=make([]byte,12)rand.Read(b)en:=base64.StdEncoding//

postgresql - 通过 pq 连接到 PostgreSQL 数据库返回 "bad connection"错误

我正在使用两台不同的计算机在Go和PostgreSQL中制作一个网络应用程序。两台计算机上的设置相同(Ubuntu与最新版本的Go和PostgreSQL)。问题是我无法让我的应用程序连接到笔记本电脑上的数据库。我使用这段代码:func(db*Database)Dial(userstring,passwordstring,dbnamestring){varerrerrordb.Conn,err=sql.Open("postgres","user="+user+"password="+password+"dbname="+dbname+"sslmode=require")iferr!=ni

json - Go:在json响应中从数据库复制各种类型的数据

我正在尝试从我的数据库中获取一组数据并以json格式返回它们。但是,它们的类型不同,我似乎在我的代码中使用了错误的返回类型。开始:typeScriptstruct{Idint`json:"id"`Typestring`json:"type"`Created_atint`json:"created_at"`}typeAllContentstruct{New_content[]*Script`json:"new_content,omitempty"`}funcReadAllContent()[][]interface{}{err:=db.Ping()iferr!=nil{log.Fatal

concurrency - Go Memory Model文档中给出的这个例子失败的原因是什么?

在Go内存模型文档中http://golang.org/ref/mem它给出了以下示例:varastringvardoneboolfuncsetup(){a="hello,world"done=true}funcmain(){gosetup()for!done{}print(a)}然后它说这个例子的以下内容。"thereisnoguaranteethatthewritetodonewilleverbeobservedbymain,sincetherearenosynchronizationeventsbetweenthetwothreads.Theloopinmainisnotguar

mysql - 为什么这一小段代码需要 11 秒来执行这几个数据库调用?

我有这段代码:packagetradebotimport("log""net/http""strconv""github.com/Philipp15b/go-steam/tradeoffer""github.com/gorilla/mux")funcAcceptTrade(whttp.ResponseWriter,r*http.Request){vars:=mux.Vars(r)vartradeIdtradeoffer.TradeOfferIdvarsTradeIdstringif_,has:=vars["TradeId"];has{varerrerrorsTradeId=vars["

unicode - 如何在 Go 中将 unicode 字符串从数据库转换为 utf 字符串?

字符串在数据库中存储为unicode"\u0435\u043e..."(表的编码为UTF-8)。从数据库中选择并打印后:日志.Println(str)输出:\u0435\u043e...如何将此字符串转换为utf格式? 最佳答案 要解码你拥有的字符串,你可以这样做:import"net/url"...url.QueryUnescape("\u0435\u043e")但我认为您的数据库或连接参数配置错误,因为这应该是自动处理的。这不是utf-8顺便说一句。 关于unicode-如何在Go中