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
bd467c82
Commit
bd467c82
authored
Aug 06, 2021
by
Dylan Griffith
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Minor docs improvements for multiple_databass.md
Suggestions from tech writer.
parent
a0a39f65
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
13 additions
and
14 deletions
+13
-14
doc/development/database/multiple_databases.md
doc/development/database/multiple_databases.md
+13
-14
No files found.
doc/development/database/multiple_databases.md
View file @
bd467c82
...
@@ -113,7 +113,7 @@ patterns may apply to future cases.
...
@@ -113,7 +113,7 @@ patterns may apply to future cases.
The simplest solution we've seen several times now has been an existing scope
The simplest solution we've seen several times now has been an existing scope
that is unused. This is the easiest example to fix. So the first step is to
that is unused. This is the easiest example to fix. So the first step is to
investigate if the code is unused and then
simply
remove it. These are some
investigate if the code is unused and then remove it. These are some
real examples:
real examples:
-
<https://gitlab.com/gitlab-org/gitlab/-/merge_requests/67162>
-
<https://gitlab.com/gitlab-org/gitlab/-/merge_requests/67162>
...
@@ -135,12 +135,12 @@ find that nobody is using these metrics, so we can remove them.
...
@@ -135,12 +135,12 @@ find that nobody is using these metrics, so we can remove them.
The
`includes`
and
`preload`
methods in Rails are both ways to avoid an N+1
The
`includes`
and
`preload`
methods in Rails are both ways to avoid an N+1
query. The
`includes`
method in Rails uses a heuristic approach to determine
query. The
`includes`
method in Rails uses a heuristic approach to determine
whether or not it needs to actually join to the table or whether it can load
if it needs to join to the table, or if it can load all of the
all the records in a separate query. It
assumes it needs to join if it thinks
records in a separate query. This method
assumes it needs to join if it thinks
you need to query the columns from the other table
in some way
, but sometimes
you need to query the columns from the other table, but sometimes
this method gets it wrong and
it executes a join even when it isn'
t needed. In
this method gets it wrong and
executes a join even when no
t needed. In
this case using
`preload`
to explicitly load the data in a separate query
will
this case using
`preload`
to explicitly load the data in a separate query
allow
you to avoid the join
while still avoiding the N+1 query.
allow
s you to avoid the join,
while still avoiding the N+1 query.
You can see a real example of this solution being used in
You can see a real example of this solution being used in
<https://gitlab.com/gitlab-org/gitlab/-/merge_requests/67655>
.
<https://gitlab.com/gitlab-org/gitlab/-/merge_requests/67655>
.
...
@@ -260,13 +260,12 @@ A quick checklist for fixing a specific join query would be:
...
@@ -260,13 +260,12 @@ A quick checklist for fixing a specific join query would be:
#### How to validate you have correctly removed a cross-join
#### How to validate you have correctly removed a cross-join
We have introduced a method you can use in RSpec tests to validate all SQL
Using RSpec tests, you can validate all SQL queries within a code block to
queries within a code block to ensure that none of them are joining across the
ensure that none of them are joining across the two databases. This is a useful
2 databases. This is a useful tool to confirm you have correctly fixed an
tool to confirm you have correctly fixed an existing cross-join.
existing cross-join.
At some point in the future we will have fixed all cross-joins and this tool
At some point in the future we will have fixed all cross-joins and this tool
will run by default in all tests
but for now it
needs to be explicitly enabled
will run by default in all tests
. For now, the tool
needs to be explicitly enabled
for your test.
for your test.
You can use this method like so:
You can use this method like so:
...
@@ -279,8 +278,8 @@ it 'does not join across databases' do
...
@@ -279,8 +278,8 @@ it 'does not join across databases' do
end
end
```
```
This will raise an exception if the query joins across the
2
databases. The
This will raise an exception if the query joins across the
two
databases. The
above example is fixed by removing the join
like so:
previous example is fixed by removing the join,
like so:
```
ruby
```
ruby
it
'does not join across databases'
do
it
'does not join across databases'
do
...
...
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