草庐IT

php - 优化随机记录查询

全部标签

ruby - YARD:记录由包含的模块添加的类方法

我正在使用YARD为我的ruby​​gem编写文档.在我的gem中,我有一些代码遵循这种常见的ruby​​模式,其中一个模块包含在一个类中,并且该模块不仅添加了实例方法,还添加了类方法:moduleMoodefself.included(klass)klass.extendClassMethodsendmoduleClassMethodsdefhelloputs"hello"endendendclassFooincludeMooendFoo.hello#=>classmethodruns,printing"hello"默认情况下,YARD将为Foo类生成如下所示的文档:我认为此文档不充

ruby - 是否可以使用事件记录为表定义复合主键?

这个问题在这里已经有了答案:HowtosetcompositekeyinRailsapplication(2个答案)关闭8年前。我在没有Rails的ruby​​项目中使用ActiveRecord。我需要为表定义复合主键。通常迁移会自动创建主键。是否可以使用事件记录为表定义我自己的复合主键?

ruby - 如何在请求范围之外访问 Sinatra 的记录器

似乎Sinatra的记录器只能在请求处理程序中使用(参见https://github.com/sinatra/sinatra#logging),但是如果我想在其他地方使用记录器怎么办,例如在辅助方法或配置Hook中?Sinatra记录器是否可以通过其他方式使用? 最佳答案 Thedocs给出一些关于范围的示例,但是您可以在helperblock中定义的方法中看到logger帮助程序,因为帮助程序block具有Application范围。在configure中它不可用,但我倾向于做的是设置我自己的日志记录,在rackup文件中作为常量

ruby - 重现随机数组排序

我有一个对象数组,我想对其进行随机排序。对于这种情况,我可以使用array.shuffle。但是,如果我想稍后在同一个数组上重现该顺序怎么办?有什么方法可以提供种子、随机数等等,以便我以后可以重现这个序列吗?我想从MongoDB数据库(使用MongoID)生成一个随机的对象列表,并且该列表必须在以后复制。但据我所知,没有真正好的方法,直接在MongoDB中实现随机排序。可能有很多对象(>1,000,000),但计算时间是第一次尝试的时间,并不是最重要的事实。 最佳答案 如果您查看RubydocsforArray#shuffle你会看

sql - SQL 查询的最大长度

SELECTf.*FROMfeedsf,user_feedsufWHERE(f.id=uf.feed_idanduf.user_idin(1,2,5,6,23,45))ORDERBYcreated_atDESC这是用于构建用户提要的查询。这个查询的问题是“uf.user_idin()”随着用户关注的用户数量的增加而增加。SQL查询允许的最大长度是多少?有没有更好的方法来实现上面的查询?注意:我正在使用ActiveRecord和Postgres。 最佳答案 PostgreSQL可以处理的查询的最大长度是2147483648个字符(带符

ruby-on-rails - Ruby Timeout::timeout 不会触发异常并且不会返回记录的内容

我有这段代码:begincomplete_results=Timeout.timeout(4)doresults=platform.search(artist,album_name)endrescueTimeout::Errorputs'Printmesomethingplease'end然后我启动包含这段代码的方法,好吧,这是堆栈跟踪的开始:Exceptionmessage:executionexpiredExceptionbacktrace:/***/****/.rvm/rubies/ruby-1.8.7-p302/lib/ruby/1.8/timeout.rb:64:i所以我天真

ruby - 选择一个随机选项,其中每个选项被选中的概率不同

假设给您三个“选项”,A、B和C。您的算法必须随机选择并返回一个。为此,只需将它们放在一个数组{A,B,C}中并生成一个随机数(0、1或2),这将是元素在返回数组。现在,这个算法有一个变体:假设A有40%的机会被选中,B有20%,而C40%。如果是这种情况,您可以采用类似的方法:生成一个数组{A,A,B,C,C}并生成一个随机数(0,1,2,3,4)选择要返回的元素。行得通。但是,我觉得效率很低。想象一下,将此算法用于大量选项。你会创建一个有点大的数组,可能有100个元素,每个元素代表1%。现在,这仍然不是很大,但假设您的算法每秒使用多次,这可能会很麻烦。我考虑过创建一个名为Slot的

ruby-on-rails - 如何使用 Ruby 中哈希的查询参数构造 URI

如何通过传递哈希来构造带有查询参数的URI对象?我可以生成查询:URI::HTTPS.build(host:'example.com',query:"a=#{hash[:a]},b=#{[hash:b]}")产生https://example.com?a=argument1&b=argument2但是我认为为许多参数构造查询字符串将不可读且难以维护。我想通过传递哈希来构造查询字符串。就像下面的例子:hash={a:'argument1',b:'argument2'#...dozenmorearguments}URI::HTTPS.build(host:'example.com',que

ruby-on-rails - 从数组中检索 x 个随机元素

我正在努力编写一个干净的方法,当传递一个字符串数组和x时返回一个随机的数组元素列表,总计x,例如。defgetrandomarrayelements(thearray,howmany)return[something]end是的,我应该提交我现有的代码,虽然效果不好,但它有8行长,我觉得它可以一次完成?! 最佳答案 在ruby1.9中:irb(main):001:0>[1,2,3,4,5].sample(3)=>[2,4,5]irb(main):002:0>[1,2,3,4,5].sample(3)=>[2,5,3]对于ruby​​

ruby-on-rails - RSpec 在测试数据库中留下记录

每当我运行用户测试时,RSpec都会在测试完成后将Fabricated用户留在测试数据库中,这会扰乱我的其他测试。我将执行rakedb:test:prepare,但是当我再次运行测试时,会在我的数据库中重新创建记录。我不知道为什么会这样。它只发生在用户对象上。在我的spec_helper文件中我什至有:config.use_transactional_fixtures=true这是一个创建记录的示例测试:it"createsapasswordresettokenfortheuser"doalice=Fabricate(:user)post:create,email:alice.emai