草庐IT

sql - 返回列的前 n 个字母

全部标签

ruby - 使用注入(inject)时可以分离出散列的键和值吗?

当在ruby​​中的散列上调用each时,您可以像这样很好地分离键和值:{:a=>1,:b=>2,:c=>3}.eachdo|key,value|puts"keyis#{key}andvalueis#{value}"end=========================keyis:aandvalueis1keyis:bandvalueis2keyis:candvalueis3=>{:a=>1,:b=>2,:c=>3}然而,这在使用inject时似乎不起作用。{:a=>1,:b=>2,:c=>3}.inject(0)do|result,key,value|puts"keyis#{key

sql - 选择预定项目时在 Postgres 中考虑 DST

我有一个Postgres时钟闹钟表(不是真的,但这是类似的,而且更容易解释)。警报由用户设置,分辨率为1小时,用户可以来自许多不同的时区。警报每天都在重复。我想可靠地获取应该在一天中的特定时间响起的警报,并且我遇到夏令时问题。如何以最佳方式做到这一点?例子AlfredandLottabothliveinStockholm(+1hourfromUTC,but+2hwhenit'sDST).SharonlivesinSingapore(+8hoursfromUTC,noDST)Duringwinter,Alfredsetsanalarmfor4AM.Thealarmshouldgooffa

ruby - 是否可以让 class.property = x 返回 x 以外的东西?

假设我有一个Ruby类:classMyClassdefself.propertyreturn"someVal"enddefself.property=(newVal)#dosomethingtoset"property"success=truereturnsuccess#successisabooleanendend如果我尝试执行MyClass.property=x,整个语句的返回值始终是x。许多基于C/受启发的语言都习惯于返回bool“成功”值-是否可以使用Ruby中的“等于语法”为setter执行此操作?此外-如果这不可能,为什么不呢?允许“equalssetter”操作返回一个值

ruby-on-rails - 为 Rails 上的连接、限制、选择等(不是条件)的 SQL 片段安全地转义字符串

在RubyonRails中,对于条件,很容易进行SQL防注入(inject)查询::conditions=>["title=?",title]标题来自外部,来自Web表单或类似的东西。但是,如果您在查询的其他部分使用SQL片段怎么办,例如::select=>"\"#{title}\"AStitle"#Idohavesomethinglikethisinoneinstance:joins=>["LEFTJOINblahASblah2ONblah2.title=\"#{title}\""]有没有办法正确转义这些字符串? 最佳答案 通常在

ruby - 如何使用 Net::HTTP 只读取正文的 x 个字节?

在读取网页正文时,Ruby的Net::HTTP方法似乎是全有或全无。例如,我如何读取正文的前100个字节?如果请求的文件不可用,我正在尝试从内容服务器读取内容服务器,该内容服务器会在响应正文中返回一条简短的错误消息。我需要阅读足够多的正文以确定文件是否存在。文件很大,所以我不想让整个body只是为了检查文件是否可用。 最佳答案 这是一个旧线程,但根据我的研究,如何在Ruby中通过HTTP只读取文件的一部分的问题仍然是一个大部分没有答案的问题。这是我通过猴子修补Net::HTTP得到的一个解决方案:require'net/http'#

ruby - 我如何检查字符串中是否存在某个单词,如果不存在,则在 ruby​​ 中返回 false?

假设我有一个字符串str="Thingstodo:eatandsleep."如何检查"do:"是否存在于str中,不区分大小写? 最佳答案 像这样:puts"yes"ifstr=~/do:/i要返回一个bool值(大概是从一个方法中),将匹配结果与nil进行比较:defhas_do(str)(str=~/do:/i)!=nilend或者,如果你不喜欢!=nil那么你可以使用!~而不是=~并否定结果:defhas_do(str)notstr!~/do:/iend但我真的不喜欢双重否定......

ruby-on-rails - rails 控制台要求 nokogiri 返回 false(但在 irb 中工作)

我的环境是ruby1.9.3p327和rails3.2.8onamac。我将gemnokogiri添加到我的Gemfile中。运行bundleinstall命令。命令显示Usingnokogiri(1.5.5)和gemlist命令返回nokogiri(1.5.5)。在Rails控制台中require'nokogiri'返回false但在irb中它返回true。这怎么可能? 最佳答案 根据theAPIdocumentation的前两行,require将:如果加载成功返回true如果已经加载则返回false如果找不到文件则引发LoadE

sql - 如何查询存储在数组中的 Rails ActiveRecord 数据

我有一个名为MentorData的Rails模型,它有一个名为os_usage的属性。这些ose存储在一个数组中,就像这样['apple','linux']。回顾一下:$MentorData.first.os_usage=>['apple','linux']我希望能够查询所有MentorData的数据,包括apple的os_usage,但是当我搜索MentorData.where(os_usage:'apple')我只得到只会用apple不会用apple和linux的导师。我需要以某种方式进行搜索以检查苹果是否包含在数组中。我也试过以下方法。MentorData.where('os_u

ruby-on-rails - 让 find_by in rails 返回多个结果

我正在尝试返回用户创建的所有组。所有组都与用户标识相关联。当我运行find_by查询时,它只返回第一个结果。有没有办法让它返回多个?提前致谢 最佳答案 我正在写一个单独的答案,因为我没有50分,无法评论JamesLowrey的答案。find_all_by已弃用(Ruby4.2)。要从模型中获取事件记录列表,请执行以下操作:Model.where(attribute_name:val)例如,要在Vehicle表(具有列名称“model_name”)中查找所有记录,使得model_name的值为“Audi”,执行@vehicles=Ve

sql - 从 Rails 4 应用程序调用大量 SQL

我有一个Rails4应用程序,我将它与sidekiq结合使用来运行异步作业。我通常在Rails应用程序之外运行的作业之一是大量复杂的SQL查询,这些查询实际上无法通过ActiveRecord建模。这组SQL查询与我的Rails应用程序的联系是它应该在我的Controller操作之一被调用时执行。理想情况下,我会在Controller中将我的Rails应用程序的作业排队,以便Sidekiq继续运行查询。现在它们存储在一个外部文件中,我不完全确定让Rails运行上述SQL的最佳方法是什么。感谢任何解决方案。 最佳答案 我同意Sharag