Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
44de0385
Commit
44de0385
authored
Jul 27, 2021
by
Simon Tomlinson
Committed by
Robert May
Jul 27, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add a database view for postgres foreign keys
parent
8b7df8d3
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
95 additions
and
0 deletions
+95
-0
db/migrate/20210719145532_add_foreign_keys_view.rb
db/migrate/20210719145532_add_foreign_keys_view.rb
+26
-0
db/schema_migrations/20210719145532
db/schema_migrations/20210719145532
+1
-0
db/structure.sql
db/structure.sql
+12
-0
lib/gitlab/database/postgres_foreign_key.rb
lib/gitlab/database/postgres_foreign_key.rb
+15
-0
spec/lib/gitlab/database/postgres_foreign_key_spec.rb
spec/lib/gitlab/database/postgres_foreign_key_spec.rb
+41
-0
No files found.
db/migrate/20210719145532_add_foreign_keys_view.rb
0 → 100644
View file @
44de0385
# frozen_string_literal: true
class
AddForeignKeysView
<
ActiveRecord
::
Migration
[
6.1
]
def
up
execute
(
<<~
SQL
)
CREATE OR REPLACE VIEW postgres_foreign_keys AS
SELECT
pg_constraint.oid AS oid,
pg_constraint.conname AS name,
constrained_namespace.nspname::text || '.'::text || constrained_table.relname::text AS constrained_table_identifier,
referenced_namespace.nspname::text || '.'::text || referenced_table.relname::text AS referenced_table_identifier
FROM pg_constraint
INNER JOIN pg_class constrained_table ON constrained_table.oid = pg_constraint.conrelid
INNER JOIN pg_class referenced_table ON referenced_table.oid = pg_constraint.confrelid
INNER JOIN pg_namespace constrained_namespace ON constrained_table.relnamespace = constrained_namespace.oid
INNER JOIN pg_namespace referenced_namespace ON referenced_table.relnamespace = referenced_namespace.oid
WHERE contype = 'f';
SQL
end
def
down
execute
(
<<~
SQL
)
DROP VIEW IF EXISTS postgres_foreign_keys
SQL
end
end
db/schema_migrations/20210719145532
0 → 100644
View file @
44de0385
5e088e5109b50d8f4fadd37a0382d7dc4ce856a851ec2b97f8d5d868c3cb19fd
\ No newline at end of file
db/structure.sql
View file @
44de0385
...
@@ -16519,6 +16519,18 @@ CREATE SEQUENCE pool_repositories_id_seq
...
@@ -16519,6 +16519,18 @@ CREATE SEQUENCE pool_repositories_id_seq
ALTER SEQUENCE pool_repositories_id_seq OWNED BY pool_repositories.id;
ALTER SEQUENCE pool_repositories_id_seq OWNED BY pool_repositories.id;
CREATE VIEW postgres_foreign_keys AS
SELECT pg_constraint.oid,
pg_constraint.conname AS name,
(((constrained_namespace.nspname)::text || '.'::text) || (constrained_table.relname)::text) AS constrained_table_identifier,
(((referenced_namespace.nspname)::text || '.'::text) || (referenced_table.relname)::text) AS referenced_table_identifier
FROM ((((pg_constraint
JOIN pg_class constrained_table ON ((constrained_table.oid = pg_constraint.conrelid)))
JOIN pg_class referenced_table ON ((referenced_table.oid = pg_constraint.confrelid)))
JOIN pg_namespace constrained_namespace ON ((constrained_table.relnamespace = constrained_namespace.oid)))
JOIN pg_namespace referenced_namespace ON ((referenced_table.relnamespace = referenced_namespace.oid)))
WHERE (pg_constraint.contype = 'f'::"char");
CREATE VIEW postgres_index_bloat_estimates AS
CREATE VIEW postgres_index_bloat_estimates AS
SELECT (((relation_stats.nspname)::text || '.'::text) || (relation_stats.idxname)::text) AS identifier,
SELECT (((relation_stats.nspname)::text || '.'::text) || (relation_stats.idxname)::text) AS identifier,
(
(
lib/gitlab/database/postgres_foreign_key.rb
0 → 100644
View file @
44de0385
# frozen_string_literal: true
module
Gitlab
module
Database
class
PostgresForeignKey
<
ApplicationRecord
self
.
primary_key
=
:oid
scope
:by_referenced_table_identifier
,
->
(
identifier
)
do
raise
ArgumentError
,
"Referenced table name is not fully qualified with a schema:
#{
identifier
}
"
unless
identifier
=~
/^\w+\.\w+$/
where
(
referenced_table_identifier:
identifier
)
end
end
end
end
spec/lib/gitlab/database/postgres_foreign_key_spec.rb
0 → 100644
View file @
44de0385
# frozen_string_literal: true
require
'spec_helper'
RSpec
.
describe
Gitlab
::
Database
::
PostgresForeignKey
,
type: :model
do
# PostgresForeignKey does not `behaves_like 'a postgres model'` because it does not correspond 1-1 with a single entry
# in pg_class
before
do
ActiveRecord
::
Base
.
connection
.
execute
(
<<~
SQL
)
CREATE TABLE public.referenced_table (
id bigserial primary key not null
);
CREATE TABLE public.other_referenced_table (
id bigserial primary key not null
);
CREATE TABLE public.constrained_table (
id bigserial primary key not null,
referenced_table_id bigint not null,
other_referenced_table_id bigint not null,
CONSTRAINT fk_constrained_to_referenced FOREIGN KEY(referenced_table_id) REFERENCES referenced_table(id),
CONSTRAINT fk_constrained_to_other_referenced FOREIGN KEY(other_referenced_table_id)
REFERENCES other_referenced_table(id)
);
SQL
end
describe
'#by_referenced_table_identifier'
do
it
'throws an error when the identifier name is not fully qualified'
do
expect
{
described_class
.
by_referenced_table_identifier
(
'referenced_table'
)
}.
to
raise_error
(
ArgumentError
,
/not fully qualified/
)
end
it
'finds the foreign keys for the referenced table'
do
expected
=
described_class
.
find_by!
(
name:
'fk_constrained_to_referenced'
)
expect
(
described_class
.
by_referenced_table_identifier
(
'public.referenced_table'
)).
to
contain_exactly
(
expected
)
end
end
end
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment