草庐IT

database-replication

全部标签

database-design - 使用 MongoDB 的类似 Twitter 的应用程序

我正在制作一个使用经典“关注”机制的应用程序(Twitter和网络上的许多其他应用程序都使用这种机制)。我正在使用MongoDB。不过,我的系统有一点不同:用户可以关注组个用户。这意味着,如果您关注一个群组,您将自动关注属于该群组的所有用户。当然,用户可以属于多个组。这是我想出的:当用户A关注用户B时,用户B的id被添加到用户A文档中的嵌入数组(称为following)为了取消关注,我从following数组中删除了被关注用户的id组的工作方式相同:当用户A关注groupX时,groupX的id被添加到following大批。(我实际上添加了一个DBRef以便我知道连接是针对用户还是组

ruby-on-rails - rails : storing encrypted data in database

我想加密数据库,因为正在存储secret数据。我将mongodb与mongoid一起使用。这种数据库可能吗?如果不是,您可以推荐哪些替代方案?附:主要目的是:如果有人入侵服务器并窃取数据库,它将无法加密。更新:感谢nickh,我发现很多soultionsforActiveRecord,但对于Mongoid和其他Mongo客户来说没有任何意义。很高兴能为Mongo和Mongoid找到一些灵魂! 最佳答案 我已经使用Mongo和Mongoid获得了attr_encrypted。只需稍作调整。确保所有由attr_encrypted自动创建

ruby-on-rails - 在 Rails 3.2 中使用 Mongoid 时删除 database.yml

我刚刚开始了一个新的Rails项目,想通过Mongoidgem使用MongoidDB。按照Mongoid网站上的说明,我在Gemfile中添加了以下几行:gem"mongoid","~>2.4"gem"bson_ext","~>1.5"然后我按照说明here继续删除我的database.yml文件.我的application.rb文件现在看起来像这样:require"action_controller/railtie"require"action_mailer/railtie"require"active_resource/railtie"require"rails/test_unit

database-design - MongoDB 存储大量指标/分析数据的方法

我们正计划使用MongoDB来存储大量分析数据,例如查看次数和点击次数。我不确定在MongoDB中构建文档以帮助查询和减小数据库大小的最佳方式。我们需要根据页面名称、客户端和操作类型来记录操作。理想情况下,我们需要下降到年/月/日/小时级别的统计数据,我们不需要或关心每秒或每分钟的浏览量。虽然这个文档结构看起来不错,但我知道100个访问者会生成100个新文档。{"_id":ObjectId("4dabdef81a34961506040000"),"pagename":"Hello","action":"view","client":"client-name","time":Date("

database-design - 用于博客的 mongodb 架构设计

您将如何为具有基于文档的数据库(mongodb)的类似博客的网站设计架构。该站点具有以下对象:用户、文章、评论。用户可以在文章中添加评论。每个用户也可以对每个评论进行一次投票。我希望能够高效地进行这些查询:1.获得文章A、文章A的评论和每条评论的票数2.获取用户B对所有文章的所有评论3.获取用户B投票给的所有评论我的第一次尝试是将文章和评论放在单独的集合中,评论可以包含投票给它的用户列表。这使得查询1和2变得简单。对于3,我添加了Vote集合,用于跟踪用户的投票。存在一些明显的缺点,例如复制用户投票数据,并且查询1需要两次调用数据库。有更好的方法吗?Article{"user_id"}

shell - mongo shell 脚本不允许我包含 "use <database>"

WindowsXP机器上的32位mongo2.0.1//scriptfilename:test.js(onelineshellscriptfiletostoreaperson)db.cTest.save({Name:"Fred",Age:21});通过输入以下2个shell命令对数据库dbTest运行:>usedbTestswitchedtodbTest>load("test.js")到目前为止,一切都很好。但如果我尝试在脚本中包含“use”语句,它会失败://scriptfilename:test.js(including"use"statement)usedbTest;db.cTe

c++ - 编译随机失败 : "cannot open program database"

在使用VisualStudio2005(版本8.0.50727.762)进行长时间编译期间,有时在某些项目的几个文件中会出现以下错误:fatalerrorC1033:cannotopenprogramdatabase'v:\temp\apprtctest\win32\release\vc80.pdb'(提到的文件是项目临时目录中的vc80.pdb或vc80.idb。)同一项目的下一次构建成功。没有其他可以访问相同文件的VisualStudio打开。这是一个严重的问题,因为它使夜间编译变得不可能。 最佳答案 可能是防病毒软件或类似程序

database - golang sqlite 数据库连接池

当我在读取数据库的同时调用数据库写入时,我遇到了SQLite在我的机器上扔Spanner的问题。当不同的方法碰巧同时尝试访问数据库时,就会发生这种情况。我所做的与thisthread中所做的相似,接受的答案解释了如何使用数据库事务来避免数据库锁定。这是我的一些代码:stmt,err:=dbtx.Prepare(`statement`)iferr!=nil{log.Fatal(err)}_,err=stmt.Exec(values,values,values)iferr!=nil{log.Fatal(err)}err=dbtx.Commit()iferr!=nil{fmt.Println

database - 如何处理来自数据库的 nil 返回值?

我正在编写一个基本程序来从数据库表中读取值并在表中打印。table上有一个古老的程序。该行中的某些字段是可选的,当我尝试将它们作为字符串读取时,我收到以下错误:panic:sql:Scanerroroncolumnindex2:unsupporteddriver->Scanpair:->*string在阅读其他类似问题的问题后,我想出了以下代码来处理nil值。该方法在实践中效果很好。我得到纯文本和空字符串的值,而不是nil值。但是,我有两个担忧:这看起来效率不高。我需要处理25多个这样的字段,这意味着我将它们中的每一个都读取为字节并转换为字符串。太多的函数调用和转换。两个结构来处理数据

postgresql - Postgres 删除数据库错误 : pq: cannot drop the currently open database

我正在尝试像这样删除当前连接的数据库,但出现此错误:pq:cannotdropthecurrentlyopendatabase我真的不明白如果我必须关闭我的连接,我应该如何删除数据库,因为我认为我将无法使用dbConn.Exec来执行我的DROPDATABASE语句?dbConn*sql.DBfuncstuff()error{_,err:=dbConn.Exec(fmt.Sprintf(`DROPDATABASE%s;`,dbName))iferr!=nil{returnerr}returndbConn.Close()}我想我可以连接到不同的数据库,然后在该连接上执行它,但我什至不确定