草庐IT

user_signed_in

全部标签

ruby-on-rails - 附加到 rake db :seed in rails and running it without duplicating data

Rakedb:seed使用应用程序的默认数据库值填充您的数据库,对吗?那么如果您已经有一个种子并且需要添加到它(您添加一个需要种子的新功能)怎么办?根据我的经验,当我再次运行rakedb:seed时,它已经添加了现有内容,因此现有内容变成了两倍。我需要的是添加一些种子,当运行时,它应该只添加最新的种子,而忽略现有的种子。我该怎么做?(我通常采用的肮脏的、菜鸟的方式是截断我的整个数据库然后再次运行种子,但这在生产中不是很聪明,对吧?) 最佳答案 更简洁的方法是使用find_or_create_by,如下所示:User.find_or_

ruby-on-rails - Ruby 2.0.0 字符串#Match ArgumentError : invalid byte sequence in UTF-8

我经常看到这种情况,但还没有想出一个优雅的解决方案。如果用户输入包含无效的字节序列,我需要能够让它不引发异常。例如:#@raw_responsecomesfromuserandcontainsinvalidUTF-8#forexample:@raw_response="\xBF"regex.match(@raw_response)ArgumentError:invalidbytesequenceinUTF-8已经问了很多类似的问题,结果似乎是对字符串进行编码或强制编码。然而,这些都不适合我:regex.match(@raw_response.force_encoding("UTF-8"

ruby-on-rails - rails : How to use dependent: :destroy in rails?

我有2个模型,如下所述。classEmpGroup和classEmpGroupMember现在的问题是,每当我试图摧毁一个组时,我都会收到如下错误。PG::ForeignKeyViolation:ERROR:updateordeleteontable"emp_groups"violatesforeignkeyconstraint"fk_rails_bd68440021"ontable"emp_group_members"DETAIL:Key(id)=(1)isstillreferencedfromtable"emp_group_members".我错过了什么?

Ruby 基准测试模块 : meanings of "user", "system"和 "real"?

试验Ruby的基准模块...>>Benchmark.bm(7){|b|b.report('Report:'){s='';10000.times{s+='a'}}}usersystemtotalrealReport:0.1500000.0100000.160000(0.156361)“用户”、“系统”、“真实”的含义是什么? 最佳答案 这些时间与Unixtime命令或其他典型基准测试工具报告的时间相同:user:执行用户空间代码(即:您的代码)所花费的时间,system:执行内核代码所花费的时间和真实:执行代码所花费的“真实”时间(即

ruby - 我如何在普通的旧 ruby (非轨道)中使用轨道助手 "distance_of_time_in_words"

Rails有一个助手,它使用distance_of_time_in_words将时间距离转换为单词如果我只是在irb提示符下使用ruby​​来获取此功能,我需要包括什么?我试过require'action_view'但没有用。我也试过require'active_support/core_ext'但这也没有帮助。 最佳答案 这应该有效:需要“action_view”包含ActionView::Helpers::DateHelper由于几个原因,这两项都需要完成。首先,您需要要求该库,以便可以调用它的模块和方法。这就是您需要执行req

ruby-on-rails - 工厂未注册 : user

我正在学习MichalHartlsRails教程第7章。我已经安装了Factorygirlgem。我在运行测试时不断收到此错误Failures:1)UsersControllerGET'show'shouldbesuccessfulFailure/Error:@user=FactoryGirl.create(:user)ArgumentError:Factorynotregistered:user#./spec/controllers/users_controller_spec.rb:10:in`block(3levels)in'Finishedin0.66336seconds42ex

ruby-on-rails - rails : How to determine controller/action in view

这是我的部分表格:{:multipart=>true}do|d|%>'Uploadlogo',:required=>false%>'Image,:required=>false',:style=>'margin-bottom:2px'%>'BilledURL',:required=>false%>如果操作是编辑,我想改为显示:{:multipart=>true}do|d|%>'Uploadlogo',:required=>false%>'Image,:required=>false',:style=>'margin-bottom:2px'%>'BilledURL',:required=

ruby-on-rails - ruby rails : How to run things in the background?

当一个新资源被创建并且它需要在资源准备好之前做一些冗长的处理时,我如何将那个处理发送到后台在那里它不会阻止我的网络应用程序的当前请求或其他流量吗?在我的模型中:classUser 最佳答案 您绝对应该查看以下Railscast:http://railscasts.com/episodes/127-rake-in-backgroundhttp://railscasts.com/episodes/128-starling-and-worklinghttp://railscasts.com/episodes/129-custom-daem

ruby - 轨道 3/ ruby : ActiveRecord Find method IN condition Array to Parameters single quote issue

我在微博模型上创建了一个方法,它接受一个user_id数组。在此方法中,我使用以下“查找”方法来提取数组中所有用户的所有帖子。find(:all,:conditions=>["user_idIN(?)",args.join(',')])但是当ActiveRecord为这个查询生成SQL时,它用单引号将逗号分隔的ID列表括起来。这会导致查询只提取单引号内第一个数字的帖子,而不是所有数字。SELECT`microposts`.*FROM`microposts`WHERE(user_idIN('3,4,5'))ORDERBYmicroposts.created_atDESC查询应该看起来像这

ruby-on-rails - Rake 中止...表 'users' 已存在

我用devise和漂亮的生成器创建了一个数据库。我正在尝试使用漂亮的生成器(railsgnifty:scaffoldAssetuser_id:integer)创建一个新数据库,但是当我尝试迁移数据库时(rakedb:migrate),我收到以下错误:charlotte-dator:showwwdownholgersindbaek$rakedb:migrate==DeviseCreateUsers:migrating==============================================--create_table(:users)rakeaborted!Anerror