草庐IT

SQL中的排座位问题

全部标签

ruby - 在生产环境中调试 Sinatra 应用程序时遇到问题

我正在使用passenger部署Sinatra应用程序。已部署的应用程序正在运行,但并非完全正常:某些路径运行良好,其他路径只是呈现一个空白页面。我似乎找不到有效路线和无效路线之间的任何重大差异,而且我似乎无法追踪任何错误..处理程序我定义了not_found和错误处理程序如下:not_founddo'404.Bummer!'enderrordo'Nastyerror:'+env['sinatra.error'].nameend这些在我的本地机器上运行良好,无论是在开发还是生产中,但我从来没有看到它们出现在服务器上。Apache日志当我跟踪Apache的access.log并找到其中一

ruby - 带有 WSDL 的 ruby​​ 中的 SOAP 服务器

我需要为一个调用在ruby​​中实现一个soap服务器,并提供一个WSDL。我的计划是自己创建WSDL,并在带有解析xml的端点的Rails服务器上提供它。那是一条有效的路径吗?我查看并找不到关于生成WSDL的ruby​​soap服务器的其他信息。ActionWeb服务有,但最后一次更新是在2005年,并且soap4r独立服务器不会生成WSDL。 最佳答案 任何对这个问题的有效解决方案感兴趣的人都应该试一试gem“wash_out”。我已经成功开发了一个带有v0.8.2的SOAP服务器请引用thegem'sgithubreposit

ruby-on-rails - readline 有什么问题?

我使用不同的操作系统以及Rails3和Rails4设置了三次Rails环境。直到我打开控制台输入一些Ruby,或者使用railsconsole或Rails数据库控制台。我得到类似于:$railsconsole/home/tobias/.rvm/rubies/ruby-1.9.2-p180/lib/ruby/1.9.1/irb/completion.rb:9:in`require':nosuchfiletoload--readline(LoadError)from/home/tobias/.rvm/rubies/ruby-1.9.2-p18080/lib/ruby/1.9.1/irb/c

ruby-on-rails - 如何使用 RestClient 修复 Ruby 中的套接字错误?

我正在使用RestClient在ruby​​类中进行网络调用。每当我未连接到Internet时,我都会收到SocketError。我已经添加了一个救援block来捕获异常,但我仍然无法这样做。错误信息是:SocketError(无法打开到api.something.com:443的TCP连接(getaddrinfo:名称或服务未知))moduleMyProjectclassClientdefget_object(url,params={})response=RestClient.get(url,{params:params})rescueSocketError=>eputs"InSoc

ruby - Ruby 中命名空间函数的最佳实践? (新手问题)

(StackOverflow告诉我这个问题是“主观的,可能会被关闭”……好吧,无论如何我都会试一试)我正在编写一堆辅助方法(用于TextMate包),我希望(并且我需要)将它们整齐地命名空间。这些方法实际上只是函数,也就是说,它们不会对自身作用域之外的任何东西进行操作,因此并不真正属于某个类。没有什么需要实例化。到目前为止,我一直在这样做,而且效果很好moduleHelpers::Foomodule_functiondefbar#...endendHelpers::Foo.bar#thisishowI'dliketocallthemethod/function但是这样会更好吗:1.跳过

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

sql - 如何查看 SQL ActiveRecord 生成的内容?

我想检查一些由ActiveRecord生成的查询,但我不需要实际运行它们。有没有办法在返回结果之前获取查询? 最佳答案 这两篇文章都应该可以帮助您做您想做的事。http://weblog.jamisbuck.org/2007/1/8/watching-activerecord-do-it-s-thinghttp://weblog.jamisbuck.org/2007/1/31/more-on-watching-activerecord 关于sql-如何查看SQLActiveRecord生

ruby - 自动向 ruby​​ 中的所有 HTTP 连接添加代理

我有一个启动多个HTTP连接的应用程序,我想为所有连接添加一个代理。该应用程序正在使用net/HTTP、TCP套接字和open-uri所以理想情况下我希望能够修补所有连接从这些库启动,而不是手动将其添加到启动连接的代码中的每个位置。有没有办法实现(在Ruby1.9.2上)? 最佳答案 OpenURI使用HTTP_PROXY环境变量这是一篇关于如何在windows和unix变体上使用它的文章。http://kaamka.blogspot.com/2009/06/httpproxy-environment-variable.html您也

sql - 用于 250K+ 字符串的通配符搜索的 Fast(er) 方法

我在MySQL数据库中有一个英语词典,其中只有超过250K个条目,我正在使用一个简单的ruby​​前端在字符串的开头使用通配符来搜索它。到目前为止,我一直这样做:SELECT*FROMwordsWHEREwordLIKE'_e__o'甚至SELECT*FROMwordsWHEREwordLIKE'____s'我总是知道单词的确切长度,但除了一个字符之外的所有字符都可能是未知的。这比糖蜜慢,比没有前导通配符的类似查询慢大约15倍,因为无法使用该列的索引。我尝试了几种方法来缩小搜索范围。例如,我添加了26个额外的列,其中包含每个单词的单个字母计数,并首先使用这些列来缩小搜索范围。我也试过按

ruby - Ruby 中的 "Gemfile"在哪里?

我经常在互联网上的文档中看到,“把它放在Gemfile中”。我不知道这个“Gemfile”在哪里和什么。如果我安装了gem,那么我已经安装了它。谁需要一个“Gemfile”?Gemfile在哪里或什么,为什么使用它? 最佳答案 Gemfile位于您想要的任何位置-通常位于项目的主目录中,文件名为Gemfile。拥有一个很方便,因为它允许您使用Bundler来管理每个项目需要运行哪些gem和哪些版本。如果您没有使用Bundler(您应该使用它!),那么您可以只安装使用geminstallX遇到的任何gem,并忽略有关向Gemfile添