在database.yml中定义所有设置。如何从ruby访问这些设置?我查看了App::Application::config,但在那里找不到它。另外,我记得人们可以在没有yaml的情况下配置数据库设置,有人知道怎么做吗? 最佳答案 Rails.configuration.database_configuration这将为您提供一个哈希表,其中包含每个环境的配置。例如。获取您的开发数据库名称:Rails.configuration.database_configuration["development"]["database"]
我正在使用多态关联来跟踪我项目中的评论。所有非常直接的东西。我遇到的问题是基于多态关联的查询以及从Comment模型连接回它的所有者。所以...我有一个评论模型classCommenttrueend还有一个论坛主题模式:classForumTopic:commentableend我还有其他几个目前不重要的“可评论”模型。所有这些都有效。我想要做的是找到属于具有指定条件(在本例中,'featured'==true)的ForumTopic的所有评论。当我尝试使用取景器加入模型时:@comments=Comment.find(:all:joins=>:commentable:conditio
Rails中after_create、after_save和after_commit的区别在于:after_save在创建和更新对象时调用after_commit在创建、更新和销毁时被调用。after_create仅在创建对象时调用这是它们之间唯一的区别,还是还有其他主要区别? 最佳答案 你几乎做对了。但是after_commit和after_create或after_save之间有一个主要区别,即在after_create的情况下,这将始终在调用保存(或创建)返回之前。Rails将每个保存都包装在一个事务中,并且创建之前/之后的回
这可能是一个简单的问题,但我似乎正在努力寻找一个优雅的解决方案。我有两个ActiveRecord模型类,它们之间有has_one和belongs_to关联:classItem我正在寻找一种优雅的方法来查找所有Item对象,这些对象没有与之关联的购买对象,理想情况下无需求助于boolis_purchased或Item上的类似属性。现在我有:purchases=Purchase.allItem.where('idnotin(?)',purchases.map(&:item_id))这行得通,但对我来说似乎效率低下,因为它执行两个查询(并且购买可能是一个庞大的记录集)。运行Rails3.1.
我想从我的Rails应用程序中批量插入几千条记录到数据库(在我的例子中是POSTGRES)。这样做的“Rails方式”是什么?一些快速且正确的方法。我知道我可以通过属性的字符串连接来创建SQL查询,但我想要一种更好的方法。 最佳答案 ActiveRecord.create方法支持批量创建。如果数据库不支持该功能,该方法将模拟该功能,如果支持该功能,则使用底层数据库引擎。只需传递一组选项。#CreateanArrayofnewobjectsUser.create([{:first_name=>'Jamie'},{:first_name
我需要一个包含表的列名的数组关于如何使用rails3.0.0rc做到这一点有什么想法吗? 最佳答案 假设您有一个Post模型:Post.column_names#orPost.columns.map{|column|column.name}它将返回一个数组,其中包含表“posts”的列名。 关于ruby-on-rails-如何获取包含表的列名的数组,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/qu
我有一个模型关系,其中今天有很多任务我正在尝试检索用户的today对象,包括tasks并将它们全部呈现给Json。在我决定要在today对象中订购tasks之前,所有这一切都进行得很顺利,因为respond_withblock也用于呈现html页。有什么方法可以包含tasks并对其进行排序吗?我正在尝试这样的事情:classTodaysControllercurrent_user.id).joins(:tasks).includes(:tasks).order(:priority).firstrespond_with@today,:include=>:tasksendend这会正确检索
非常简单的问题-我如何进行搜索以查找名称以ActiveRecord中的特定字符串开头的所有记录。我在互联网上看到过各种使用逐字LIKESQL子句的位-但据我所知,这不是“正确”的做法。是否有“合适的”Rails方法? 最佳答案 如果您希望在数据库中进行搜索,那么您将需要使用SQL。当然,您需要在数据库中进行搜索,否则您需要将所有对象加载到Ruby中(这不是一件好事)。所以,你需要类似的东西MyModel.find(:all,:conditions=>["fieldLIKE?","#{prefix}%"])其中prefix是一个包含您
当我呈现XML模板时,我很难理解如何让Rails为验证失败的子资源显示明确的错误消息。假设我有以下类(class):classSchool/^([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})$/i,:message=>"Youmustsupplyavalidemail"end现在,在Controller中,假设我们想要构建一个简单的API来允许我们添加一个新的学校,其中有一个学生(我再说一次,这是一个糟糕的例子,但发挥它的作用是为了问题)classSchoolsController@school.errors,:status=>:unprocessable_
我有一组ActiveRecord模型,我希望将其转换为CSV。我尝试研究像FasterCSV这样的gem,但它们似乎只适用于字符串和数组,而不适用于ActiveRecord模型。简而言之,我要转换:user1=User.firstuser2=User.lasta=[user1,user2]收件人:id,username,bio,email1,user1,user1bio,user1email1,user2,user2bio,user2email有没有简单的Rails方法可以做到这一点? 最佳答案 下面将所有用户的属性写入一个文件:C