blob: 4a3dad4d16458245a9cf4aaf63c9052ef00a2f86 [file] [log] [blame]
Andrey Andreevc5536aa2012-11-01 17:33:58 +02001<?php
Derek Allard2067d1a2008-11-13 22:59:24 +00002/**
3 * CodeIgniter
4 *
Andrey Andreevfe9309d2015-01-09 17:48:58 +02005 * An open source application development framework for PHP
Derek Allard2067d1a2008-11-13 22:59:24 +00006 *
Andrey Andreevbdb96ca2014-10-28 00:13:31 +02007 * This content is released under the MIT License (MIT)
Andrey Andreev1ff49e02012-01-27 11:30:41 +02008 *
Master Yodada60e9b2016-12-31 08:46:18 -08009 * Copyright (c) 2014 - 2017, British Columbia Institute of Technology
Andrey Andreev1ff49e02012-01-27 11:30:41 +020010 *
Andrey Andreevbdb96ca2014-10-28 00:13:31 +020011 * Permission is hereby granted, free of charge, to any person obtaining a copy
12 * of this software and associated documentation files (the "Software"), to deal
13 * in the Software without restriction, including without limitation the rights
14 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
15 * copies of the Software, and to permit persons to whom the Software is
16 * furnished to do so, subject to the following conditions:
Derek Jonesf4a4bd82011-10-20 12:18:42 -050017 *
Andrey Andreevbdb96ca2014-10-28 00:13:31 +020018 * The above copyright notice and this permission notice shall be included in
19 * all copies or substantial portions of the Software.
20 *
21 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
22 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
23 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
24 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
25 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
26 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
27 * THE SOFTWARE.
28 *
29 * @package CodeIgniter
30 * @author EllisLab Dev Team
Andrey Andreev1924e872016-01-11 12:55:34 +020031 * @copyright Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/)
Master Yodada60e9b2016-12-31 08:46:18 -080032 * @copyright Copyright (c) 2014 - 2017, British Columbia Institute of Technology (http://bcit.ca/)
Andrey Andreevbdb96ca2014-10-28 00:13:31 +020033 * @license http://opensource.org/licenses/MIT MIT License
Andrey Andreevbd202c92016-01-11 12:50:18 +020034 * @link https://codeigniter.com
Andrey Andreevbdb96ca2014-10-28 00:13:31 +020035 * @since Version 1.3.0
Derek Allard2067d1a2008-11-13 22:59:24 +000036 * @filesource
37 */
Andrey Andreevc5536aa2012-11-01 17:33:58 +020038defined('BASEPATH') OR exit('No direct script access allowed');
Derek Allard2067d1a2008-11-13 22:59:24 +000039
Derek Allard2067d1a2008-11-13 22:59:24 +000040/**
41 * MySQLi Utility Class
42 *
Andrey Andreevbdb96ca2014-10-28 00:13:31 +020043 * @package CodeIgniter
44 * @subpackage Drivers
Derek Allard2067d1a2008-11-13 22:59:24 +000045 * @category Database
Derek Jonesf4a4bd82011-10-20 12:18:42 -050046 * @author EllisLab Dev Team
Andrey Andreevbd202c92016-01-11 12:50:18 +020047 * @link https://codeigniter.com/user_guide/database/
Derek Allard2067d1a2008-11-13 22:59:24 +000048 */
49class CI_DB_mysqli_utility extends CI_DB_utility {
Barry Mienydd671972010-10-04 16:33:58 +020050
Andrey Andreevc98e93a2012-11-02 02:04:59 +020051 /**
52 * List databases statement
53 *
54 * @var string
55 */
Andrey Andreevb457a402012-04-09 16:11:56 +030056 protected $_list_databases = 'SHOW DATABASES';
Derek Allard2067d1a2008-11-13 22:59:24 +000057
58 /**
Andrey Andreevc98e93a2012-11-02 02:04:59 +020059 * OPTIMIZE TABLE statement
Derek Allard2067d1a2008-11-13 22:59:24 +000060 *
Andrey Andreevc98e93a2012-11-02 02:04:59 +020061 * @var string
62 */
63 protected $_optimize_table = 'OPTIMIZE TABLE %s';
64
65 /**
66 * REPAIR TABLE statement
67 *
68 * @var string
69 */
70 protected $_repair_table = 'REPAIR TABLE %s';
71
72 // --------------------------------------------------------------------
73
74 /**
75 * Export
76 *
77 * @param array $params Preferences
Derek Allard2067d1a2008-11-13 22:59:24 +000078 * @return mixed
79 */
Andrey Andreevb457a402012-04-09 16:11:56 +030080 protected function _backup($params = array())
Derek Allard2067d1a2008-11-13 22:59:24 +000081 {
Andrey Andreev782de112012-06-12 03:04:50 +030082 if (count($params) === 0)
83 {
84 return FALSE;
85 }
86
87 // Extract the prefs for simplicity
88 extract($params);
89
90 // Build the output
91 $output = '';
Andrew Podner79494dd2012-12-19 14:15:41 -050092
Andrew Podner48512172012-12-20 07:56:19 -050093 // Do we need to include a statement to disable foreign key checks?
94 if ($foreign_key_checks === FALSE)
Andrew Podner79494dd2012-12-19 14:15:41 -050095 {
Andrey Andreev61c4d0a2012-12-20 16:29:29 +020096 $output .= 'SET foreign_key_checks = 0;'.$newline;
Andrew Podner79494dd2012-12-19 14:15:41 -050097 }
98
Andrey Andreev782de112012-06-12 03:04:50 +030099 foreach ( (array) $tables as $table)
100 {
101 // Is the table in the "ignore" list?
102 if (in_array($table, (array) $ignore, TRUE))
103 {
104 continue;
105 }
106
107 // Get the table schema
108 $query = $this->db->query('SHOW CREATE TABLE '.$this->db->escape_identifiers($this->db->database.'.'.$table));
109
110 // No result means the table name was invalid
111 if ($query === FALSE)
112 {
113 continue;
114 }
115
116 // Write out the table schema
117 $output .= '#'.$newline.'# TABLE STRUCTURE FOR: '.$table.$newline.'#'.$newline.$newline;
118
119 if ($add_drop === TRUE)
120 {
121 $output .= 'DROP TABLE IF EXISTS '.$this->db->protect_identifiers($table).';'.$newline.$newline;
122 }
123
124 $i = 0;
125 $result = $query->result_array();
126 foreach ($result[0] as $val)
127 {
128 if ($i++ % 2)
129 {
130 $output .= $val.';'.$newline.$newline;
131 }
132 }
133
134 // If inserts are not needed we're done...
135 if ($add_insert === FALSE)
136 {
137 continue;
138 }
139
140 // Grab all the data from the current table
141 $query = $this->db->query('SELECT * FROM '.$this->db->protect_identifiers($table));
142
143 if ($query->num_rows() === 0)
144 {
145 continue;
146 }
147
148 // Fetch the field names and determine if the field is an
149 // integer type. We use this info to decide whether to
150 // surround the data with quotes or not
151
152 $i = 0;
153 $field_str = '';
154 $is_int = array();
155 while ($field = $query->result_id->fetch_field())
156 {
157 // Most versions of MySQL store timestamp as a string
158 $is_int[$i] = in_array(strtolower($field->type),
159 array('tinyint', 'smallint', 'mediumint', 'int', 'bigint'), //, 'timestamp'),
160 TRUE);
161
162 // Create a string of field names
163 $field_str .= $this->db->escape_identifiers($field->name).', ';
164 $i++;
165 }
166
167 // Trim off the end comma
168 $field_str = preg_replace('/, $/' , '', $field_str);
169
170 // Build the insert string
171 foreach ($query->result_array() as $row)
172 {
173 $val_str = '';
174
175 $i = 0;
176 foreach ($row as $v)
177 {
178 // Is the value NULL?
179 if ($v === NULL)
180 {
181 $val_str .= 'NULL';
182 }
183 else
184 {
185 // Escape the data if it's not an integer
186 $val_str .= ($is_int[$i] === FALSE) ? $this->db->escape($v) : $v;
187 }
188
189 // Append a comma
190 $val_str .= ', ';
191 $i++;
192 }
193
194 // Remove the comma at the end of the string
195 $val_str = preg_replace('/, $/' , '', $val_str);
196
197 // Build the INSERT string
198 $output .= 'INSERT INTO '.$this->db->protect_identifiers($table).' ('.$field_str.') VALUES ('.$val_str.');'.$newline;
199 }
200
201 $output .= $newline.$newline;
202 }
203
Andrew Podner48512172012-12-20 07:56:19 -0500204 // Do we need to include a statement to re-enable foreign key checks?
205 if ($foreign_key_checks === FALSE)
Andrew Podner79494dd2012-12-19 14:15:41 -0500206 {
Andrey Andreev61c4d0a2012-12-20 16:29:29 +0200207 $output .= 'SET foreign_key_checks = 1;'.$newline;
Andrew Podner79494dd2012-12-19 14:15:41 -0500208 }
209
Andrey Andreev782de112012-06-12 03:04:50 +0300210 return $output;
Derek Allard2067d1a2008-11-13 22:59:24 +0000211 }
Andrey Andreev782de112012-06-12 03:04:50 +0300212
Derek Allard2067d1a2008-11-13 22:59:24 +0000213}