我通过我的终端"Terminator“和Shell”Fish shell“在Ubuntu 14.04上使用带有Ruby2.1的Rails 4.0.4和Thin 1.6.2。
当我在开发模式下启动Rails服务器时,我的日志中没有SQL查询,只有JS和HTML文件被加载。
我在搜索类似这样的东西:
User Load (3.0ms) SELECT "users".* FROM "users" WHERE "users"."id" = 3 ORDER BY "users"."id" ASC LIMIT 1
(2.0ms) SELECT COUNT(*) FROM "users" WHERE (driver_register_state_cd = -2)发布于 2014-05-01 06:52:56
rails控制台从不写入日志文件,但是您可以很容易地实现这一点,例如,如果您在启动rails控制台后执行以下命令
ActiveRecord::Base.logger = Logger.new STDOUTrails会将所有SQL语句记录到stdout中,从而在终端中显示它们。由于Logger.new接受任何流作为第一个参数,您可以让它写入rails development.log:
ActiveRecord::Base.logger = Logger.new File.open('log/development.log', 'a')发布于 2015-10-03 20:01:13
将config/environments/development.rb中的config.log_level设置为:debug并重启本地服务器、控制台:
config.log_level = :debug发布于 2015-08-20 01:36:03
通过创建一个初始化器文件,我得到了我想要的:
# initializers/sql_logging.rb
ActiveRecord::Base.logger = ActiveSupport::Logger.new(STDOUT)这似乎也避免了日志记录预先加上难看的时间戳。
https://stackoverflow.com/questions/23397341
复制相似问题