草庐IT

多表连接查询

全部标签

ruby - 不使用 Rails 将 Ruby 连接到 Mysql

如何在没有Rails的情况下将Ruby连接到Mysql?我想使用Rubystandalone编写纯ruby​​代码来制作Web应用程序。没有抽象 最佳答案 看这里require"mysql"#ifneeded@db_host="localhost"@db_user="root"@db_pass="root"@db_name="your_db_name"client=Mysql::Client.new(:host=>@db_host,:username=>@db_user,:password=>@db_pass,:database=>

ruby - 使用 Ruby 检查 Internet 连接是否存在?

刚刚问到如何checkifaninternetconnectionexistsusingjavascript并得到了一些很好的答案。在Ruby中执行此操作的最简单方法是什么?为了使生成的html标记代码尽可能干净,我想根据Internet条件有条件地呈现javascript文件的脚本标记。类似的东西(这是HAML):-ifinternet_connection?%script{:src=>"http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js",:type=>"text/javascript"}-else%scr

ruby - 如何捕获由对等方重置的错误连接 (Errno::ECONNRESET)

以下代码有时会生成“连接被对等方重置”错误。谁能告诉我如何处理这个异常?doc=Nokogiri::HTML(open(url))Connectionresetbypeer(Errno::ECONNRESET) 最佳答案 要捕获它,就像处理任何其他异常一样:begindoc=Nokogiri::HTML(open(url))rescueErrno::ECONNRESET=>eputs"wearehandlingit!"end更有用的模式是尝试几次,然后放弃:count=0begindoc=Nokogiri::HTML(open(ur

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,

ruby - 在连接之前检查 nil 字符串

这个问题类似于很多问题,但绝不是重复的。这个问题是关于字符串连接和编写比检查零/零更好的代码。目前我有:file.puts"cn:"+(var1.nil??"UNKNOWN":var1)效果很好,但看起来不太好。有什么更好的方法可以用ruby​​编写它,以便我检查nil而不是连接它 最佳答案 你可以这样做:file.puts"cn:"+(var1||"UNKNOWN")或者,如果您愿意,也可以:file.puts"cn:"+(var1or"UNKNOWN")或者我最喜欢的,我认为是最地道的ruby​​:file.puts"cn:#{

ruby-on-rails - 如何修复 Rails 中 pg_attribute 表的缓慢隐式查询

在我们的生产环境中,我们注意到Rails应用程序频繁出现峰值(大约每1小时一次)。深入挖掘,这是由于以下查询在单个HTTP请求中累计运行时间超过1.5秒(称为100倍)。SELECTa.attname,format_type(a.atttypid,a.atttypmod),pg_get_expr(d.adbin,d.adrelid),a.attnotnull,a.atttypid,a.atttypmodFROMpg_attributeaLEFTJOINpg_attrdefdONa.attrelid=d.adrelidANDa.attnum=d.adnumWHEREa.attrelid=

ruby - 自动记录 DataMapper 查询

我正在使用DataMapper在Sinatra中开发一个简单的应用程序。我想查看DM为我的各种链式查找器等创建的查询。我试过:DataMapper::Logger.new(STDOUT,:debug)在我的configuredo...endblock中,environment.rb文件会在应用程序启动时加载。我也试过:DataMapper::Logger.new('log/my-app.log',:debug)既不会从通过浏览器或通过需要我的应用程序的irbsession访问的应用程序生成日志语句。我确实看到了应用启动消息。我正在使用rackupconfig.ru在本地运行应用程序。我

ruby-on-rails - 我的应用程序一直在创建数据库连接,我该如何追踪原因?

我有一个在Heroku上运行的RubyonRails应用程序。我不断在日志中收到这些消息:2015-05-05T16:11:14Zapp[postgres.27102]:[AQUA]connectionreceived:host=xx.xxx.xx.26port=602782015-05-05T16:11:14Zapp[postgres.27102]:[AQUA]connectionauthorized:user=postgresdatabase=somedb2015-05-05T16:11:14Zapp[postgres.27103]:[AQUA]connectionreceived

ruby-on-rails - 将查询字符串附加到 url

我有一个回调url字符串params[:callback],我需要附加一个查询字符串"&result=true"并重定向用户。我发现这样做的更好方法是使用addressable但我认为代码对于这样的任务来说太大了,尤其是当我们谈论ruby​​时:callback=Addressable::URI.parse(params[:callback])query=callback.query_valuesquery[:result]='true'callback.query_values=queryredirect_tocallback.to_s是否有更优雅的方式来获得与此代码段相同的结果?

ruby-on-rails - 如何获取触发查询的代码行?

在rails3.2中是否有一种方法(一个gem、一个插件或其他东西)来知道哪一行代码触发了一个数据库查询?例如在我的日志中我有:UserLoad(0.4ms)SELECT`users`.*FROM`users`WHERE`users`.`id`=5LIMIT1如何知道触发查询的代码行?谢谢... 最佳答案 我找到了这个解决方案:moduleQueryTracedefself.enable!::ActiveRecord::LogSubscriber.send(:include,self)enddefself.append_featur