草庐IT

php - jquery ajax 传递 sql 查询

全部标签

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 - 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 - 微软 SQL ruby gem

我需要编写一个ruby​​脚本来连接到MSSQLServer数据库,但我发现的所有线程都指向gems以将ActiveRecord绑定(bind)到MSSQL。是否有任何gems可以让我像pg那样做这个(对于postgreshttps://github.com/ged/ruby-pg)?我只需要做一些非常简单的远程查询,非常感谢! 最佳答案 最好的方法是使用tiny_tdsgemhttps://github.com/rails-sqlserver/tiny_tds 关于ruby-微软SQL

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)中

sql - Rails + PostgreSQL SSL 解密失败

我的生产服务器上运行了一个应用程序,它使用pggem与Postgres数据库通信。Postgres在默认端口上运行,并且位于防火墙后面-因此只能从localhost访问它。我还没有配置Postgres来做任何与SSL相关的事情。我正在通过SSL访问Rails应用程序,并且证书是为另一个域签名的,所以当您第一次点击它时,会出现证书错误……但这是唯一与SSL相关的奇怪之处。然而,我在我的Rails日志中间歇性地看到这个(当它发生时浏览器会出现500错误):StartedGET"/admin/pages"forat2012-02-0201:52:03-0500ProcessingbyPage

ruby - rake 将参数传递给相关任务

这是我目前运行rak相关任务的方式task:test=>[:prepare_testdir,:run_tests]目前这两个依赖任务没有参数。但是我需要向其中一项任务添加参数。它应该像在命令行上一样运行rakeprepare_testdir[mydir]我如何将这个新参数传递给这个task:test=>[:prepare_testdir,:run_tests]我试过了task:test=>[:prepare_testdir[mydir],:run_tests]和task:test=>[:prepare_testdir['mydir'],:run_tests]两者都不工作。提前致谢

ruby-on-rails - 呈现传递局部变量的模板时出现问题

我正在运行RubyonRails3,我想呈现一个传递局部变量的模板(show.html.erb)。在RAILS_ROOT/views/users/show.html.erb我有Name:Surname:我还有一个页面Controller来处理页面,在application_controller.rb中有一个@current_user的实例。一个页面叫做user,所以在RAILS_ROOT/views/pages/user.html.erb我有"users/show",:locals=>{:user=>@current_user}%>上面的代码不起作用(我得到这个错误:RuntimeEr

sql - SQL 查询的最大长度

SELECTf.*FROMfeedsf,user_feedsufWHERE(f.id=uf.feed_idanduf.user_idin(1,2,5,6,23,45))ORDERBYcreated_atDESC这是用于构建用户提要的查询。这个查询的问题是“uf.user_idin()”随着用户关注的用户数量的增加而增加。SQL查询允许的最大长度是多少?有没有更好的方法来实现上面的查询?注意:我正在使用ActiveRecord和Postgres。 最佳答案 PostgreSQL可以处理的查询的最大长度是2147483648个字符(带符

ruby-on-rails - 如何使用 Ruby 中哈希的查询参数构造 URI

如何通过传递哈希来构造带有查询参数的URI对象?我可以生成查询:URI::HTTPS.build(host:'example.com',query:"a=#{hash[:a]},b=#{[hash:b]}")产生https://example.com?a=argument1&b=argument2但是我认为为许多参数构造查询字符串将不可读且难以维护。我想通过传递哈希来构造查询字符串。就像下面的例子:hash={a:'argument1',b:'argument2'#...dozenmorearguments}URI::HTTPS.build(host:'example.com',que