草庐IT

day06-动态SQL语句

全部标签

sql - Rails + PostgreSQL SSL 解密失败

我的生产服务器上运行了一个应用程序,它使用pggem与Postgres数据库通信。Postgres在默认端口上运行,并且位于防火墙后面-因此只能从localhost访问它。我还没有配置Postgres来做任何与SSL相关的事情。我正在通过SSL访问Rails应用程序,并且证书是为另一个域签名的,所以当您第一次点击它时,会出现证书错误……但这是唯一与SSL相关的奇怪之处。然而,我在我的Rails日志中间歇性地看到这个(当它发生时浏览器会出现500错误):StartedGET"/admin/pages"forat2012-02-0201:52:03-0500ProcessingbyPage

ruby-on-rails - 如何在 Rails 中动态调用或调用类?

假设我可以构造一个与现有类匹配的字符串,我该如何调用它?比如我有几个类:MyClass1MyClass2MyClass3我想通过构造一个与它们的名称相匹配的字符串来动态调用它们中的每一个。如果他们都有方法“方法”,我该如何做这样的事情?:(1..3).eachdo|n|("MyClass"+n).methodsend 最佳答案 constantize符合要求。您可以阅读更多相关信息here.在你的情况下,它会是这样的:(1..3).eachdo|n|"MyClass#{n}".constantize.methodsend

Ruby - 动态地向类添加属性(在运行时)

这个问题在这里已经有了答案:addingattributestoaRubyobjectdynamically(6个答案)关闭8年前。我正在寻找一种在运行时或更好的方式向我已定义的类添加属性的方法:classClientattr_accessor:login,:passworddefinitializeargs={}self.login=args[:login]self.password=args[:password]endend但是,我有这个散列{:swift_bic=>"XXXX",:account_name=>"XXXX",:id=>"123",:iban=>"XXXX"}我希望这

ruby-on-rails - Nokogiri 是针对 LibXML 版本 2.7.7 构建的,但已动态加载 2.7.3

在Rails3中,我注意到每次调用框架时,无论是从rake、railsserver还是其他任何地方,我都会收到以下警告:NokogiriwasbuiltagainstLibXMLversion2.7.7,buthasdynamicallyloaded2.7.3在Google上搜索会得到一些博客文章,所有这些文章都建议使用显式库和包含路径重建Nokogiri。例如:http://mrflip.github.com/2009-08/nokogiri-hates-libxml2-on-osx.html但是,这并没有解决我的问题。输入nokogiri-v给我这个:---warnings:[]r

sql - SQL 查询的最大长度

SELECTf.*FROMfeedsf,user_feedsufWHERE(f.id=uf.feed_idanduf.user_idin(1,2,5,6,23,45))ORDERBYcreated_atDESC这是用于构建用户提要的查询。这个查询的问题是“uf.user_idin()”随着用户关注的用户数量的增加而增加。SQL查询允许的最大长度是多少?有没有更好的方法来实现上面的查询?注意:我正在使用ActiveRecord和Postgres。 最佳答案 PostgreSQL可以处理的查询的最大长度是2147483648个字符(带符

ruby - 动态添加 ruby​​ 类方法或实例方法

我对Ruby很陌生,所以还在学习中。我研究了很多关于如何动态添加方法,并且我成功地创建了实例方法,但在创建类方法时却没有成功。这就是我生成实例方法的方式:classBdefbefore_methodputs"beforemethod"enddefself.run(method)send:define_method,methoddobefore_methodputs"method#{method}"endendendclassA关于创建静态方法的最佳方法有什么想法吗?我的最终任务是寻找为类方法创建“之前”和“之后”任务的最佳方式。 最佳答案

ruby - 如何在 Ruby 中动态改变继承

我想在Ruby中为一个类动态指定父类。考虑这段代码:classAgentdefself.hook_up(calling_class,desired_parent_class)#DosomemagichereendendclassParentdefbarputs"bar"endendclassChilddeffooputs"foo"endAgent.hook_up(self,Parent)endChild.new.barParent和Child类定义均未指定父类,因此它们都继承自Object。我的第一个问题是:我需要在Agent.hook_up中做什么才能使Parent成为Child的父

Ruby strftime : Day without leading zero, %e 不工作

我正在尝试用没有前导零的日期来格式化日期使用%d它工作正常,但前导零date_time.strftime("%d/%m/%y")result:04/01/11我搜索了一下,发现我应该使用%e而不是%d,但是执行以下操作会得到一个空字符串。date_time.strftime("%e/%m/%y")result:这跟Ruby的版本有关系吗?我在Windows机器上使用v1.8.7。更重要的是,是否有另一种方法可以在没有前导零的情况下完成一天(比gsub更方便)? 最佳答案 如果你想删除月份或日期的前导零,只需在格式前添加一个减号,如下

ruby-on-rails - 帮助重构这个讨厌的 Ruby if/else 语句

所以我有这个大而多毛的if/else语句。我将一个跟踪号传递给它,然后它确定它是什么类型的跟踪号。我怎样才能简化这件事?特别想减少代码行数。ifnum_length是的,我知道。这很讨厌。 最佳答案 试试这个。我使用case和正则表达式重写了它。我还使用:symbols而不是"strings"作为返回值,但您可以将其改回。tracking_service=casenumberwhen/^.Z/then:upswhen/^Q/then:dhlwhen/^96.{20}$/then:fedexwhen/^[HK].{10}$/then:

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