Edit File by line
/home/zeestwma/ceyloniy.../wp-inclu...
File: class-wpdb.php
/**
[500] Fix | Delete
* Multisite Sites table.
[501] Fix | Delete
*
[502] Fix | Delete
* @since 3.0.0
[503] Fix | Delete
*
[504] Fix | Delete
* @var string|null
[505] Fix | Delete
*/
[506] Fix | Delete
public $site;
[507] Fix | Delete
[508] Fix | Delete
/**
[509] Fix | Delete
* Multisite Sitewide Terms table.
[510] Fix | Delete
*
[511] Fix | Delete
* @since 3.0.0
[512] Fix | Delete
*
[513] Fix | Delete
* @var string|null
[514] Fix | Delete
*/
[515] Fix | Delete
public $sitecategories;
[516] Fix | Delete
[517] Fix | Delete
/**
[518] Fix | Delete
* Multisite Site Metadata table.
[519] Fix | Delete
*
[520] Fix | Delete
* @since 3.0.0
[521] Fix | Delete
*
[522] Fix | Delete
* @var string|null
[523] Fix | Delete
*/
[524] Fix | Delete
public $sitemeta;
[525] Fix | Delete
[526] Fix | Delete
/**
[527] Fix | Delete
* Format specifiers for DB columns.
[528] Fix | Delete
*
[529] Fix | Delete
* Columns not listed here default to %s. Initialized during WP load.
[530] Fix | Delete
* Keys are column names, values are format types: 'ID' => '%d'.
[531] Fix | Delete
*
[532] Fix | Delete
* @since 2.8.0
[533] Fix | Delete
*
[534] Fix | Delete
* @see wpdb::prepare()
[535] Fix | Delete
* @see wpdb::insert()
[536] Fix | Delete
* @see wpdb::update()
[537] Fix | Delete
* @see wpdb::delete()
[538] Fix | Delete
* @see wp_set_wpdb_vars()
[539] Fix | Delete
* @var array
[540] Fix | Delete
*/
[541] Fix | Delete
public $field_types = array();
[542] Fix | Delete
[543] Fix | Delete
/**
[544] Fix | Delete
* Database table columns charset.
[545] Fix | Delete
*
[546] Fix | Delete
* @since 2.2.0
[547] Fix | Delete
*
[548] Fix | Delete
* @var string
[549] Fix | Delete
*/
[550] Fix | Delete
public $charset;
[551] Fix | Delete
[552] Fix | Delete
/**
[553] Fix | Delete
* Database table columns collate.
[554] Fix | Delete
*
[555] Fix | Delete
* @since 2.2.0
[556] Fix | Delete
*
[557] Fix | Delete
* @var string
[558] Fix | Delete
*/
[559] Fix | Delete
public $collate;
[560] Fix | Delete
[561] Fix | Delete
/**
[562] Fix | Delete
* Database Username.
[563] Fix | Delete
*
[564] Fix | Delete
* @since 2.9.0
[565] Fix | Delete
*
[566] Fix | Delete
* @var string
[567] Fix | Delete
*/
[568] Fix | Delete
protected $dbuser;
[569] Fix | Delete
[570] Fix | Delete
/**
[571] Fix | Delete
* Database Password.
[572] Fix | Delete
*
[573] Fix | Delete
* @since 3.1.0
[574] Fix | Delete
*
[575] Fix | Delete
* @var string
[576] Fix | Delete
*/
[577] Fix | Delete
protected $dbpassword;
[578] Fix | Delete
[579] Fix | Delete
/**
[580] Fix | Delete
* Database Name.
[581] Fix | Delete
*
[582] Fix | Delete
* @since 3.1.0
[583] Fix | Delete
*
[584] Fix | Delete
* @var string
[585] Fix | Delete
*/
[586] Fix | Delete
protected $dbname;
[587] Fix | Delete
[588] Fix | Delete
/**
[589] Fix | Delete
* Database Host.
[590] Fix | Delete
*
[591] Fix | Delete
* @since 3.1.0
[592] Fix | Delete
*
[593] Fix | Delete
* @var string
[594] Fix | Delete
*/
[595] Fix | Delete
protected $dbhost;
[596] Fix | Delete
[597] Fix | Delete
/**
[598] Fix | Delete
* Database handle.
[599] Fix | Delete
*
[600] Fix | Delete
* Possible values:
[601] Fix | Delete
*
[602] Fix | Delete
* - `mysqli` instance during normal operation
[603] Fix | Delete
* - `null` if the connection is yet to be made or has been closed
[604] Fix | Delete
* - `false` if the connection has failed
[605] Fix | Delete
*
[606] Fix | Delete
* @since 0.71
[607] Fix | Delete
*
[608] Fix | Delete
* @var mysqli|false|null
[609] Fix | Delete
*/
[610] Fix | Delete
protected $dbh;
[611] Fix | Delete
[612] Fix | Delete
/**
[613] Fix | Delete
* A textual description of the last query/get_row/get_var call.
[614] Fix | Delete
*
[615] Fix | Delete
* @since 3.0.0
[616] Fix | Delete
*
[617] Fix | Delete
* @var string
[618] Fix | Delete
*/
[619] Fix | Delete
public $func_call;
[620] Fix | Delete
[621] Fix | Delete
/**
[622] Fix | Delete
* Whether MySQL is used as the database engine.
[623] Fix | Delete
*
[624] Fix | Delete
* Set in wpdb::db_connect() to true, by default. This is used when checking
[625] Fix | Delete
* against the required MySQL version for WordPress. Normally, a replacement
[626] Fix | Delete
* database drop-in (db.php) will skip these checks, but setting this to true
[627] Fix | Delete
* will force the checks to occur.
[628] Fix | Delete
*
[629] Fix | Delete
* @since 3.3.0
[630] Fix | Delete
*
[631] Fix | Delete
* @var bool
[632] Fix | Delete
*/
[633] Fix | Delete
public $is_mysql = null;
[634] Fix | Delete
[635] Fix | Delete
/**
[636] Fix | Delete
* A list of incompatible SQL modes.
[637] Fix | Delete
*
[638] Fix | Delete
* @since 3.9.0
[639] Fix | Delete
*
[640] Fix | Delete
* @var string[]
[641] Fix | Delete
*/
[642] Fix | Delete
protected $incompatible_modes = array(
[643] Fix | Delete
'NO_ZERO_DATE',
[644] Fix | Delete
'ONLY_FULL_GROUP_BY',
[645] Fix | Delete
'STRICT_TRANS_TABLES',
[646] Fix | Delete
'STRICT_ALL_TABLES',
[647] Fix | Delete
'TRADITIONAL',
[648] Fix | Delete
'ANSI',
[649] Fix | Delete
);
[650] Fix | Delete
[651] Fix | Delete
/**
[652] Fix | Delete
* Backward compatibility, where wpdb::prepare() has not quoted formatted/argnum placeholders.
[653] Fix | Delete
*
[654] Fix | Delete
* This is often used for table/field names (before %i was supported), and sometimes string formatting, e.g.
[655] Fix | Delete
*
[656] Fix | Delete
* $wpdb->prepare( 'WHERE `%1$s` = "%2$s something %3$s" OR %1$s = "%4$-10s"', 'field_1', 'a', 'b', 'c' );
[657] Fix | Delete
*
[658] Fix | Delete
* But it's risky, e.g. forgetting to add quotes, resulting in SQL Injection vulnerabilities:
[659] Fix | Delete
*
[660] Fix | Delete
* $wpdb->prepare( 'WHERE (id = %1s) OR (id = %2$s)', $_GET['id'], $_GET['id'] ); // ?id=id
[661] Fix | Delete
*
[662] Fix | Delete
* This feature is preserved while plugin authors update their code to use safer approaches:
[663] Fix | Delete
*
[664] Fix | Delete
* $_GET['key'] = 'a`b';
[665] Fix | Delete
*
[666] Fix | Delete
* $wpdb->prepare( 'WHERE %1s = %s', $_GET['key'], $_GET['value'] ); // WHERE a`b = 'value'
[667] Fix | Delete
* $wpdb->prepare( 'WHERE `%1$s` = "%2$s"', $_GET['key'], $_GET['value'] ); // WHERE `a`b` = "value"
[668] Fix | Delete
*
[669] Fix | Delete
* $wpdb->prepare( 'WHERE %i = %s', $_GET['key'], $_GET['value'] ); // WHERE `a``b` = 'value'
[670] Fix | Delete
*
[671] Fix | Delete
* While changing to false will be fine for queries not using formatted/argnum placeholders,
[672] Fix | Delete
* any remaining cases are most likely going to result in SQL errors (good, in a way):
[673] Fix | Delete
*
[674] Fix | Delete
* $wpdb->prepare( 'WHERE %1$s = "%2$-10s"', 'my_field', 'my_value' );
[675] Fix | Delete
* true = WHERE my_field = "my_value "
[676] Fix | Delete
* false = WHERE 'my_field' = "'my_value '"
[677] Fix | Delete
*
[678] Fix | Delete
* But there may be some queries that result in an SQL Injection vulnerability:
[679] Fix | Delete
*
[680] Fix | Delete
* $wpdb->prepare( 'WHERE id = %1$s', $_GET['id'] ); // ?id=id
[681] Fix | Delete
*
[682] Fix | Delete
* So there may need to be a `_doing_it_wrong()` phase, after we know everyone can use
[683] Fix | Delete
* identifier placeholders (%i), but before this feature is disabled or removed.
[684] Fix | Delete
*
[685] Fix | Delete
* @since 6.2.0
[686] Fix | Delete
* @var bool
[687] Fix | Delete
*/
[688] Fix | Delete
private $allow_unsafe_unquoted_parameters = true;
[689] Fix | Delete
[690] Fix | Delete
/**
[691] Fix | Delete
* Whether to use the mysqli extension over mysql. This is no longer used as the mysql
[692] Fix | Delete
* extension is no longer supported.
[693] Fix | Delete
*
[694] Fix | Delete
* Default true.
[695] Fix | Delete
*
[696] Fix | Delete
* @since 3.9.0
[697] Fix | Delete
* @since 6.4.0 This property was removed.
[698] Fix | Delete
* @since 6.4.1 This property was reinstated and its default value was changed to true.
[699] Fix | Delete
* The property is no longer used in core but may be accessed externally.
[700] Fix | Delete
*
[701] Fix | Delete
* @var bool
[702] Fix | Delete
*/
[703] Fix | Delete
private $use_mysqli = true;
[704] Fix | Delete
[705] Fix | Delete
/**
[706] Fix | Delete
* Whether we've managed to successfully connect at some point.
[707] Fix | Delete
*
[708] Fix | Delete
* @since 3.9.0
[709] Fix | Delete
*
[710] Fix | Delete
* @var bool
[711] Fix | Delete
*/
[712] Fix | Delete
private $has_connected = false;
[713] Fix | Delete
[714] Fix | Delete
/**
[715] Fix | Delete
* Time when the last query was performed.
[716] Fix | Delete
*
[717] Fix | Delete
* Only set when `SAVEQUERIES` is defined and truthy.
[718] Fix | Delete
*
[719] Fix | Delete
* @since 1.5.0
[720] Fix | Delete
*
[721] Fix | Delete
* @var float
[722] Fix | Delete
*/
[723] Fix | Delete
public $time_start = null;
[724] Fix | Delete
[725] Fix | Delete
/**
[726] Fix | Delete
* The last SQL error that was encountered.
[727] Fix | Delete
*
[728] Fix | Delete
* @since 2.5.0
[729] Fix | Delete
*
[730] Fix | Delete
* @var WP_Error|string
[731] Fix | Delete
*/
[732] Fix | Delete
public $error = null;
[733] Fix | Delete
[734] Fix | Delete
/**
[735] Fix | Delete
* Connects to the database server and selects a database.
[736] Fix | Delete
*
[737] Fix | Delete
* Does the actual setting up
[738] Fix | Delete
* of the class properties and connection to the database.
[739] Fix | Delete
*
[740] Fix | Delete
* @since 2.0.8
[741] Fix | Delete
*
[742] Fix | Delete
* @link https://core.trac.wordpress.org/ticket/3354
[743] Fix | Delete
*
[744] Fix | Delete
* @param string $dbuser Database user.
[745] Fix | Delete
* @param string $dbpassword Database password.
[746] Fix | Delete
* @param string $dbname Database name.
[747] Fix | Delete
* @param string $dbhost Database host.
[748] Fix | Delete
*/
[749] Fix | Delete
public function __construct(
[750] Fix | Delete
$dbuser,
[751] Fix | Delete
#[\SensitiveParameter]
[752] Fix | Delete
$dbpassword,
[753] Fix | Delete
$dbname,
[754] Fix | Delete
$dbhost
[755] Fix | Delete
) {
[756] Fix | Delete
if ( WP_DEBUG && WP_DEBUG_DISPLAY ) {
[757] Fix | Delete
$this->show_errors();
[758] Fix | Delete
}
[759] Fix | Delete
[760] Fix | Delete
$this->dbuser = $dbuser;
[761] Fix | Delete
$this->dbpassword = $dbpassword;
[762] Fix | Delete
$this->dbname = $dbname;
[763] Fix | Delete
$this->dbhost = $dbhost;
[764] Fix | Delete
[765] Fix | Delete
// wp-config.php creation will manually connect when ready.
[766] Fix | Delete
if ( defined( 'WP_SETUP_CONFIG' ) ) {
[767] Fix | Delete
return;
[768] Fix | Delete
}
[769] Fix | Delete
[770] Fix | Delete
$this->db_connect();
[771] Fix | Delete
}
[772] Fix | Delete
[773] Fix | Delete
/**
[774] Fix | Delete
* Makes private properties readable for backward compatibility.
[775] Fix | Delete
*
[776] Fix | Delete
* @since 3.5.0
[777] Fix | Delete
*
[778] Fix | Delete
* @param string $name The private member to get, and optionally process.
[779] Fix | Delete
* @return mixed The private member.
[780] Fix | Delete
*/
[781] Fix | Delete
public function __get( $name ) {
[782] Fix | Delete
if ( 'col_info' === $name ) {
[783] Fix | Delete
$this->load_col_info();
[784] Fix | Delete
}
[785] Fix | Delete
[786] Fix | Delete
return $this->$name;
[787] Fix | Delete
}
[788] Fix | Delete
[789] Fix | Delete
/**
[790] Fix | Delete
* Makes private properties settable for backward compatibility.
[791] Fix | Delete
*
[792] Fix | Delete
* @since 3.5.0
[793] Fix | Delete
*
[794] Fix | Delete
* @param string $name The private member to set.
[795] Fix | Delete
* @param mixed $value The value to set.
[796] Fix | Delete
*/
[797] Fix | Delete
public function __set( $name, $value ) {
[798] Fix | Delete
$protected_members = array(
[799] Fix | Delete
'col_meta',
[800] Fix | Delete
'table_charset',
[801] Fix | Delete
'check_current_query',
[802] Fix | Delete
'allow_unsafe_unquoted_parameters',
[803] Fix | Delete
);
[804] Fix | Delete
if ( in_array( $name, $protected_members, true ) ) {
[805] Fix | Delete
return;
[806] Fix | Delete
}
[807] Fix | Delete
$this->$name = $value;
[808] Fix | Delete
}
[809] Fix | Delete
[810] Fix | Delete
/**
[811] Fix | Delete
* Makes private properties check-able for backward compatibility.
[812] Fix | Delete
*
[813] Fix | Delete
* @since 3.5.0
[814] Fix | Delete
*
[815] Fix | Delete
* @param string $name The private member to check.
[816] Fix | Delete
* @return bool If the member is set or not.
[817] Fix | Delete
*/
[818] Fix | Delete
public function __isset( $name ) {
[819] Fix | Delete
return isset( $this->$name );
[820] Fix | Delete
}
[821] Fix | Delete
[822] Fix | Delete
/**
[823] Fix | Delete
* Makes private properties un-settable for backward compatibility.
[824] Fix | Delete
*
[825] Fix | Delete
* @since 3.5.0
[826] Fix | Delete
*
[827] Fix | Delete
* @param string $name The private member to unset.
[828] Fix | Delete
*/
[829] Fix | Delete
public function __unset( $name ) {
[830] Fix | Delete
unset( $this->$name );
[831] Fix | Delete
}
[832] Fix | Delete
[833] Fix | Delete
/**
[834] Fix | Delete
* Sets $this->charset and $this->collate.
[835] Fix | Delete
*
[836] Fix | Delete
* @since 3.1.0
[837] Fix | Delete
*/
[838] Fix | Delete
public function init_charset() {
[839] Fix | Delete
$charset = '';
[840] Fix | Delete
$collate = '';
[841] Fix | Delete
[842] Fix | Delete
if ( function_exists( 'is_multisite' ) && is_multisite() ) {
[843] Fix | Delete
$charset = 'utf8';
[844] Fix | Delete
if ( defined( 'DB_COLLATE' ) && DB_COLLATE ) {
[845] Fix | Delete
$collate = DB_COLLATE;
[846] Fix | Delete
} else {
[847] Fix | Delete
$collate = 'utf8_general_ci';
[848] Fix | Delete
}
[849] Fix | Delete
} elseif ( defined( 'DB_COLLATE' ) ) {
[850] Fix | Delete
$collate = DB_COLLATE;
[851] Fix | Delete
}
[852] Fix | Delete
[853] Fix | Delete
if ( defined( 'DB_CHARSET' ) ) {
[854] Fix | Delete
$charset = DB_CHARSET;
[855] Fix | Delete
}
[856] Fix | Delete
[857] Fix | Delete
$charset_collate = $this->determine_charset( $charset, $collate );
[858] Fix | Delete
[859] Fix | Delete
$this->charset = $charset_collate['charset'];
[860] Fix | Delete
$this->collate = $charset_collate['collate'];
[861] Fix | Delete
}
[862] Fix | Delete
[863] Fix | Delete
/**
[864] Fix | Delete
* Determines the best charset and collation to use given a charset and collation.
[865] Fix | Delete
*
[866] Fix | Delete
* For example, when able, utf8mb4 should be used instead of utf8.
[867] Fix | Delete
*
[868] Fix | Delete
* @since 4.6.0
[869] Fix | Delete
*
[870] Fix | Delete
* @param string $charset The character set to check.
[871] Fix | Delete
* @param string $collate The collation to check.
[872] Fix | Delete
* @return array {
[873] Fix | Delete
* The most appropriate character set and collation to use.
[874] Fix | Delete
*
[875] Fix | Delete
* @type string $charset Character set.
[876] Fix | Delete
* @type string $collate Collation.
[877] Fix | Delete
* }
[878] Fix | Delete
*/
[879] Fix | Delete
public function determine_charset( $charset, $collate ) {
[880] Fix | Delete
if ( ( ! ( $this->dbh instanceof mysqli ) ) || empty( $this->dbh ) ) {
[881] Fix | Delete
return compact( 'charset', 'collate' );
[882] Fix | Delete
}
[883] Fix | Delete
[884] Fix | Delete
if ( 'utf8' === $charset ) {
[885] Fix | Delete
$charset = 'utf8mb4';
[886] Fix | Delete
}
[887] Fix | Delete
[888] Fix | Delete
if ( 'utf8mb4' === $charset ) {
[889] Fix | Delete
// _general_ is outdated, so we can upgrade it to _unicode_, instead.
[890] Fix | Delete
if ( ! $collate || 'utf8_general_ci' === $collate ) {
[891] Fix | Delete
$collate = 'utf8mb4_unicode_ci';
[892] Fix | Delete
} else {
[893] Fix | Delete
$collate = str_replace( 'utf8_', 'utf8mb4_', $collate );
[894] Fix | Delete
}
[895] Fix | Delete
}
[896] Fix | Delete
[897] Fix | Delete
// _unicode_520_ is a better collation, we should use that when it's available.
[898] Fix | Delete
if ( $this->has_cap( 'utf8mb4_520' ) && 'utf8mb4_unicode_ci' === $collate ) {
[899] Fix | Delete
$collate = 'utf8mb4_unicode_520_ci';
[900] Fix | Delete
}
[901] Fix | Delete
[902] Fix | Delete
return compact( 'charset', 'collate' );
[903] Fix | Delete
}
[904] Fix | Delete
[905] Fix | Delete
/**
[906] Fix | Delete
* Sets the connection's character set.
[907] Fix | Delete
*
[908] Fix | Delete
* @since 3.1.0
[909] Fix | Delete
*
[910] Fix | Delete
* @param mysqli $dbh The connection returned by `mysqli_connect()`.
[911] Fix | Delete
* @param string $charset Optional. The character set. Default null.
[912] Fix | Delete
* @param string $collate Optional. The collation. Default null.
[913] Fix | Delete
*/
[914] Fix | Delete
public function set_charset( $dbh, $charset = null, $collate = null ) {
[915] Fix | Delete
if ( ! isset( $charset ) ) {
[916] Fix | Delete
$charset = $this->charset;
[917] Fix | Delete
}
[918] Fix | Delete
if ( ! isset( $collate ) ) {
[919] Fix | Delete
$collate = $this->collate;
[920] Fix | Delete
}
[921] Fix | Delete
if ( $this->has_cap( 'collation' ) && ! empty( $charset ) ) {
[922] Fix | Delete
$set_charset_succeeded = true;
[923] Fix | Delete
[924] Fix | Delete
if ( function_exists( 'mysqli_set_charset' ) && $this->has_cap( 'set_charset' ) ) {
[925] Fix | Delete
$set_charset_succeeded = mysqli_set_charset( $dbh, $charset );
[926] Fix | Delete
}
[927] Fix | Delete
[928] Fix | Delete
if ( $set_charset_succeeded ) {
[929] Fix | Delete
$query = $this->prepare( 'SET NAMES %s', $charset );
[930] Fix | Delete
if ( ! empty( $collate ) ) {
[931] Fix | Delete
$query .= $this->prepare( ' COLLATE %s', $collate );
[932] Fix | Delete
}
[933] Fix | Delete
mysqli_query( $dbh, $query );
[934] Fix | Delete
}
[935] Fix | Delete
}
[936] Fix | Delete
}
[937] Fix | Delete
[938] Fix | Delete
/**
[939] Fix | Delete
* Changes the current SQL mode, and ensures its WordPress compatibility.
[940] Fix | Delete
*
[941] Fix | Delete
* If no modes are passed, it will ensure the current SQL server modes are compatible.
[942] Fix | Delete
*
[943] Fix | Delete
* @since 3.9.0
[944] Fix | Delete
*
[945] Fix | Delete
* @param array $modes Optional. A list of SQL modes to set. Default empty array.
[946] Fix | Delete
*/
[947] Fix | Delete
public function set_sql_mode( $modes = array() ) {
[948] Fix | Delete
if ( empty( $modes ) ) {
[949] Fix | Delete
$res = mysqli_query( $this->dbh, 'SELECT @@SESSION.sql_mode' );
[950] Fix | Delete
[951] Fix | Delete
if ( empty( $res ) ) {
[952] Fix | Delete
return;
[953] Fix | Delete
}
[954] Fix | Delete
[955] Fix | Delete
$modes_array = mysqli_fetch_array( $res );
[956] Fix | Delete
[957] Fix | Delete
if ( empty( $modes_array[0] ) ) {
[958] Fix | Delete
return;
[959] Fix | Delete
}
[960] Fix | Delete
[961] Fix | Delete
$modes_str = $modes_array[0];
[962] Fix | Delete
[963] Fix | Delete
if ( empty( $modes_str ) ) {
[964] Fix | Delete
return;
[965] Fix | Delete
}
[966] Fix | Delete
[967] Fix | Delete
$modes = explode( ',', $modes_str );
[968] Fix | Delete
}
[969] Fix | Delete
[970] Fix | Delete
$modes = array_change_key_case( $modes, CASE_UPPER );
[971] Fix | Delete
[972] Fix | Delete
/**
[973] Fix | Delete
* Filters the list of incompatible SQL modes to exclude.
[974] Fix | Delete
*
[975] Fix | Delete
* @since 3.9.0
[976] Fix | Delete
*
[977] Fix | Delete
* @param array $incompatible_modes An array of incompatible modes.
[978] Fix | Delete
*/
[979] Fix | Delete
$incompatible_modes = (array) apply_filters( 'incompatible_sql_modes', $this->incompatible_modes );
[980] Fix | Delete
[981] Fix | Delete
foreach ( $modes as $i => $mode ) {
[982] Fix | Delete
if ( in_array( $mode, $incompatible_modes, true ) ) {
[983] Fix | Delete
unset( $modes[ $i ] );
[984] Fix | Delete
}
[985] Fix | Delete
}
[986] Fix | Delete
[987] Fix | Delete
$modes_str = implode( ',', $modes );
[988] Fix | Delete
[989] Fix | Delete
mysqli_query( $this->dbh, "SET SESSION sql_mode='$modes_str'" );
[990] Fix | Delete
}
[991] Fix | Delete
[992] Fix | Delete
/**
[993] Fix | Delete
* Sets the table prefix for the WordPress tables.
[994] Fix | Delete
*
[995] Fix | Delete
* @since 2.5.0
[996] Fix | Delete
*
[997] Fix | Delete
* @param string $prefix Alphanumeric name for the new prefix.
[998] Fix | Delete
* @param bool $set_table_names Optional. Whether the table names, e.g. wpdb::$posts,
[999] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function