1
|
|
|
<?php |
2
|
|
|
|
3
|
|
|
/** Link system tables (in mysql and information_schema databases) by foreign keys |
4
|
|
|
* @link https://www.adminer.org/plugins/#use |
5
|
|
|
* @author Jakub Vrana, http://www.vrana.cz/ |
6
|
|
|
* @license http://www.apache.org/licenses/LICENSE-2.0 Apache License, Version 2.0 |
7
|
|
|
* @license http://www.gnu.org/licenses/gpl-2.0.html GNU General Public License, version 2 (one or other) |
8
|
|
|
*/ |
9
|
|
|
class AdminerForeignSystem { |
10
|
|
|
|
11
|
|
|
function foreignKeys($table) { |
|
|
|
|
12
|
|
|
if (DRIVER == 'server' && DB == 'mysql') { |
13
|
|
|
switch ($table) { |
14
|
|
View Code Duplication |
case 'columns_priv': return array(array('table' => 'user', 'source' => array('Host', 'User'), 'target' => array('Host', 'User'))); |
|
|
|
|
15
|
|
View Code Duplication |
case 'db': return array(array('table' => 'user', 'source' => array('Host', 'User'), 'target' => array('Host', 'User'))); |
|
|
|
|
16
|
|
View Code Duplication |
case 'help_category': return array(array('table' => 'help_category', 'source' => array('parent_category_id'), 'target' => array('help_category_id'))); |
|
|
|
|
17
|
|
|
case 'help_relation': return array(array('table' => 'help_topic', 'source' => array('help_topic_id'), 'target' => array('help_topic_id')), array('table' => 'help_keyword', 'source' => array('help_keyword_id'), 'target' => array('help_keyword_id'))); |
18
|
|
View Code Duplication |
case 'help_topic': return array(array('table' => 'help_category', 'source' => array('help_category_id'), 'target' => array('help_category_id'))); |
|
|
|
|
19
|
|
View Code Duplication |
case 'procs_priv': return array(array('table' => 'user', 'source' => array('Host', 'User'), 'target' => array('Host', 'User')), array('table' => 'proc', 'source' => array('Db', 'Routine_name'), 'target' => array('db', 'name'))); |
|
|
|
|
20
|
|
View Code Duplication |
case 'tables_priv': return array(array('table' => 'user', 'source' => array('Host', 'User'), 'target' => array('Host', 'User'))); |
|
|
|
|
21
|
|
View Code Duplication |
case 'time_zone_name': return array(array('table' => 'time_zone', 'source' => array('Time_zone_id'), 'target' => array('Time_zone_id'))); |
|
|
|
|
22
|
|
View Code Duplication |
case 'time_zone_transition': return array(array('table' => 'time_zone', 'source' => array('Time_zone_id'), 'target' => array('Time_zone_id')), array( |
|
|
|
|
23
|
|
|
'table' => 'time_zone_transition_type', 'source' => array('Time_zone_id', 'Transition_type_id'), 'target' => array( |
24
|
|
|
'Time_zone_id', |
25
|
|
|
'Transition_type_id' |
26
|
|
|
))); |
27
|
|
View Code Duplication |
case 'time_zone_transition_type': return array(array('table' => 'time_zone', 'source' => array('Time_zone_id'), 'target' => array('Time_zone_id'))); |
|
|
|
|
28
|
|
|
} |
29
|
|
|
} elseif (DB == 'information_schema') { |
30
|
|
|
$schemata = array('table' => 'SCHEMATA', 'source' => array('TABLE_CATALOG', 'TABLE_SCHEMA'), 'target' => array('CATALOG_NAME', 'SCHEMA_NAME')); |
31
|
|
|
$tables = array('table' => 'TABLES', 'source' => array('TABLE_CATALOG', 'TABLE_SCHEMA', 'TABLE_NAME'), 'target' => array('TABLE_CATALOG', 'TABLE_SCHEMA', 'TABLE_NAME')); |
32
|
|
|
$columns = array('table' => 'COLUMNS', 'source' => array('TABLE_CATALOG', 'TABLE_SCHEMA', 'TABLE_NAME', 'COLUMN_NAME'), 'target' => array('TABLE_CATALOG', 'TABLE_SCHEMA', 'TABLE_NAME', 'COLUMN_NAME')); |
33
|
|
|
$character_sets = array('table' => 'CHARACTER_SETS', 'source' => array('CHARACTER_SET_NAME'), 'target' => array('CHARACTER_SET_NAME')); |
34
|
|
|
$collations = array('table' => 'COLLATIONS', 'source' => array('COLLATION_NAME'), 'target' => array('COLLATION_NAME')); |
35
|
|
|
$routine_charsets = array(array('source' => array('CHARACTER_SET_CLIENT')) + $character_sets, array('source' => array('COLLATION_CONNECTION')) + $collations, array('source' => array('DATABASE_COLLATION')) + $collations); |
36
|
|
|
switch ($table) { |
37
|
|
|
case 'CHARACTER_SETS': return array(array('source' => array('DEFAULT_COLLATE_NAME')) + $collations); |
38
|
|
|
case 'COLLATIONS': return array($character_sets); |
39
|
|
|
case 'COLLATION_CHARACTER_SET_APPLICABILITY': return array($collations, $character_sets); |
40
|
|
|
case 'COLUMNS': return array($schemata, $tables, $character_sets, $collations); |
41
|
|
|
case 'COLUMN_PRIVILEGES': return array($schemata, $tables, $columns); |
42
|
|
|
case 'TABLES': return array($schemata, array('source' => array('TABLE_COLLATION')) + $collations); |
43
|
|
|
case 'SCHEMATA': return array(array('source' => array('DEFAULT_CHARACTER_SET_NAME')) + $character_sets, array('source' => array('DEFAULT_COLLATION_NAME')) + $collations); |
44
|
|
|
case 'EVENTS': return array_merge(array(array('source' => array('EVENT_CATALOG', 'EVENT_SCHEMA')) + $schemata), $routine_charsets); |
45
|
|
|
case 'FILES': return array($schemata, $tables); |
46
|
|
|
case 'KEY_COLUMN_USAGE': return array(array('source' => array('CONSTRAINT_CATALOG', 'CONSTRAINT_SCHEMA')) + $schemata, $schemata, $tables, $columns, array('source' => array('TABLE_CATALOG', 'REFERENCED_TABLE_SCHEMA')) + $schemata, array( |
47
|
|
|
'source' => array( |
48
|
|
|
'TABLE_CATALOG', |
49
|
|
|
'REFERENCED_TABLE_SCHEMA', |
50
|
|
|
'REFERENCED_TABLE_NAME' |
51
|
|
|
)) + $tables, array( |
52
|
|
|
'source' => array( |
53
|
|
|
'TABLE_CATALOG', |
54
|
|
|
'REFERENCED_TABLE_SCHEMA', |
55
|
|
|
'REFERENCED_TABLE_NAME', |
56
|
|
|
'REFERENCED_COLUMN_NAME' |
57
|
|
|
)) + $columns); |
58
|
|
|
case 'PARTITIONS': return array($schemata, $tables); |
59
|
|
|
case 'REFERENTIAL_CONSTRAINTS': return array(array('source' => array('CONSTRAINT_CATALOG', 'CONSTRAINT_SCHEMA')) + $schemata, array('source' => array('UNIQUE_CONSTRAINT_CATALOG', 'UNIQUE_CONSTRAINT_SCHEMA')) + $schemata, array( |
60
|
|
|
'source' => array( |
61
|
|
|
'CONSTRAINT_CATALOG', |
62
|
|
|
'CONSTRAINT_SCHEMA', |
63
|
|
|
'TABLE_NAME' |
64
|
|
|
)) + $tables, array( |
65
|
|
|
'source' => array( |
66
|
|
|
'CONSTRAINT_CATALOG', |
67
|
|
|
'CONSTRAINT_SCHEMA', |
68
|
|
|
'REFERENCED_TABLE_NAME' |
69
|
|
|
)) + $tables); |
70
|
|
|
case 'ROUTINES': return array_merge(array(array('source' => array('ROUTINE_CATALOG', 'ROUTINE_SCHEMA')) + $schemata), $routine_charsets); |
71
|
|
|
case 'SCHEMA_PRIVILEGES': return array($schemata); |
72
|
|
|
case 'STATISTICS': return array($schemata, $tables, $columns, array('source' => array('TABLE_CATALOG', 'INDEX_SCHEMA')) + $schemata); |
73
|
|
|
case 'TABLE_CONSTRAINTS': return array(array('source' => array('CONSTRAINT_CATALOG', 'CONSTRAINT_SCHEMA')) + $schemata, array('source' => array('CONSTRAINT_CATALOG', 'TABLE_SCHEMA')) + $schemata, array('source' => array('CONSTRAINT_CATALOG', 'TABLE_SCHEMA', 'TABLE_NAME')) + $tables); |
74
|
|
|
case 'TABLE_PRIVILEGES': return array($schemata, $tables); |
75
|
|
|
case 'TRIGGERS': return array_merge(array(array('source' => array('TRIGGER_CATALOG', 'TRIGGER_SCHEMA')) + $schemata, array('source' => array('EVENT_OBJECT_CATALOG', 'EVENT_OBJECT_SCHEMA')) + $schemata, array( |
76
|
|
|
'source' => array( |
77
|
|
|
'EVENT_OBJECT_CATALOG', |
78
|
|
|
'EVENT_OBJECT_SCHEMA', |
79
|
|
|
'EVENT_OBJECT_TABLE' |
80
|
|
|
)) + $tables), $routine_charsets); |
81
|
|
|
case 'VIEWS': return array($schemata); |
82
|
|
|
} |
83
|
|
|
} |
84
|
|
|
} |
85
|
|
|
|
86
|
|
|
} |
87
|
|
|
|
Adding explicit visibility (
private
,protected
, orpublic
) is generally recommend to communicate to other developers how, and from where this method is intended to be used.