草庐IT

update-gcs

全部标签

ruby-on-rails - "gem update --system is disabled on Debian"错误

当我尝试更新ruby​​gems(通过运行“gemupdate--system”)时出现此错误:ERROR:Whileexecutinggem...(RuntimeError)gemupdate--systemisdisabledonDebian.RubyGemscanbeupdatedusingtheofficialDebianrepositoriesbyaptitudeorapt-get.知道可能出了什么问题以及如何解决它吗? 最佳答案 有两种方法:摆脱debianruby​​包并从源代码安装ruby​​,或者您可以按照给您的说

ruby-on-rails - 注销前更新 current_user 时收到 "Attempted to update a stale object: User"异常

我在我的用户模型上启用了乐观锁定,以处理我代码库各个部分中可能发生的冲突。但是,我遇到了意外冲突,我不知道如何处理它,因为我不知道是什么原因造成的。我正在使用Devisegem进行身份验证,并且正在使用before_logout方法来重置安全token...classSessionsController:createbefore_filter:before_logout,:only=>:destroydefafter_login#logictosetthesecuritytokenenddefbefore_logoutcurrent_user.update(security_token

ruby - Sudo gem update --dry-run?

有没有办法让RubyGems判断是否有可用的更新?我发现自己一直在运行sudogemupdate——通常每天运行几次。如果我可以使用--dry-run之类的标志运行该命令,那么我可以评估更改的gem是否对添加很重要(并且仅当我对当前项目的测试为绿色时才运行它。有什么建议吗? 最佳答案 尝试:gemoutdated它将显示所有需要更新的gem(列出您的当前版本和最新版本)。 关于ruby-Sudogemupdate--dry-run?,我们在StackOverflow上找到一个类似的问题:

sql - 在 Rails 中使用连接执行 update_all

在这种情况下,Rails对原始SQL的抽象让我抓狂。在MySQL中我可以这样做:UPDATEFROMtasksAStLEFTJOINprojectsaspONt.project_id=p.idSETt.invoice_id=7WHEREp.organization_id==42ANDt.invoice_idISNULL我如何在Rails3.0.1中使用预先加载来做到这一点?我已经尝试了以下所有方法:Tasks.joins(:project).where('projects.organization_id'=>42,:invoice_id=>nil).update_all(:invoic

ruby-on-rails - 在 after_update 回调中获取更改的属性

我正在尝试进行有条件的after_update,我有以下内容:after_updatedo|participant|Rails.logger.info"#{self.previous_changes}changed."ifself.previous_changes.include?(:current_distance)#Domystuff...endend记录器打印空哈希:{}如何检查哪个属性已更改?我正在使用:participant.update_attribute(:current_distance,distance)来更新属性。 最佳答案

ruby-on-rails - Rails 4 - 想让 Rails 将我的本地时区用于 created_at 和 updated_at

是否真的有办法让Rails使用我服务器上设置的当前时区使用created_at和update_at添加/更新行?我见过许多StackOverflow解决方案,其中人们说明了如何在具有选定时区的RailsView上显示它。我还发现其他StackOverflow解决方案指出它应该从我的服务器获取时区并更新created_at和updated_at。至少对于我正在运行的MacMini服务器而言,情况并非如此。我把它设置为我本地的时区。我还在config/application.rb中设置了config.time_zone='CentralTime(US&Canada)'。我希望能够查看pgA

ruby - update(other_hash) 和 merge(other_hash) 的区别

更新代码:irb(main):001:0>h1={"a"=>100,"b"=>200}=>{"a"=>100,"b"=>200}irb(main):002:0>h2={"b"=>254,"c"=>300}=>{"b"=>254,"c"=>300}irb(main):003:0>h1.update(h2)=>{"a"=>100,"b"=>254,"c"=>300}合并代码:irb(main):001:0>h1={"a"=>100,"b"=>200}=>{"a"=>100,"b"=>200}irb(main):002:0>h2={"b"=>254,"c"=>300}=>{"b"=>254,

ruby-on-rails - 在 Rails 3 中使用 update_columns?

在Rails3中有更短的方法吗?user.update_column(:attribute1,value1)user.update_column(:attribute2,value2)user.update_column(:attribute3,value3)user.update_column(:attribute4,value4)我试过update_columns但它只在Rails4中可用。感谢您的帮助。 最佳答案 这是Rails3.x的解决方法:User.where(id:user.id).update_all(attribu

ruby-on-rails - 使用#update_all 更新时间戳

当我有要更新其属性的ID列表时,数据库中的updated_at字段似乎没有改变,这就是我的意思:ids=[2,4,51,124,33]MyObj.where(:id=>ids).update_all(:closed=>true)执行此更新后,updated_at字段不会更改。但是,当我使用railsc进入rails控制台并执行此操作时:obj=MyObj.find(2)obj.closed=false;obj.save!在此语句之后updated_at字段更改值。为什么是这样?当发生这种情况时,我正在监听更新并执行整个应用程序流程时,我依赖于我的应用程序中的这个updated_at字段

ruby-on-rails - 尝试更新数据库值时,rails update_attributes 返回 false

希望这里有人能给我指出正确的方向。我有一个ControllerUpdatedef运行“update_attributes”。目前它返回false,没有错误消息。我是Ruby的新手,但不是编码的新手,这让我困惑了好几天!我正在尝试使用下面指定的值更新用户模型和数据库。defupdate#getcurrentlyloggedinuser@user=current_user#updateuserparamsbasedoneditform...if@user.update_attributes(params[:user])redirect_toprofile_path,:notice=>"Su