草庐IT

检测与记录

全部标签

ruby-on-rails - 保存事件记录数组

我有一个这样的数组a=[]a"c")a"s")a"e")a"t")如何一次性保存? 最佳答案 B.transactiondoa.each(&:save!)end这将创建一个循环遍历数组的每个元素并对其调用element.save的事务。您可以阅读有关ActiveRecordTransactions的信息和theeachmethod在Rails和RubyAPI中。 关于ruby-on-rails-保存事件记录数组,我们在StackOverflow上找到一个类似的问题:

ruby-on-rails - PG::TRDeadlockDetected:错误:检测到死锁

我正在通过bundleexecpumactl-Fconfig/puma.rbphased-restart重新启动8个pumaworker,效果很好。现在我收到越来越多的postgres错误:PG::TRDeadlockDetected:ERROR:deadlockdetected我发现大约有50个空闲的postgres进程在运行:postgres:myappmyapp_production127.0.0.1(59950)idlepostgres:myappmyapp_production127.0.0.1(60141)idle...当我运行bundleexecpumactl-Fconf

ruby - 在每种方法之后检测 Rspec 测试失败

我正在尝试运行RSpec测试,我想检测测试是否在after方法中失败。我现在有这样的东西:after(:each)docc=ConnectController.new()cc.update(,,result?)end如您所见,result?函数是我需要替换的,用于检测测试是否失败,以及获取有关失败测试的信息。 最佳答案 除了Daniel的回答之外,在Rspec3中删除了示例方法(有关更多信息,请参阅here)。你将不得不做这样的事情:after(:each)do|example|ifexample.exception#...ende

ruby-on-rails - 在 Rails 中通过 belongs_to 关系查询记录

我有一个事件模型,它们属于一个位置如何选择location.country=Australia的所有事件?(例如)我可以在一个范围内这样做吗? 最佳答案 使用最新的rails版本,您可以:Activity.joins(:location).where(locations:{country:"Australia"})注意:它是joins(:location)中的位置(单数),因为它引用了belongs_to关系名称它是where(…)中的位置(复数),因为它引用了表名后者意味着如果您有以下情况:belongs_to:location,

ruby - 检测类方法中的新方法可见性

这是一个代码示例:classFoodefself.create_methoddefexample_method"foo"endendprivatecreate_methodendFoo.public_instance_methods(false)#=>[:example_method]是否可以检测到类方法create_method是从类Foo私有(private)区域调用的?在上面的示例中,该信息可用于根据调用create_method的位置将example_method设为公开或私有(private)。 最佳答案 为了确定,我仔细

ruby-on-rails - 如何在 ruby​​ ActiveRecord 中销毁没有 ID 列的记录?

我有一个没有ID列的表。当我尝试使用ActiveRecord从中删除时,生成的SQL是DELETEFROMtable_nameWHEREID=NULL,这显然不起作用。有什么方法可以使用ActiveRecord从表中删除,或者至少运行带有占位符的原始SQL删除查询(因此它不易受到SQL注入(inject)的攻击)? 最佳答案 您是否尝试过使用ActiveRecord的delete_all方法?这是我的沙箱中的摘录:>>customer=Customer.new(:login=>'foo')=>#,discount:0,last_fo

ruby-on-rails - Rails 自定义验证 - 只有一条记录可以为真

我正在尝试编写一个验证,其中只有一个记录可以为真。我有一个带有“事件”bool列的“游戏”模型,任何时候只能有一个游戏处于事件状态,所以如果有人在已经有一个事件的游戏时试图创建一个新的“游戏”记录,那么他们应该会得到一个错误.以下是我目前拥有但无法使用的内容!validate:active_gamedefactive_gameifactive==true&&Game.find_by(active:true)==trueerrors[:name]="agameisalreadyactive!"endend 最佳答案 我认为您可以在ac

ruby-on-rails - 查找存在属性的记录

我有一个User模型,具有属性username、email和name。username和email在注册时是必需的,但不是name。查找所有填写了name(即不是nil)的用户的查询是什么?查询应该至少与Rails3.2和4.0兼容。我在想一些事情:User.where(name:present?) 最佳答案 [2022年5月13日更新]要获取SQL中不存在属性的所有记录,我们将编写WHEREattrISNULLorattr=''一个容易犯的错误就是否定它并写成WHEREattrisnotnullandattr!=''但是在SQL中

ruby-on-rails - capybara 在功能规范期间找不到数据库记录

我有一个JS功能规范,我正在尝试使用CapybaraWebkit运行。但是它似乎无法找到我的数据库记录。有问题的规范看起来像这样it"shouldallowpledgingtoaHardbacklevel",js:truedobook=FactoryGirl.create:bookvisitbook_path(book)click_link"pledge-btn"end很遗憾,请求book_path(book)404s因为找不到这本书。如果我取消:js标志,测试通过。我已将DatabaseCleaner设置为使用:truncation用于JS规范asistherecommendedme

ruby-on-rails - 计算最近 7 天内创建的记录

如何更改下面的查询以仅选择过去7天内创建的记录?self.favorites.count此函数位于我的User模型中。defcalculate_user_scoreunlessself.new_record?self.score=(self.links.count*5)+(self.favorites.count*0.5)endend 最佳答案 您可以像这样添加一个where条件:self.favorites.where('created_at>=?',1.week.ago).count对于您的calculate_user_scor