草庐IT

第三章-标准SQL语句

全部标签

sql-server - Ruby 连接到 SQL Server

我在将Ruby连接到MicrosoftSQLServer时遇到问题。我正在运行MacOSX,但目标环境是UbuntuLinux。这是我尝试过的:安装unixODBC安装FreeTDS使用了选项--with-unixodbc=/usr/local/etc--with-tdsver=8.0然后我在/usr/local/etc中有了这些文件:odbc.iniodbcinst.inifreetds.conf我在odbcinst.ini文件中将对FreeTDS驱动程序的引用添加到我的ODBC驱动程序文件中,如下所示:;;odbcinst.ini;;[FreeTDS]Driver=/usr/loc

sql - Rails 中独立于数据库的 SQL 字符串连接

我想在Rails查询中进行数据库端字符串连接,并以独立于数据库的方式进行。SQL-92指定双杠(||)作为连接运算符。不幸的是,MSSQLServer似乎不支持它;它使用+代替。我猜Rails的SQL语法抽象已经解决了特定于数据库的运算符问题。如果它确实存在,我该如何使用它? 最佳答案 我遇到了同样的问题,但从未想出任何内置于Rails中的东西。所以我写了这个小方法。#Symbolsshouldbeusedforfieldnames,everythingelsewillbequotedasastringdefdb_concat(*a

ruby - 'array.each do |block|'在生成的 Haml HTML 中包含语句的结果

我正在生成一封电子邮件,其中包含来自Haml模板的动态内容,该模板解析数组中的信息。基本上,Haml接收一个包含多个哈希值的数组。在代码中,我有一个如下所示的block:%table=arrayname.eachdo|object|%tr%td=object.name%td=object.link每当发送电子邮件时,整个对象arrayname都包含在HTML的底部。这会导致[#,#](当有更多对象时更多#)显示在block的顶部。没有办法用CSS操纵这段文本,否则我会把它隐藏起来。[#,#]该行与在IRB中执行代码时显示的结果相同。谁能告诉我如何防止这种情况发生?

ruby - 在 case 语句中使用类对象

在case语句中使用类对象的最佳方式是什么?假设我有a,它是Class类的一个实例。我想将它与不同的类(class)相匹配。如果我这样做caseawhenStringthen...whenFixnumthen...end这不会给出预期的结果,因为即使a==String例如,a===String也是不正确的。执行此操作的巧妙方法是什么? 最佳答案 我不会使用to_s,因为"String".to_s会是"String",所以也许我会使用casewhena==Stringthen...whena==Fixnumthen...end或a=S

sql - 将每个 SQL 查询记录到 Rails 中的数据库

我想将某些SQL查询rails执行(即CREATE、UPDATE和DELETE)保存到日志文件中因此我需要拦截所有查询,然后可能使用一些正则表达式过滤它们并根据需要记录它们。我应该把这样的东西放在Rails代码的什么地方? 最佳答案 这里是c0r0ner链接的简化版本,以更好地展示它:connection=ActiveRecord::Base.connectionclasse;end#executeoriginalstatementoriginal_exec(sql,*name)endend

ruby - 在 ruby​​ 中哪个更快 - 散列查找或带有 case 语句的函数?

在时间紧迫的脚本中,我们有几个地方可以将旧ID转换为字符串。目前,我们在函数内部使用case语句,如下所示:defget_nameidcaseidwhen1"onething"when3"otherthing"else"defaultthing"endend我正在考虑将其替换为哈希查找,如下所示:NAMES={1=>"onething",3=>"otherthing",}NAMES.default="defaultthing"感觉使用NAMES[id]应该比使用get_name(id)更快-但真的是这样吗? 最佳答案 首先,有几点。

ruby-on-rails - Rails 上持续的第三方 API 监控和测试

我们想设置自动化作业(通过Jenkins)以在第三方API出现故障或他们部署了不兼容的API时发出警报。我说的是针对真实的HTTPAPI进行测试,而不是模拟,但是因为我们已经使用rspec编写了模拟,所以我不确定我们是否应该通过编写两个独立的睾丸来重复这项工作。有人有这方面的经验吗?(如果其他工具可以提供帮助,我不限于Ruby/Rspec) 最佳答案 你看过VCR了吗??使用它,您可以“记录您的测试套件的HTTP交互并在未来的测试运行期间重播它们以进行快速、确定性、准确的测试”。在测试来自外部API的预期响应时,我将它与RSpec一

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

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 - 如何从其他 Ruby 脚本调用标准 Rakefile 中定义的 Rake 任务?

是否可以从其他Ruby脚本调用在Rakefile中定义的任务-而不是在somefile.rake中定义的任务?我希望创建一个新的Rake::Application会自动从同一目录加载Rakefile,但事实并非如此。这是我到目前为止的想法:$LOAD_PATH.unshiftFile.dirname(__FILE__)require'rake'require'pp'rake=Rake::Application.newrake[:hello].invoke执行此代码会产生以下结果:/opt/ruby/1.9.2-p180/lib/ruby/1.9.1/rake.rb:1720:in`[]