从MySQL迁移到Postgres on Rails 3

mdr*_*iel 6 postgresql ruby-on-rails ruby-on-rails-3

除了删除一些特定于MySQL的查询之外,迁移非常顺利.现在的问题是,在开发期间,对DB的查询比以前多得多.

Started GET "/profiles/data" for 127.0.0.1 at Tue Sep 21 10:26:18 +0200 2010
 Processing by ProfilesController#data as JSON
 User Load (24.3ms)  SELECT "users".* FROM "users" ORDER BY updated_at DESC LIMIT 1
 CACHE (0.0ms)  SELECT "users".* FROM "users" ORDER BY updated_at DESC LIMIT 1
 SQL (10.5ms)   SELECT a.attname, format_type(a.atttypid, a.atttypmod), d.adsrc, a.attnotnull
 FROM pg_attribute a LEFT JOIN pg_attrdef d
 ON  a.attrelid = d.adrelid AND a.attnum = d.adnum
 WHERE a.attrelid = '"users"'::regclass
 AND a.attnum > 0 AND NOT a.attisdropped
 ORDER BY a.attnum
Run Code Online (Sandbox Code Playgroud)

每个查询都会产生3-8个额外的查询,如上所述.什么和为什么发生?现在的问题之一是,developement.log臃肿且难以理解.我浪费大量时间在那些查找正确的查询之间滚动...

更新:9月21日星期二

这与查询类型无关.所有查询都生成这种stuph:

ree-1.8.7-2010.02 > User.first
  SQL (0.3ms)  SHOW client_min_messages
  SQL (2.0ms)  SET client_min_messages TO 'panic'
  SQL (6.3ms)  SET standard_conforming_strings = on
  SQL (18.3ms)  SET client_min_messages TO 'notice'
  SQL (15.6ms)  SET time zone 'UTC'
  SQL (17.2ms)  SHOW TIME ZONE
  SQL (23.8ms)   SELECT tablename FROM pg_tables WHERE schemaname = ANY (current_schemas(false)) 
  User Load (162.4ms)  SELECT "users".* FROM "users" LIMIT 1
  SQL (7.5ms)   SELECT a.attname, format_type(a.atttypid, a.atttypmod), d.adsrc,
    a.attnotnull FROM pg_attribute a LEFT JOIN pg_attrdef d ON a.attrelid = d.adrelid
    AND a.attnum = d.adnum WHERE a.attrelid = '"users"'::regclass AND a.attnum > 0 AND
    NOT a.attisdropped ORDER BY a.attnum 
Run Code Online (Sandbox Code Playgroud)

[...] set ree-1.8.7-2010.02中的1行>

bal*_*ark 4

我从另一篇文章中窃取了这个:您可能想看看http://github.com/dolzenko/silent-postgres该插件会删除这些查询。这些日志噪音是由于 postgresql 日志级别较高而发生的。