草庐IT

find-by-sql

全部标签

ruby-on-rails - 使用 Rails 中的命名空间类防止 "warning: toplevel constant B referenced by A::B"

在自定义目录(例如:app/presenters/)中存储文件时,如何确保加载命名空间类?例如,如果您有:app/models/mega_menu.rbapp/presenters/catalog_presenter.rbapp/presenters/mega_menu/catalog_presenter.rbRails无法加载MegaMenu::CatalogPresenter:CatalogPresenter.new=>#MegaMenu::CatalogPresenter.new(irb):3:warning:toplevelconstantCatalogPresenterref

sql - Ruby 中的 pretty-print SQL

有没有一种简单的方法可以在(rails3)控制台中pretty-print随机SQL?类似于awesome_print的内容,甚至可能是PrettyPrint.它不需要理解所有可能的方言或非常高级。我真正想要的是更轻松地检查ActiveRecord生成的SQL。目前我只是将SQL复制到网上进行格式化,这显然是生产力killer。我真的很想query.to_sql.pretty_format_sql并查看更好的输出。谢谢。 最佳答案 试试这个:gitclonehttps://github.com/sonota/anbt-sql-for

sql - Arel中 "where exists"怎么办

如何在Arel中执行包含“whereexists”的查询?例如,在这样的查询中显示至少有一个订单的所有供应商:SELECT*FROMsuppliersWHEREEXISTS(SELECT*FROMordersWHEREsuppliers.supplier_id=orders.supplier_id);我在Arel文档中看到“存在”http://rubydoc.info/gems/arel/2.0.7/Arel/Nodes/Exists但我在使用它时遇到了问题。 最佳答案 给你:suppliers=Supplier.arel_tabl

ruby - 有没有办法查看 Sequel 表达式将生成的原始 SQL?

假设我有一个像这样的Sequel表达式:db.select(:id).from(:some_table).where(:foo=>5)有没有办法获取这将生成的SQL字符串(即"SELECTidFROMsome_tableWHEREfoo=5")?我注意到对上述表达式的结果调用inspect或to_s包括生成的SQL,但不确定如何直接访问它。以及不返回数据集的Sequel表达式如何,例如:db.from(:some_table).update(:foo=>5)是否可以在执行之前从中看到SQL? 最佳答案 你可以在数据集上调用sql:d

ruby-on-rails - Ruby 哈希数组。 group_by 一行修改

我有一个散列数组,类似于[{:type=>"Meat",:name=>"one"},{:type=>"Meat",:name=>"two"},{:type=>"Fruit",:name=>"four"}]我想把它转换成这个{"Meat"=>["one","two"],"Fruit"=>["Four"]}我尝试了group_by但后来我得到了这个{"Meat"=>[{:type=>"Meat",:name=>"one"},{:type=>"Meat",:name=>"two"}],"Fruit"=>[{:type=>"Fruit",:name=>"four"}]}然后我不能修改它只留下名

ruby-on-rails - Ruby 有 natural_sort_by 方法吗?

我有一个包含一堆属性的文件列表。其中一个属性是文件名,这是我想要对列表进行排序的方式。然而,列表是这样的:文件名1、文件名2、文件名10、文件名20。rubysort_by方法产生这个:files=files.sort_by{|file|file.name}=>[filename1,filename10,filename2,filename20]我想要一个更易于阅读的列表,例如文件名1、文件名2、文件名10、文件名20我找到了natural_sortgem但它似乎只能像排序方法一样工作。我需要一些可以指定数组排序依据的东西。有什么帮助吗? 最佳答案

ruby-on-rails - 数组上的 rails where() sql 查询

我会尽可能详细地解释这一点。我对用户帖子有疑问:@selected_posts=Posts.where(:category=>"棒球")我想写下面的语句。这是伪术语:User.where(用户在@selected_posts中有帖子)请记住,我设置了多对多关系,因此post.user可用。有什么想法吗?/编辑@posts_matches=User.includes(@selected_posts).map{|user|[user.company_name,user.posts.count,user.username]}.sort基本上,我需要上面的工作,以便它使用在selected_p

ruby-on-rails - Rails 5 SQL 注入(inject)

我已经在各种SO线程、指南等上阅读了一段时间...但所有答案都是相互矛盾和矛盾的。好像有很多类似的方法,而且很多答案都说使用不同的方法。清理sanitize_conditionssanitize_sqlsanitize_sql_arraysanitize_sql_for_assignmentsanitize_sql_for_conditionssanitize_sql_hashsanitize_sql_hash_for_assignmentsanitize_sql_hash_for_conditionssanitize_sql_like我正在尝试编写一个“原始查询”适配器,让我可以运行

sql - 在 ActiveRecord 中存储序列化哈希与键/值数据库对象的优缺点?

如果我有几个对象,每个对象基本上都有一个Profile,我用什么来存储随机属性,有什么优缺点:在记录列中存储序列化哈希,对比存储一组属于主对象的键/值对象。代码假设您有这样的STI记录:classBuilding:profilableendclassOfficeBuilding每个has_one:profile选项1.序列化哈希classSerializedProfiletruedo|t|t.string:namet.string:websitet.string:emailt.string:phonet.string:typet.text:settingst.integer:profi

Ruby - Array.find,但返回 block 的值

我有一个数组,我想要第一个block的结果返回一个真值(又名,不是零)。问题是,在我的实际用例中,测试有一个副作用(我实际上是在一组队列上迭代,然后从顶部弹出),所以我不需要在第一次成功之后评估block。a,b,c=[1,2,3][a,b,c].first_but_value{|i|(i+1)==2}==2a==2b==2c==3有什么想法吗? 最佳答案 break很丑=P如果你想要一个函数式方法,你需要一个惰性map:[nil,1,2,3].lazy.map{|i|i&&i.to_s}.find&:itself#=>"1"如果你