forked from dszymczuk/MySQL-Dump-with-Foreign-keys
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathFKMySQLDump.php
114 lines (100 loc) · 4.2 KB
/
FKMySQLDump.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
<?php
/**
* Dump MySQL databes with Foreign Keys
*
* FKMySQLDump extends only doDump method to create dump all database with Foreign Keys.
*
* FKMySQLDump class extends MySQL class written by Daniele Viganň
* @link http://www.phpclasses.org/package/3498-PHP-Dump-a-MySQL-database-in-a-backup-file.html
*
* @name FKMySQLDump
* @author Damian Szymczuk - [email protected]
* Daniel Marschall - www.daniel-marschall.de (continued work in 2022)
* @link https://github.com/danielmarschall/MySQL-Dump-with-Foreign-keys
* @version 3.00 - 5 November 2022
* @license http://opensource.org/licenses/gpl-license.php GNU Public License
*/
require_once __DIR__.'/MySQLDump.php';
class FKMySQLDump extends MySQLDump{
/**
* Database name
* @var string
*/
private $_dbname;
/**
* Array of FK names
* @var array
*/
private $_fk_names = array();
/**
* Class constructor
* @param string $db The database name
* @param string $filepath The file where the dump will be written
* @param boolean $compress It defines if the output file is compress (gzip) or not
* @param boolean $hexValue It defines if the output values are base-16 or not
*/
function __construct($db = null, $filepath = 'dump.sql', $compress = false, $hexValue = false){
parent::__construct($db,$filepath,$compress,$hexValue);
$this->_dbname = $db;
parent::getOutputFile();
}
/**
* Writes to file the selected database dump
*
* @return bool
*/
public function doFKDump($params = array()) {
parent::doDumpWithoutClosing($params);
$this->getForeignKeys();
$sql_file = "-- ------------\n";
$sql_file .= "-- FOREIGN KEYS\n";
$sql_file .= "-- ------------\n";
$sql_file .= "SET FOREIGN_KEY_CHECKS = 0;\n\n";
$sql_file .= $this->getForeignKeysRules();
$sql_file .= "SET FOREIGN_KEY_CHECKS = 1;\n\n";
$this->saveToFile($this->file, $sql_file);
$this->closeFile($this->file);
return true;
}
/**
* Gets Foreign Keys names to array
*
* Select CONSTRAINT_NAME from Information Schema
*
* @return void
*/
public function getForeignKeys() {
$sql = "select * from information_schema.TABLE_CONSTRAINTS
where CONSTRAINT_TYPE = 'foreign key'
and CONSTRAINT_SCHEMA ='{$this->_dbname}'";
$result = mysql_query($sql);
while($row = mysql_fetch_assoc($result)) {
array_push($this->_fk_names, $row['CONSTRAINT_NAME']);
}
}
/**
* Return SQL command with foreign keys as string
*
* Function select some columns from Information Schema and write informations about foreign keys to string.
*
* @return string
*/
public function getForeignKeysRules(){
$FK_to_sql_file = "";
foreach($this->_fk_names as $fk_name){
$sql = "select KEY_COLUMN_USAGE.TABLE_NAME, KEY_COLUMN_USAGE.CONSTRAINT_NAME, COLUMN_NAME,
REFERENCED_COLUMN_NAME, KEY_COLUMN_USAGE.REFERENCED_TABLE_NAME, UPDATE_RULE, DELETE_RULE
from information_schema.KEY_COLUMN_USAGE, information_schema.REFERENTIAL_CONSTRAINTS
where KEY_COLUMN_USAGE.CONSTRAINT_SCHEMA = '{$this->_dbname}'
and KEY_COLUMN_USAGE.CONSTRAINT_NAME = '{$fk_name}'
and KEY_COLUMN_USAGE.CONSTRAINT_NAME = REFERENTIAL_CONSTRAINTS.CONSTRAINT_NAME
and KEY_COLUMN_USAGE.CONSTRAINT_SCHEMA = REFERENTIAL_CONSTRAINTS.CONSTRAINT_SCHEMA";
$result = mysql_query($sql);
while($row = mysql_fetch_assoc($result)){
$FK_to_sql_file .= "ALTER TABLE `".$row['TABLE_NAME']."` ADD CONSTRAINT `".$row['CONSTRAINT_NAME']."` FOREIGN KEY (`".$row['COLUMN_NAME']."`) REFERENCES `".$row['REFERENCED_TABLE_NAME']."` (`".$row['REFERENCED_COLUMN_NAME']."`) ON DELETE {$row['DELETE_RULE']} ON UPDATE {$row['UPDATE_RULE']};";
$FK_to_sql_file .= "\r\n\r\n";
}
}
return $FK_to_sql_file;
}
}