草庐IT

sql_string

全部标签

ruby-on-rails - array * string 在 Ruby 中是什么意思?

我在查看一些Rails源代码时偶然发现了#Filevendor/rails/activesupport/lib/active_support/vendor/builder-2.1.2/builder/css.rb,line129129:deftarget!130:@target*''131:end*''是做什么的?那是乘以一个空字符串......?你为什么要那样做。 最佳答案 这是一个奇怪的语法。这些是等价的:>>[1,2,3]*'joiner'=>"1joiner2joiner3">>[1,2,3].join'joiner'=>"

ruby-on-rails - Ruby 1.8.7(或 Rails 2.x)中的 String.force_encoding()

是否有在Ruby1.8.7(或Rails2.x)中使用String.force_encoding()的解决方案,以便它像在Ruby1.9中一样工作?我读了一些关于requireactive_support的内容,但这不起作用$>gem列表--本地|grep'rails\|activesupport'activesupport(3.0.3,2.3.8,2.3.5)rails(2.3.8,2.3.5)$>ruby-vruby1.8.7(2010-08-16patchlevel302)[i686-darwin10.4.0]$>rails-vRails2.3.8IRB:>require"rub

ruby - 如何转义 Ruby 中的字符串以防止 SQL 注入(inject)? (无导轨)

我只是想知道我们如何在Ruby中转义SQL查询(字符串)以防止SQL注入(inject)。请注意我没有使用Rails框架。谢谢。 最佳答案 如果可能,请使用RubyDBI模块,而不是尝试引用您的字符串,而是使用参数化的准备查询,如下所示:dbh=DBI.connect("DBI:Mysql:test:localhost","testuser","testpass")sth=dbh.prepare("INSERTINTOpeople(id,name,height)VALUES(?,?,?)")File.open("people.txt

ruby - 没有将 nil 隐式转换为 String 错误

我有一个ruby​​脚本,它将通过获取和合并来自另一个文件的值来创建两个文件。#Resourcesrequire'rubygems'require'csv'col_date=[]col_constant1=[]col_constant2=[]col_appYear=[]col_statsDesc=[]col_keyStats=[]col_weeklyTotal=[]weekly_total=[]fname="finalStats.csv"#variableforcapturefilefinalStatsFile=File.open(fname,"w")#writetocapturefi

sql - 如何使用 Sequel 运行原始 SQL 查询

我还不清楚使用Sequel运行原始SQL查询的正确方法。目前我正在尝试这个:DB.fetch("SELECT*FROMzoneWHEREdialcode='#{@dialcode}'LIMIT1")do|row|@zonename=rowend我怎样才能将查询作为原始SQL运行,然后像平常一样访问结果?if@zonename.name="UK" 最佳答案 请注意,而不是:DB.fetch("SELECT*FROMzoneWHEREdialcode='#{@dialcode}'LIMIT1")你应该这样做:DB.fetch("SELE

ruby - `dirname' : can't convert nil into String (TypeError)

我不确定这是否真的在cucumber中,但以防万一你们中的一些人知道如何解决这个问题。基本上,我的测试突然停止工作,当我检查时,它显示了这个错误:C:/Vendor/Ruby187/lib/ruby/gems/1.8/gems/cucumber-rails-1.0.0/lib/cucumber/rails3.rb:3in'dirname':can'tconvertnilintoString(TypeError)是的,我先翻了个白眼,然后诅咒Windows,但我在我的Mac上试了一下,我得到了同样的结果:/Users/eumir/.rvm/gems/ruby-1.8.7-p174@myg

ruby - 当字符串包含数字时,为什么 Ruby 的 String#to_i 有时会返回 0?

我刚刚尝试使用Ruby,然后遇到了String#to_i。假设我有这段代码:var1='6sldasdhkjas'var2='aljdfldjlfjldsfjl6'为什么putsvar1.to_i输出6而putsvar2.to_i给出0? 最佳答案 to_i方法返回由字符串开头处的所有可解析数字组成的数字。您的第一个字符串以带有数字的a开头,因此to_i返回该字符串,第二个字符串不以数字开头,因此返回0。顺便说一句,空格被忽略,所以"123abc".to_i返回123. 关于ruby-当

ruby-on-rails - 如何清理 Rails 4 中的原始 SQL

在Rails3中,我可以使用sanitize_sql_array为那些偶尔需要原始SQL查询的时刻清理原始SQL。但这似乎已在Rails4中删除,或者没有删除太多,而是移至ActiveRecord::Sanitization。但是,我现在不知道如何调用sanitize_sql_array,那么在Rails4中清理原始SQL的最佳方法是什么?我想澄清一下,我在这里谈论的是完整的原始SQL查询,而不是使用Rail的模型。我知道这不是最佳实践,这正是我必须为这个特定查询做的事情,因为它不能用Rails漂亮的ActiveRecord接口(interface)表示(相信我,我已经试过了)。这是一

sql - Ruby 中的 pretty-print SQL

有没有一种简单的方法可以在(rails3)控制台中pretty-print随机SQL?类似于awesome_print的内容,甚至可能是PrettyPrint.它不需要理解所有可能的方言或非常高级。我真正想要的是更轻松地检查ActiveRecord生成的SQL。目前我只是将SQL复制到网上进行格式化,这显然是生产力killer。我真的很想query.to_sql.pretty_format_sql并查看更好的输出。谢谢。 最佳答案 试试这个:gitclonehttps://github.com/sonota/anbt-sql-for

ruby - 为什么没有 String#shift()?

我正在努力通过ProjectEuler,并遇到了一个有点令人惊讶的遗漏:没有String#shift、unshift、push或pop.我曾假设String被认为是像数组一样的“顺序”对象,因为它们共享索引和迭代的能力,并且这将包括轻松更改对象的开头和结尾的能力。我知道有一些方法可以创建相同的效果,但是是否有特定原因导致String没有有这些方法? 最佳答案 从1.9开始,字符串不再作为可枚举对象,因为它被认为太困惑而无法决定它是一个列表:字符/代码点列表?字节列表?行列表? 关于rub