jjzjj

Connection

全部标签

ruby-on-rails - 弃用警告 : Dangerous query method (method whose arguments are used as raw SQL) called with non-attribute argument(s)

我将我的Rails5.1.4应用更新到了5.2.0。我的一个模型中有以下范围:scope:by_category,lambda{|category_slug|category_ids=Category.find_by(slug:category_slug)&.subtree_idswhere(category_id:category_ids)}由于该范围,Rails返回以下错误:DEPRECATIONWARNING:Dangerousquerymethod(methodwhoseargumentsareusedasrawSQL)calledwithnon-attributeargume

ruby-on-rails - 安装 gitlab-5.0 时遇到问题 - rake 中止

安装gitlab-5.0时遇到问题https://github.com/gitlabhq/gitlabhq/blob/5-0-stable/doc/install/installation.md#initialise-database-and-activate-advanced-featuresroot@ubuntu:/home/gitlab/gitlab#bundleexecrakegitlab:setupRAILS_ENV=productionrakeaborted!Accessdeniedforuser'root'@'localhost'(usingpassword:YES)/h

ruby-on-rails - Rspec:如何测试 ActiveRecord::Base.connection.execute

我正在使用原始/裸机sql插入来提高我服务的写入性能。我的模块中有这样的东西-insert="('#{id}','#{status}','#{some_time_val}')"sql_string="INSERTINTOhistory('device_id','status','time')VALUES#{insert}"ActiveRecord::Base.connection.executesql_string当我编写如下所示的rspec时,它会测试除插入是否通过之外的所有内容。因此,由于rspec、database_cleaner等执行回滚和事务的方式,我的期望永远不会奏效。我尝

ruby-on-rails - 如何在 Rails 中捕获 ActiveRecord::Base.connection.execute 的错误?

我想按如下方式运行原始SQL查询:ActiveRecord::Base.connection.execute(some_query);我能否捕获执行查询时发生的任何错误?如果是,如何?execute会返回什么吗?文档中没有说明。干杯 最佳答案 您可以像往常一样修复错误。例如:beginActiveRecord::Base.connection.execute(some_query)rescue#dostuffwithexceptionend看看MySql(forexample)adapter'scode看看发生了什么。在这种情况下,

ruby - ActiveRecord 3.1.0 多数据库

我正在尝试将ActiveRecordgem升级到最新的3.1.0版本并看到出现了很多异常,我认为这是由于我们处理多个数据库的方式所致。对于我们的每个数据库,我们指定一个单独的基类,它继承自ActiveRecord::Base,并在其中调用establish_connection。没有跨数据库关系。到目前为止,这对我们来说效果很好。升级到ActiveRecord3.1.0后,我看到它在遍历关系时失败并出现ActiveRecord::ConnectionNotEstablished异常(即,它将成功地从数据库,但在导航到相关类时失败)。回溯的第一行是C:/Ruby/lib/ruby/gem

ruby-on-rails - 我如何从 Ruby 代码连接到 mongodb?

我如何从Ruby代码连接到mongodb? 最佳答案 首先,您必须安装MongoDbgem:geminstallmongo然后运行代码:require'rubygems'#notnecessaryforRuby1.9require'mongo'db=Mongo::Connection.new.db("mydb")#ORdb=Mongo::Connection.new("localhost").db("mydb")#ORdb=Mongo::Connection.new("localhost",27017).db("mydb")

ruby - 为什么是 ActiveRecord::Base.connected?为 false,在调用 establish_connection 之后

我开发了Sinatra应用程序并在那里使用ActiveRecord来处理数据库,但我遇到了一个问题。我为一个模型写了一个测试,它打破了SQLite3::CantOpenException:unabletoopendatabasefile使用以下代码在test_helper.rb中建立与数据库的连接:Dir.chdir('..')doActiveRecord::Base.establish_connection(db_config)end和ActiveRecord::Base.connected?为假。例如,如果我在连接建立后调用User.find(:all),测试将通过并且Active

ruby-on-rails - 有必要把Unicorn放在Nginx(或Apache)后面吗

我对这个架构有点困惑。在我正在进行的一个项目中,Unicorn被选为Rails服务器。它放在Nginx网络服务器后面。据我了解,Unicorn是功能齐全的Web服务器,我们不打算在同一服务器实例上托管任何其他Rails应用程序。所以我的问题是:在链中添加附加层有什么好处:client->nginx->unicorn->unicornworker 最佳答案 Unicorn不是为处理“慢客户端”而设计的。您可以在PHILOSOPHY中阅读更多相关信息帮助文件:Mostbenchmarkswe’veseendon’ttellyouthis

ruby 和 accdb(MS Access )

如果我有一个基本的windowsxp系统、ruby和一个msaccess2007文件(例如c:/foo/bar.accdb)文件,读取该.accdb文件的侵入性最小的方法是什么。xp系统需要安装什么。具体的连接字符串是什么。 最佳答案 按照这些思路应该可以帮助您入门。当然,您需要修改一些值,例如;路径、文件名、SQL语句等使用Jet引擎的MDB文件(Access2003格式和更早版本)require'win32ole'connection=WIN32OLE.new('ADODB.Connection')connection.Open

ruby-on-rails - RSpec 在测试数据库中留下记录

每当我运行用户测试时,RSpec都会在测试完成后将Fabricated用户留在测试数据库中,这会扰乱我的其他测试。我将执行rakedb:test:prepare,但是当我再次运行测试时,会在我的数据库中重新创建记录。我不知道为什么会这样。它只发生在用户对象上。在我的spec_helper文件中我什至有:config.use_transactional_fixtures=true这是一个创建记录的示例测试:it"createsapasswordresettokenfortheuser"doalice=Fabricate(:user)post:create,email:alice.emai