aboutsummaryrefslogtreecommitdiffstats
path: root/Gemfile.lock
diff options
context:
space:
mode:
authorJordan Lewis <jordanthelewis@gmail.com>2017-02-08 17:46:54 -0500
committerJeremy Daer <jeremydaer@gmail.com>2017-02-09 14:26:25 -0700
commitd6529af2954a67bd57fda45286fa9cfd0ff6b5ac (patch)
treed4fe2cf3b028310a83d924574aa8c2a293d40ef0 /Gemfile.lock
parent2b4d145f31eb2edfbfc5b0c8c65efc07321d4378 (diff)
downloadrails-d6529af2954a67bd57fda45286fa9cfd0ff6b5ac.tar.gz
rails-d6529af2954a67bd57fda45286fa9cfd0ff6b5ac.tar.bz2
rails-d6529af2954a67bd57fda45286fa9cfd0ff6b5ac.zip
Simplify and speed up Postgres query for primary_keys
primary_keys(table) needs to query various metadata tables in Postgres to determine the primary key for the table. Previously, it did so using a complex common table expression against pg_constraint and pg_attribute. This patch simplifies the query by joining pg_index against pg_attribute instead of going through pg_constraint. This avoids an expensive unnest, window function query, and common table expression. EXPLAINing these queries in Postgres against a database with a single table with a composite primary key shows a 66% reduction in the plan and execute latencies. This is significant during application startup time, especially against very large schemas, where these queries would be even slower and more numerous. Closes #27949
Diffstat (limited to 'Gemfile.lock')
0 files changed, 0 insertions, 0 deletions