草庐IT

9个SQL运维常遇到的问题

全部标签

ruby - 有没有办法查看 Sequel 表达式将生成的原始 SQL?

假设我有一个像这样的Sequel表达式:db.select(:id).from(:some_table).where(:foo=>5)有没有办法获取这将生成的SQL字符串(即"SELECTidFROMsome_tableWHEREfoo=5")?我注意到对上述表达式的结果调用inspect或to_s包括生成的SQL,但不确定如何直接访问它。以及不返回数据集的Sequel表达式如何,例如:db.from(:some_table).update(:foo=>5)是否可以在执行之前从中看到SQL? 最佳答案 你可以在数据集上调用sql:d

ruby - 使用 RVM 在 Ubuntu 10.10 上安装 Ruby,gem 有问题

我决定从ubuntu10.10开始。我从安装git开始,然后从gitrepo安装rvm。一切正常很好,我编译并安装了ruby​​1.8.7和ruby​​1.9.2gem也已安装,我运行gem-v但是当运行gemlist或geminstallrake我得到以下错误ERROR:Loadingcommand:list(LoadError)nosuchfiletoload--zlibERROR:Whileexecutinggem...(NameError)uninitializedconstantGem::Commands::ListCommand知道如何解决这个问题吗?我也试过sudoapt

ruby-on-rails - Ruby on Rails : hash. 每个 {} 问题

这是我的代码:records_hash=records[:id].inject({}){|result,h|ifresult.has_key?(h)result[h]+=1elseresult[h]=1endresult}@test2=records_hash.each{|key,value|puts"#{key}is#{value}"}我的输出应该是这样的:bozois3bubbais4bonkeris5但它在页面()上呈现如下:bozo3bubba4bonker5我已经用类似的block尝试了.each_key和.each-value,它们都返回上面相同的字符串。我在IRB中运行相

ruby-on-rails - 数组上的 rails where() sql 查询

我会尽可能详细地解释这一点。我对用户帖子有疑问:@selected_posts=Posts.where(:category=>"棒球")我想写下面的语句。这是伪术语:User.where(用户在@selected_posts中有帖子)请记住,我设置了多对多关系,因此post.user可用。有什么想法吗?/编辑@posts_matches=User.includes(@selected_posts).map{|user|[user.company_name,user.posts.count,user.username]}.sort基本上,我需要上面的工作,以便它使用在selected_p

ruby-on-rails - Rails 5 SQL 注入(inject)

我已经在各种SO线程、指南等上阅读了一段时间...但所有答案都是相互矛盾和矛盾的。好像有很多类似的方法,而且很多答案都说使用不同的方法。清理sanitize_conditionssanitize_sqlsanitize_sql_arraysanitize_sql_for_assignmentsanitize_sql_for_conditionssanitize_sql_hashsanitize_sql_hash_for_assignmentsanitize_sql_hash_for_conditionssanitize_sql_like我正在尝试编写一个“原始查询”适配器,让我可以运行

sql - 在 ActiveRecord 中存储序列化哈希与键/值数据库对象的优缺点?

如果我有几个对象,每个对象基本上都有一个Profile,我用什么来存储随机属性,有什么优缺点:在记录列中存储序列化哈希,对比存储一组属于主对象的键/值对象。代码假设您有这样的STI记录:classBuilding:profilableendclassOfficeBuilding每个has_one:profile选项1.序列化哈希classSerializedProfiletruedo|t|t.string:namet.string:websitet.string:emailt.string:phonet.string:typet.text:settingst.integer:profi

ruby-on-rails - 程序 'rails' 可以在以下包中找到 - 某些应用程序和 RVM 有问题吗?

我刚刚从github下载了一个应用程序代码,当我尝试运行命令railss时,出现了这个错误-Theprogram'rails'canbefoundinthefollowingpackages:*rails*ruby-railties-3.2此问题仅适用于此应用,有人可以告诉我如何解决此问题吗?我正在使用RVM 最佳答案 以防其他人遇到此问题,但上述方法不起作用。尝试运行:/bin/bash--login然后运行rvmuse2.0.0#orwhateveryourversionnumberis...

c - Ruby C 扩展 API 问题

所以,最近我不幸地需要为Ruby做一个C扩展(因为性能)。因为我在理解上有问题VALUE(并且仍然如此),所以我查看了Ruby源代码并发现:typedefunsignedlongVALUE;(LinktoSource,但您会注意到它还有其他一些“方法”,但我认为它本质上是一个long;如果我错了,请纠正我)。因此,在进一步调查时,我发现了一个有趣的blogpost,其中说:"...insomecasestheVALUEobjectcouldBEthedatainsteadofPOINTINGTOthedata."令我困惑的是,当我尝试从Ruby将字符串传递给C并使用RSTRING_PT

sql - 如何使用 ActiveRecord 模型在日期范围内进行搜索?

我是Ruby和ActiveRecord的新手。我目前需要修改现有的一段代码以在选择中添加日期范围。当前的作品是这样的:ReportsThirdparty.find(:all,:conditions=>{:site_id=>site_id,:campaign_id=>campaign_id,:size_id=>size_id})现在,我需要添加一个范围,但我不确定如何做BETWEEN或>=或运营商。我想我需要的是类似于:ReportsThirdparty.find(:all,:conditions=>{:site_id=>site_id,:campaign_id=>campaign_id

sql - 使用 SQL IN 和 SQL OR 运算符的 Rails 3 ActiveRecord 查询

我正在使用“where”语法编写一个Rails3ActiveRecord查询,它同时使用了SQLIN和SQLOR运算符,但不知道如何同时使用它们。此代码有效(在我的用户模型中):Question.where(:user_id=>self.friends.ids)#note:self.friends.idsreturnsanarrayofintegers但是这段代码Question.where(:user_id=>self.friends.idsOR:target=>self.friends.usernames)返回这个错误syntaxerror,unexpectedtCONSTANT,