Commit 3f590fd
Replace slow UNION ALL query with optimized all_objects query in describe
Replace the 4-way UNION ALL query across all_tables, all_views, and
all_synonyms with a single all_objects query for the common TABLE/VIEW
path. Synonym targets are resolved via a second all_synonyms query only
when needed.
- Add ORDER BY to preserve lookup priority (table, view, owner synonym,
public synonym)
- Add regression test covering table, view, private synonym and public
synonym resolution for the same underlying table
- Grant CREATE/DROP PUBLIC SYNONYM to test users
Refs #2429
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>1 parent f3440f8 commit 3f590fd
3 files changed
Lines changed: 38 additions & 23 deletions
File tree
- lib/active_record/connection_adapters/oracle_enhanced
- spec
- active_record/connection_adapters/oracle_enhanced
- support
Lines changed: 17 additions & 21 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
34 | 34 | | |
35 | 35 | | |
36 | 36 | | |
37 | | - | |
38 | | - | |
39 | | - | |
40 | | - | |
41 | | - | |
42 | | - | |
43 | | - | |
44 | | - | |
45 | | - | |
46 | | - | |
47 | | - | |
48 | | - | |
49 | | - | |
50 | | - | |
51 | | - | |
52 | | - | |
53 | | - | |
54 | | - | |
55 | | - | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
56 | 44 | | |
57 | | - | |
| 45 | + | |
58 | 46 | | |
59 | 47 | | |
60 | | - | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
61 | 57 | | |
62 | 58 | | |
63 | 59 | | |
| |||
Lines changed: 17 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
577 | 577 | | |
578 | 578 | | |
579 | 579 | | |
| 580 | + | |
| 581 | + | |
| 582 | + | |
| 583 | + | |
| 584 | + | |
| 585 | + | |
| 586 | + | |
| 587 | + | |
| 588 | + | |
| 589 | + | |
| 590 | + | |
| 591 | + | |
| 592 | + | |
| 593 | + | |
| 594 | + | |
| 595 | + | |
| 596 | + | |
580 | 597 | | |
581 | 598 | | |
582 | 599 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
4 | 4 | | |
5 | 5 | | |
6 | 6 | | |
7 | | - | |
| 7 | + | |
| 8 | + | |
8 | 9 | | |
9 | 10 | | |
10 | 11 | | |
11 | 12 | | |
12 | 13 | | |
13 | | - | |
| 14 | + | |
| 15 | + | |
0 commit comments