blob: 606424655826c8c19ed5e9f5366e9838a48a81fd [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 *
Instructor, BCIT0e59db62019-01-01 08:34:36 -08009 * Copyright (c) 2014 - 2019, 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/)
Instructor, BCIT0e59db62019-01-01 08:34:36 -080032 * @copyright Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/)
33 * @license https://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
Andrey Andreeva9194652017-09-27 18:57:46 +0300158 $is_int[$i] = in_array($field->type, array(MYSQLI_TYPE_TINY, MYSQLI_TYPE_SHORT, MYSQLI_TYPE_INT24, MYSQLI_TYPE_LONG), TRUE);
Andrey Andreev782de112012-06-12 03:04:50 +0300159
160 // Create a string of field names
161 $field_str .= $this->db->escape_identifiers($field->name).', ';
162 $i++;
163 }
164
165 // Trim off the end comma
166 $field_str = preg_replace('/, $/' , '', $field_str);
167
168 // Build the insert string
169 foreach ($query->result_array() as $row)
170 {
171 $val_str = '';
172
173 $i = 0;
174 foreach ($row as $v)
175 {
176 // Is the value NULL?
177 if ($v === NULL)
178 {
179 $val_str .= 'NULL';
180 }
181 else
182 {
183 // Escape the data if it's not an integer
184 $val_str .= ($is_int[$i] === FALSE) ? $this->db->escape($v) : $v;
185 }
186
187 // Append a comma
188 $val_str .= ', ';
189 $i++;
190 }
191
192 // Remove the comma at the end of the string
193 $val_str = preg_replace('/, $/' , '', $val_str);
194
195 // Build the INSERT string
196 $output .= 'INSERT INTO '.$this->db->protect_identifiers($table).' ('.$field_str.') VALUES ('.$val_str.');'.$newline;
197 }
198
199 $output .= $newline.$newline;
200 }
201
Andrew Podner48512172012-12-20 07:56:19 -0500202 // Do we need to include a statement to re-enable foreign key checks?
203 if ($foreign_key_checks === FALSE)
Andrew Podner79494dd2012-12-19 14:15:41 -0500204 {
Andrey Andreev61c4d0a2012-12-20 16:29:29 +0200205 $output .= 'SET foreign_key_checks = 1;'.$newline;
Andrew Podner79494dd2012-12-19 14:15:41 -0500206 }
207
Andrey Andreev782de112012-06-12 03:04:50 +0300208 return $output;
Derek Allard2067d1a2008-11-13 22:59:24 +0000209 }
Andrey Andreev782de112012-06-12 03:04:50 +0300210
Derek Allard2067d1a2008-11-13 22:59:24 +0000211}