草庐IT

php - 查询连接三个表 yii

全部标签

ruby-on-rails - Rails 查询执行导致数据库峰值

我的Rails应用程序出现问题,一些随机查询需要大约5秒或更长时间才能完成。大多数时候,查询非常简单(select*fromxwhereid=?),而且字段甚至也被编入索引。这里有一些关于设置的更多信息:反向nginx代理背后的Puma3.5.04个worker,每个worker最少4个,最多8个线程。Rubyv2.2.3,Railsv4.2.4PostgreSQL9.4数据库线程池设置为最多60个连接监控应用8GBRAM、4个CPU、SSD。我在查看Appsignal中的查询性能时发现了这一点。我注意到大多数查询在几毫秒内完成,然后时不时地,仍然在同一个请求中,有多个查询需要5秒以上

ruby-on-rails - 在 Rspec 中用项目符号标记 N+1 查询

我正在尝试使用bulletgem标记N+1并在代码中添加计数器缓存的位置.但是手动执行所有检查N+1查询的操作似乎非常痛苦,所以我尝试使用Bullet和Rspec,使用他们推荐的设置步骤:#config/environments/test.rbconfig.after_initializedoBullet.enable=trueBullet.bullet_logger=trueBullet.raise=true#raiseanerrorifn+1queryoccursend#spec/spec_helper.rbifBullet.enable?config.before(:each)d

ruby-on-rails - 无法连接到服务器 : "/var/run/postgresql/.s.PGSQL.5432"?

我在RubyOnRails中有一个带有postgresql数据库的简单网页,但是当我运行服务器时出现此错误,我不知道我这样做了。我使用postgresql,因为heroku需要应用程序在postgresql中。我在ubuntu13.10上工作错误是:PG::ConnectionBad无法连接到服务器:没有这样的文件或目录服务器是否在本地运行并接受Unix域套接字“/var/run/postgresql/.s.PGSQL.5432”上的连接?我需要帮助谢谢 最佳答案 像这样创建一个软链接(softlink),这对我有用$sudoln-

ruby-on-rails - ActiveRecord:查询未对 STI 子类使用正确的类型条件

我有一组STI子类继承自User基类。我发现在子类定义中的某些条件下,对子类的查询没有正确使用type条件。classUser在开发中加载Rails控制台时,它会按照我的预期进行:Admin:SELECT`users`.*FROM`users`WHERE`users`.`type`IN('Admin')但是当点击应用程序(localhost/pow)时,它缺少type条件,我明白了:Admin:SELECT`users`.*FROM`users`但在部署到暂存服务器时不是来自应用程序:Admin:SELECT`users`.*FROM`users`WHERE`users`.`type`

ruby-on-rails - 如何使用 OAuth 将 Aweber 连接到我的 Rails 应用程序?

我正在尝试通过OAuth将我的Rails应用程序与Aweber集成,使用officialawebergem.如果我在Rails控制台中遵循他们的流程,我可以获得访问token,没问题:oauth=AWeber::OAuth.new(ENV["AWEBER_CONSUMER_KEY"],ENV["AWEBER_CONSUMER_SECRET"])putsoauth.request_token.authorize_url#=>https://auth.aweber.com/1.0/oauth/authorize?oauth_token=xxxxxxxxxxxxxx然后我访问该URL,输入我

ruby - 在连接之前定义 Sequel 模型

在我的(非Rails)应用程序中,我试图定义一个Sequel模型:classFoo当我运行我的应用程序时,出现错误:NodatabaseassociatedwithSequel::Model:haveyoucalledSequel.connectorSequel::Model.db=?(Sequel::Error)事实上,我没有调用连接,因为“requireFoo”发生在我的数据库代码运行之前。当然,我可以换个方式,以便在数据库连接后完成要求,但还有其他选择吗?目前,我将应用程序的所有“require”语句都放在一个文件中,最好不要为这些模型类文件破坏它。

sql - 具有相同名称列的连接表上的 Rails ".pluck"返回一个值,然后返回 nil

Experimenthas_many:featuresFeaturebelongs_to:experimentExperiment.where("experiments.id=1").joins(:features).pluck("features.id","experiments.id")我希望这会返回每个功能的ID和实验的ID。[[1,1],[2,1],[3,1],#....]相反,这会返回实验的id,然后返回nil[[1,nil],[1,nil],[1,nil],#....]这在三个方面很奇怪:即使它是一个内部联接并且只返回一个实验,我也能够从功能(features.name)中

ruby - 使用#inject 连接数组中的字符串

我正在浏览anonlinelesson,通常有一个非常简单的单行解决方案。一个问题指出,给定以下数组:["emperor","joshua","abraham","norton"]我必须使用#inject获取所有名称的单个字符串,并用一个字符串连接在一起,每个名称的首字母都有上限,如下所示:"EmperorJoshuaAbrahamNorton"虽然这可以通过#map轻松完成和#join,此特定练习仅需要使用#inject。我想到了这样的事情:["emperor","joshua","abraham","norton"].inject("")do|memo,word|memo这会给我:

ruby-on-rails - Rails 应用程序连接池大小,避免最大池大小问题

我正在运行JRubyonRails应用程序。我在日志中随机看到很多这样的内容:最大池大小当前为5;考虑增加它我知道我可以在我的配置中增加最大池大小来解决这个问题。我要解决的问题是了解最佳数量应该是多少。我试图避免连接争用问题。显然,将此数字设置得过大也不会奏效。是否有可遵循的通用协议(protocol)来了解您的应用的最佳池大小设置? 最佳答案 来自here,Theoptimumsizeofathreadpooldependsonthenumberofprocessorsavailableandthenatureofthetasks

ruby-on-rails - 通过本地网络将 Ruby/Rails 连接到 ipad

主机ip:192.168.1.2ipadip:192.168.1.3在我的主机上工作时,网址是:localhost.dev:3000/sign_in/当我尝试通过192.168.1.2.dev:3000/sign_in连接到我的ipad时,连接超时。解决我的问题的一种方法是将ipad上的wifi设置更改为手动代理:服务器:192.168.1.2端口:3000现在192.168.1.2.dev工作了!有点……我现在可以登录到我的站点,但是js似乎已损坏并且ipad将url更改为:(http://2.dev/page)通常它会是(http://localhost.dev:3000/page