wp/wp-includes/wp-db.php
author ymh <ymh.work@gmail.com>
Wed, 06 Nov 2013 03:21:17 +0000
changeset 0 d970ebf37754
child 5 5e2f62d02dcd
permissions -rw-r--r--
first import
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     1
<?php
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     2
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     3
 * WordPress DB Class
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     4
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     5
 * Original code from {@link http://php.justinvincent.com Justin Vincent (justin@visunet.ie)}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     6
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     7
 * @package WordPress
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     8
 * @subpackage Database
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     9
 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    10
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    11
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    12
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    13
 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    14
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    15
define( 'EZSQL_VERSION', 'WP1.25' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    16
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    17
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    18
 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    19
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    20
define( 'OBJECT', 'OBJECT', true );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    21
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    22
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    23
 * @since 2.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    24
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    25
define( 'OBJECT_K', 'OBJECT_K' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    26
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    27
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    28
 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    29
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    30
define( 'ARRAY_A', 'ARRAY_A' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    31
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    32
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    33
 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    34
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    35
define( 'ARRAY_N', 'ARRAY_N' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    36
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    37
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    38
 * WordPress Database Access Abstraction Object
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    39
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    40
 * It is possible to replace this class with your own
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    41
 * by setting the $wpdb global variable in wp-content/db.php
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    42
 * file to your class. The wpdb class will still be included,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    43
 * so you can extend it or simply use your own.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    44
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    45
 * @link http://codex.wordpress.org/Function_Reference/wpdb_Class
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    46
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    47
 * @package WordPress
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    48
 * @subpackage Database
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    49
 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    50
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    51
class wpdb {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    52
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    53
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    54
	 * Whether to show SQL/DB errors
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    55
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    56
	 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    57
	 * @access private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    58
	 * @var bool
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    59
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    60
	var $show_errors = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    61
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    62
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    63
	 * Whether to suppress errors during the DB bootstrapping.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    64
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    65
	 * @access private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    66
	 * @since 2.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    67
	 * @var bool
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    68
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    69
	var $suppress_errors = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    70
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    71
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    72
	 * The last error during query.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    73
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    74
	 * @since 2.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    75
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    76
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    77
	var $last_error = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    78
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    79
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    80
	 * Amount of queries made
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    81
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    82
	 * @since 1.2.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    83
	 * @access private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    84
	 * @var int
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    85
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    86
	var $num_queries = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    87
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    88
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    89
	 * Count of rows returned by previous query
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    90
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    91
	 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    92
	 * @access private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    93
	 * @var int
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    94
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    95
	var $num_rows = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    96
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    97
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    98
	 * Count of affected rows by previous query
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    99
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   100
	 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   101
	 * @access private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   102
	 * @var int
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   103
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   104
	var $rows_affected = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   105
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   106
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   107
	 * The ID generated for an AUTO_INCREMENT column by the previous query (usually INSERT).
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   108
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   109
	 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   110
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   111
	 * @var int
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   112
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   113
	var $insert_id = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   114
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   115
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   116
	 * Last query made
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   117
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   118
	 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   119
	 * @access private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   120
	 * @var array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   121
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   122
	var $last_query;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   123
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   124
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   125
	 * Results of the last query made
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   126
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   127
	 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   128
	 * @access private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   129
	 * @var array|null
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   130
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   131
	var $last_result;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   132
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   133
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   134
	 * MySQL result, which is either a resource or boolean.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   135
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   136
	 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   137
	 * @access protected
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   138
	 * @var mixed
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   139
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   140
	protected $result;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   141
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   142
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   143
	 * Saved info on the table column
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   144
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   145
	 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   146
	 * @access protected
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   147
	 * @var array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   148
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   149
	protected $col_info;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   150
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   151
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   152
	 * Saved queries that were executed
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   153
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   154
	 * @since 1.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   155
	 * @access private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   156
	 * @var array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   157
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   158
	var $queries;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   159
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   160
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   161
	 * WordPress table prefix
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   162
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   163
	 * You can set this to have multiple WordPress installations
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   164
	 * in a single database. The second reason is for possible
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   165
	 * security precautions.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   166
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   167
	 * @since 2.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   168
	 * @access private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   169
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   170
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   171
	var $prefix = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   172
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   173
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   174
	 * Whether the database queries are ready to start executing.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   175
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   176
	 * @since 2.3.2
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   177
	 * @access private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   178
	 * @var bool
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   179
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   180
	var $ready = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   181
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   182
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   183
	 * {@internal Missing Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   184
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   185
	 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   186
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   187
	 * @var int
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   188
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   189
	var $blogid = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   190
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   191
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   192
	 * {@internal Missing Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   193
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   194
	 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   195
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   196
	 * @var int
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   197
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   198
	var $siteid = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   199
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   200
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   201
	 * List of WordPress per-blog tables
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   202
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   203
	 * @since 2.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   204
	 * @access private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   205
	 * @see wpdb::tables()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   206
	 * @var array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   207
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   208
	var $tables = array( 'posts', 'comments', 'links', 'options', 'postmeta',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   209
		'terms', 'term_taxonomy', 'term_relationships', 'commentmeta' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   210
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   211
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   212
	 * List of deprecated WordPress tables
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   213
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   214
	 * categories, post2cat, and link2cat were deprecated in 2.3.0, db version 5539
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   215
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   216
	 * @since 2.9.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   217
	 * @access private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   218
	 * @see wpdb::tables()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   219
	 * @var array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   220
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   221
	var $old_tables = array( 'categories', 'post2cat', 'link2cat' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   222
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   223
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   224
	 * List of WordPress global tables
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   225
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   226
	 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   227
	 * @access private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   228
	 * @see wpdb::tables()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   229
	 * @var array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   230
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   231
	var $global_tables = array( 'users', 'usermeta' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   232
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   233
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   234
	 * List of Multisite global tables
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   235
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   236
	 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   237
	 * @access private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   238
	 * @see wpdb::tables()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   239
	 * @var array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   240
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   241
	var $ms_global_tables = array( 'blogs', 'signups', 'site', 'sitemeta',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   242
		'sitecategories', 'registration_log', 'blog_versions' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   243
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   244
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   245
	 * WordPress Comments table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   246
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   247
	 * @since 1.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   248
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   249
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   250
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   251
	var $comments;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   252
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   253
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   254
	 * WordPress Comment Metadata table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   255
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   256
	 * @since 2.9.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   257
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   258
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   259
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   260
	var $commentmeta;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   261
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   262
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   263
	 * WordPress Links table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   264
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   265
	 * @since 1.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   266
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   267
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   268
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   269
	var $links;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   270
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   271
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   272
	 * WordPress Options table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   273
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   274
	 * @since 1.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   275
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   276
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   277
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   278
	var $options;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   279
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   280
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   281
	 * WordPress Post Metadata table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   282
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   283
	 * @since 1.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   284
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   285
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   286
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   287
	var $postmeta;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   288
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   289
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   290
	 * WordPress Posts table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   291
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   292
	 * @since 1.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   293
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   294
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   295
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   296
	var $posts;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   297
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   298
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   299
	 * WordPress Terms table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   300
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   301
	 * @since 2.3.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   302
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   303
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   304
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   305
	var $terms;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   306
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   307
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   308
	 * WordPress Term Relationships table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   309
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   310
	 * @since 2.3.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   311
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   312
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   313
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   314
	var $term_relationships;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   315
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   316
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   317
	 * WordPress Term Taxonomy table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   318
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   319
	 * @since 2.3.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   320
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   321
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   322
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   323
	var $term_taxonomy;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   324
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   325
	/*
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   326
	 * Global and Multisite tables
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   327
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   328
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   329
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   330
	 * WordPress User Metadata table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   331
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   332
	 * @since 2.3.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   333
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   334
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   335
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   336
	var $usermeta;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   337
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   338
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   339
	 * WordPress Users table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   340
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   341
	 * @since 1.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   342
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   343
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   344
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   345
	var $users;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   346
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   347
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   348
	 * Multisite Blogs table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   349
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   350
	 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   351
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   352
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   353
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   354
	var $blogs;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   355
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   356
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   357
	 * Multisite Blog Versions table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   358
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   359
	 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   360
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   361
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   362
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   363
	var $blog_versions;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   364
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   365
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   366
	 * Multisite Registration Log table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   367
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   368
	 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   369
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   370
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   371
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   372
	var $registration_log;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   373
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   374
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   375
	 * Multisite Signups table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   376
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   377
	 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   378
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   379
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   380
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   381
	var $signups;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   382
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   383
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   384
	 * Multisite Sites table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   385
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   386
	 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   387
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   388
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   389
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   390
	var $site;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   391
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   392
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   393
	 * Multisite Sitewide Terms table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   394
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   395
	 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   396
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   397
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   398
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   399
	var $sitecategories;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   400
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   401
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   402
	 * Multisite Site Metadata table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   403
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   404
	 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   405
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   406
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   407
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   408
	var $sitemeta;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   409
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   410
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   411
	 * Format specifiers for DB columns. Columns not listed here default to %s. Initialized during WP load.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   412
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   413
	 * Keys are column names, values are format types: 'ID' => '%d'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   414
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   415
	 * @since 2.8.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   416
	 * @see wpdb::prepare()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   417
	 * @see wpdb::insert()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   418
	 * @see wpdb::update()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   419
	 * @see wpdb::delete()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   420
	 * @see wp_set_wpdb_vars()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   421
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   422
	 * @var array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   423
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   424
	var $field_types = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   425
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   426
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   427
	 * Database table columns charset
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   428
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   429
	 * @since 2.2.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   430
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   431
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   432
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   433
	var $charset;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   434
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   435
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   436
	 * Database table columns collate
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   437
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   438
	 * @since 2.2.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   439
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   440
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   441
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   442
	var $collate;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   443
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   444
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   445
	 * Database Username
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   446
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   447
	 * @since 2.9.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   448
	 * @access protected
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   449
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   450
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   451
	protected $dbuser;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   452
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   453
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   454
	 * Database Password
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   455
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   456
	 * @since 3.1.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   457
	 * @access protected
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   458
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   459
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   460
	protected $dbpassword;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   461
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   462
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   463
	 * Database Name
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   464
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   465
	 * @since 3.1.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   466
	 * @access protected
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   467
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   468
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   469
	protected $dbname;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   470
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   471
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   472
	 * Database Host
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   473
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   474
	 * @since 3.1.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   475
	 * @access protected
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   476
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   477
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   478
	protected $dbhost;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   479
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   480
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   481
	 * Database Handle
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   482
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   483
	 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   484
	 * @access protected
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   485
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   486
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   487
	protected $dbh;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   488
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   489
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   490
	 * A textual description of the last query/get_row/get_var call
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   491
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   492
	 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   493
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   494
	 * @var string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   495
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   496
	var $func_call;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   497
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   498
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   499
	 * Whether MySQL is used as the database engine.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   500
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   501
	 * Set in WPDB::db_connect() to true, by default. This is used when checking
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   502
	 * against the required MySQL version for WordPress. Normally, a replacement
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   503
	 * database drop-in (db.php) will skip these checks, but setting this to true
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   504
	 * will force the checks to occur.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   505
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   506
	 * @since 3.3.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   507
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   508
	 * @var bool
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   509
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   510
	public $is_mysql = null;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   511
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   512
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   513
	 * Connects to the database server and selects a database
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   514
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   515
	 * PHP5 style constructor for compatibility with PHP5. Does
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   516
	 * the actual setting up of the class properties and connection
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   517
	 * to the database.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   518
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   519
	 * @link http://core.trac.wordpress.org/ticket/3354
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   520
	 * @since 2.0.8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   521
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   522
	 * @param string $dbuser MySQL database user
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   523
	 * @param string $dbpassword MySQL database password
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   524
	 * @param string $dbname MySQL database name
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   525
	 * @param string $dbhost MySQL database host
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   526
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   527
	function __construct( $dbuser, $dbpassword, $dbname, $dbhost ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   528
		register_shutdown_function( array( $this, '__destruct' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   529
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   530
		if ( WP_DEBUG && WP_DEBUG_DISPLAY )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   531
			$this->show_errors();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   532
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   533
		$this->init_charset();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   534
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   535
		$this->dbuser = $dbuser;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   536
		$this->dbpassword = $dbpassword;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   537
		$this->dbname = $dbname;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   538
		$this->dbhost = $dbhost;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   539
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   540
		$this->db_connect();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   541
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   542
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   543
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   544
	 * PHP5 style destructor and will run when database object is destroyed.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   545
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   546
	 * @see wpdb::__construct()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   547
	 * @since 2.0.8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   548
	 * @return bool true
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   549
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   550
	function __destruct() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   551
		return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   552
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   553
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   554
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   555
	 * PHP5 style magic getter, used to lazy-load expensive data.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   556
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   557
	 * @since 3.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   558
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   559
	 * @param string $name The private member to get, and optionally process
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   560
	 * @return mixed The private member
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   561
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   562
	function __get( $name ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   563
		if ( 'col_info' == $name )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   564
			$this->load_col_info();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   565
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   566
		return $this->$name;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   567
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   568
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   569
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   570
	 * Magic function, for backwards compatibility
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   571
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   572
	 * @since 3.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   573
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   574
	 * @param string $name  The private member to set
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   575
	 * @param mixed  $value The value to set
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   576
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   577
	function __set( $name, $value ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   578
		$this->$name = $value;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   579
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   580
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   581
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   582
	 * Magic function, for backwards compatibility
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   583
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   584
	 * @since 3.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   585
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   586
	 * @param string $name  The private member to check
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   587
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   588
	 * @return bool If the member is set or not
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   589
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   590
	function __isset( $name ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   591
		return isset( $this->$name );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   592
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   593
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   594
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   595
	 * Magic function, for backwards compatibility
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   596
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   597
	 * @since 3.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   598
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   599
	 * @param string $name  The private member to unset
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   600
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   601
	function __unset( $name ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   602
		unset( $this->$name );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   603
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   604
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   605
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   606
	 * Set $this->charset and $this->collate
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   607
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   608
	 * @since 3.1.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   609
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   610
	function init_charset() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   611
		if ( function_exists('is_multisite') && is_multisite() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   612
			$this->charset = 'utf8';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   613
			if ( defined( 'DB_COLLATE' ) && DB_COLLATE )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   614
				$this->collate = DB_COLLATE;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   615
			else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   616
				$this->collate = 'utf8_general_ci';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   617
		} elseif ( defined( 'DB_COLLATE' ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   618
			$this->collate = DB_COLLATE;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   619
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   620
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   621
		if ( defined( 'DB_CHARSET' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   622
			$this->charset = DB_CHARSET;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   623
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   624
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   625
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   626
	 * Sets the connection's character set.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   627
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   628
	 * @since 3.1.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   629
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   630
	 * @param resource $dbh     The resource given by mysql_connect
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   631
	 * @param string   $charset The character set (optional)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   632
	 * @param string   $collate The collation (optional)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   633
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   634
	function set_charset( $dbh, $charset = null, $collate = null ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   635
		if ( ! isset( $charset ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   636
			$charset = $this->charset;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   637
		if ( ! isset( $collate ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   638
			$collate = $this->collate;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   639
		if ( $this->has_cap( 'collation' ) && ! empty( $charset ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   640
			if ( function_exists( 'mysql_set_charset' ) && $this->has_cap( 'set_charset' ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   641
				mysql_set_charset( $charset, $dbh );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   642
			} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   643
				$query = $this->prepare( 'SET NAMES %s', $charset );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   644
				if ( ! empty( $collate ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   645
					$query .= $this->prepare( ' COLLATE %s', $collate );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   646
				mysql_query( $query, $dbh );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   647
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   648
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   649
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   650
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   651
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   652
	 * Sets the table prefix for the WordPress tables.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   653
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   654
	 * @since 2.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   655
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   656
	 * @param string $prefix Alphanumeric name for the new prefix.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   657
	 * @param bool $set_table_names Optional. Whether the table names, e.g. wpdb::$posts, should be updated or not.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   658
	 * @return string|WP_Error Old prefix or WP_Error on error
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   659
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   660
	function set_prefix( $prefix, $set_table_names = true ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   661
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   662
		if ( preg_match( '|[^a-z0-9_]|i', $prefix ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   663
			return new WP_Error('invalid_db_prefix', 'Invalid database prefix' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   664
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   665
		$old_prefix = is_multisite() ? '' : $prefix;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   666
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   667
		if ( isset( $this->base_prefix ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   668
			$old_prefix = $this->base_prefix;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   669
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   670
		$this->base_prefix = $prefix;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   671
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   672
		if ( $set_table_names ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   673
			foreach ( $this->tables( 'global' ) as $table => $prefixed_table )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   674
				$this->$table = $prefixed_table;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   675
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   676
			if ( is_multisite() && empty( $this->blogid ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   677
				return $old_prefix;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   678
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   679
			$this->prefix = $this->get_blog_prefix();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   680
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   681
			foreach ( $this->tables( 'blog' ) as $table => $prefixed_table )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   682
				$this->$table = $prefixed_table;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   683
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   684
			foreach ( $this->tables( 'old' ) as $table => $prefixed_table )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   685
				$this->$table = $prefixed_table;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   686
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   687
		return $old_prefix;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   688
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   689
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   690
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   691
	 * Sets blog id.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   692
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   693
	 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   694
	 * @access public
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   695
	 * @param int $blog_id
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   696
	 * @param int $site_id Optional.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   697
	 * @return string previous blog id
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   698
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   699
	function set_blog_id( $blog_id, $site_id = 0 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   700
		if ( ! empty( $site_id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   701
			$this->siteid = $site_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   702
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   703
		$old_blog_id  = $this->blogid;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   704
		$this->blogid = $blog_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   705
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   706
		$this->prefix = $this->get_blog_prefix();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   707
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   708
		foreach ( $this->tables( 'blog' ) as $table => $prefixed_table )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   709
			$this->$table = $prefixed_table;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   710
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   711
		foreach ( $this->tables( 'old' ) as $table => $prefixed_table )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   712
			$this->$table = $prefixed_table;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   713
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   714
		return $old_blog_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   715
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   716
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   717
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   718
	 * Gets blog prefix.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   719
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   720
	 * @uses is_multisite()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   721
	 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   722
	 * @param int $blog_id Optional.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   723
	 * @return string Blog prefix.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   724
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   725
	function get_blog_prefix( $blog_id = null ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   726
		if ( is_multisite() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   727
			if ( null === $blog_id )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   728
				$blog_id = $this->blogid;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   729
			$blog_id = (int) $blog_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   730
			if ( defined( 'MULTISITE' ) && ( 0 == $blog_id || 1 == $blog_id ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   731
				return $this->base_prefix;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   732
			else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   733
				return $this->base_prefix . $blog_id . '_';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   734
		} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   735
			return $this->base_prefix;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   736
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   737
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   738
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   739
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   740
	 * Returns an array of WordPress tables.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   741
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   742
	 * Also allows for the CUSTOM_USER_TABLE and CUSTOM_USER_META_TABLE to
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   743
	 * override the WordPress users and usermeta tables that would otherwise
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   744
	 * be determined by the prefix.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   745
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   746
	 * The scope argument can take one of the following:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   747
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   748
	 * 'all' - returns 'all' and 'global' tables. No old tables are returned.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   749
	 * 'blog' - returns the blog-level tables for the queried blog.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   750
	 * 'global' - returns the global tables for the installation, returning multisite tables only if running multisite.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   751
	 * 'ms_global' - returns the multisite global tables, regardless if current installation is multisite.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   752
	 * 'old' - returns tables which are deprecated.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   753
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   754
	 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   755
	 * @uses wpdb::$tables
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   756
	 * @uses wpdb::$old_tables
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   757
	 * @uses wpdb::$global_tables
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   758
	 * @uses wpdb::$ms_global_tables
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   759
	 * @uses is_multisite()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   760
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   761
	 * @param string $scope Optional. Can be all, global, ms_global, blog, or old tables. Defaults to all.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   762
	 * @param bool $prefix Optional. Whether to include table prefixes. Default true. If blog
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   763
	 * 	prefix is requested, then the custom users and usermeta tables will be mapped.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   764
	 * @param int $blog_id Optional. The blog_id to prefix. Defaults to wpdb::$blogid. Used only when prefix is requested.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   765
	 * @return array Table names. When a prefix is requested, the key is the unprefixed table name.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   766
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   767
	function tables( $scope = 'all', $prefix = true, $blog_id = 0 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   768
		switch ( $scope ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   769
			case 'all' :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   770
				$tables = array_merge( $this->global_tables, $this->tables );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   771
				if ( is_multisite() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   772
					$tables = array_merge( $tables, $this->ms_global_tables );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   773
				break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   774
			case 'blog' :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   775
				$tables = $this->tables;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   776
				break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   777
			case 'global' :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   778
				$tables = $this->global_tables;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   779
				if ( is_multisite() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   780
					$tables = array_merge( $tables, $this->ms_global_tables );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   781
				break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   782
			case 'ms_global' :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   783
				$tables = $this->ms_global_tables;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   784
				break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   785
			case 'old' :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   786
				$tables = $this->old_tables;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   787
				break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   788
			default :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   789
				return array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   790
				break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   791
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   792
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   793
		if ( $prefix ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   794
			if ( ! $blog_id )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   795
				$blog_id = $this->blogid;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   796
			$blog_prefix = $this->get_blog_prefix( $blog_id );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   797
			$base_prefix = $this->base_prefix;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   798
			$global_tables = array_merge( $this->global_tables, $this->ms_global_tables );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   799
			foreach ( $tables as $k => $table ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   800
				if ( in_array( $table, $global_tables ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   801
					$tables[ $table ] = $base_prefix . $table;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   802
				else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   803
					$tables[ $table ] = $blog_prefix . $table;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   804
				unset( $tables[ $k ] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   805
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   806
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   807
			if ( isset( $tables['users'] ) && defined( 'CUSTOM_USER_TABLE' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   808
				$tables['users'] = CUSTOM_USER_TABLE;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   809
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   810
			if ( isset( $tables['usermeta'] ) && defined( 'CUSTOM_USER_META_TABLE' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   811
				$tables['usermeta'] = CUSTOM_USER_META_TABLE;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   812
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   813
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   814
		return $tables;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   815
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   816
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   817
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   818
	 * Selects a database using the current database connection.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   819
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   820
	 * The database name will be changed based on the current database
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   821
	 * connection. On failure, the execution will bail and display an DB error.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   822
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   823
	 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   824
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   825
	 * @param string $db MySQL database name
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   826
	 * @param resource $dbh Optional link identifier.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   827
	 * @return null Always null.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   828
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   829
	function select( $db, $dbh = null ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   830
		if ( is_null($dbh) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   831
			$dbh = $this->dbh;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   832
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   833
		if ( !@mysql_select_db( $db, $dbh ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   834
			$this->ready = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   835
			wp_load_translations_early();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   836
			$this->bail( sprintf( __( '<h1>Can&#8217;t select database</h1>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   837
<p>We were able to connect to the database server (which means your username and password is okay) but not able to select the <code>%1$s</code> database.</p>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   838
<ul>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   839
<li>Are you sure it exists?</li>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   840
<li>Does the user <code>%2$s</code> have permission to use the <code>%1$s</code> database?</li>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   841
<li>On some systems the name of your database is prefixed with your username, so it would be like <code>username_%1$s</code>. Could that be the problem?</li>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   842
</ul>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   843
<p>If you don\'t know how to set up a database you should <strong>contact your host</strong>. If all else fails you may find help at the <a href="http://wordpress.org/support/">WordPress Support Forums</a>.</p>' ), htmlspecialchars( $db, ENT_QUOTES ), htmlspecialchars( $this->dbuser, ENT_QUOTES ) ), 'db_select_fail' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   844
			return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   845
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   846
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   847
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   848
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   849
	 * Do not use, deprecated.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   850
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   851
	 * Use esc_sql() or wpdb::prepare() instead.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   852
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   853
	 * @since 2.8.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   854
	 * @deprecated 3.6.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   855
	 * @see wpdb::prepare
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   856
	 * @see esc_sql()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   857
	 * @access private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   858
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   859
	 * @param string $string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   860
	 * @return string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   861
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   862
	function _weak_escape( $string ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   863
		if ( func_num_args() === 1 && function_exists( '_deprecated_function' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   864
			_deprecated_function( __METHOD__, '3.6', 'wpdb::prepare() or esc_sql()' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   865
		return addslashes( $string );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   866
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   867
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   868
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   869
	 * Real escape, using mysql_real_escape_string()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   870
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   871
	 * @see mysql_real_escape_string()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   872
	 * @since 2.8.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   873
	 * @access private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   874
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   875
	 * @param  string $string to escape
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   876
	 * @return string escaped
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   877
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   878
	function _real_escape( $string ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   879
		if ( $this->dbh )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   880
			return mysql_real_escape_string( $string, $this->dbh );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   881
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   882
		$class = get_class( $this );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   883
		_doing_it_wrong( $class, "$class must set a database connection for use with escaping.", E_USER_NOTICE );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   884
		return addslashes( $string );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   885
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   886
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   887
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   888
	 * Escape data. Works on arrays.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   889
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   890
	 * @uses wpdb::_real_escape()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   891
	 * @since  2.8.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   892
	 * @access private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   893
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   894
	 * @param  string|array $data
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   895
	 * @return string|array escaped
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   896
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   897
	function _escape( $data ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   898
		if ( is_array( $data ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   899
			foreach ( $data as $k => $v ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   900
				if ( is_array($v) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   901
					$data[$k] = $this->_escape( $v );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   902
				else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   903
					$data[$k] = $this->_real_escape( $v );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   904
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   905
		} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   906
			$data = $this->_real_escape( $data );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   907
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   908
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   909
		return $data;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   910
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   911
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   912
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   913
	 * Do not use, deprecated.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   914
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   915
	 * Use esc_sql() or wpdb::prepare() instead.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   916
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   917
	 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   918
	 * @deprecated 3.6.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   919
	 * @see wpdb::prepare()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   920
	 * @see esc_sql()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   921
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   922
	 * @param mixed $data
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   923
	 * @return mixed
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   924
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   925
	function escape( $data ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   926
		if ( func_num_args() === 1 && function_exists( '_deprecated_function' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   927
			_deprecated_function( __METHOD__, '3.6', 'wpdb::prepare() or esc_sql()' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   928
		if ( is_array( $data ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   929
			foreach ( $data as $k => $v ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   930
				if ( is_array( $v ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   931
					$data[$k] = $this->escape( $v, 'recursive' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   932
				else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   933
					$data[$k] = $this->_weak_escape( $v, 'internal' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   934
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   935
		} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   936
			$data = $this->_weak_escape( $data, 'internal' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   937
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   938
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   939
		return $data;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   940
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   941
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   942
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   943
	 * Escapes content by reference for insertion into the database, for security
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   944
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   945
	 * @uses wpdb::_real_escape()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   946
	 * @since 2.3.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   947
	 * @param string $string to escape
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   948
	 * @return void
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   949
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   950
	function escape_by_ref( &$string ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   951
		if ( ! is_float( $string ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   952
			$string = $this->_real_escape( $string );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   953
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   954
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   955
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   956
	 * Prepares a SQL query for safe execution. Uses sprintf()-like syntax.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   957
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   958
	 * The following directives can be used in the query format string:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   959
	 *   %d (integer)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   960
	 *   %f (float)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   961
	 *   %s (string)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   962
	 *   %% (literal percentage sign - no argument needed)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   963
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   964
	 * All of %d, %f, and %s are to be left unquoted in the query string and they need an argument passed for them.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   965
	 * Literals (%) as parts of the query must be properly written as %%.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   966
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   967
	 * This function only supports a small subset of the sprintf syntax; it only supports %d (integer), %f (float), and %s (string).
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   968
	 * Does not support sign, padding, alignment, width or precision specifiers.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   969
	 * Does not support argument numbering/swapping.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   970
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   971
	 * May be called like {@link http://php.net/sprintf sprintf()} or like {@link http://php.net/vsprintf vsprintf()}.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   972
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   973
	 * Both %d and %s should be left unquoted in the query string.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   974
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   975
	 * <code>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   976
	 * wpdb::prepare( "SELECT * FROM `table` WHERE `column` = %s AND `field` = %d", 'foo', 1337 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   977
	 * wpdb::prepare( "SELECT DATE_FORMAT(`field`, '%%c') FROM `table` WHERE `column` = %s", 'foo' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   978
	 * </code>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   979
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   980
	 * @link http://php.net/sprintf Description of syntax.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   981
	 * @since 2.3.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   982
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   983
	 * @param string $query Query statement with sprintf()-like placeholders
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   984
	 * @param array|mixed $args The array of variables to substitute into the query's placeholders if being called like
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   985
	 * 	{@link http://php.net/vsprintf vsprintf()}, or the first variable to substitute into the query's placeholders if
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   986
	 * 	being called like {@link http://php.net/sprintf sprintf()}.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   987
	 * @param mixed $args,... further variables to substitute into the query's placeholders if being called like
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   988
	 * 	{@link http://php.net/sprintf sprintf()}.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   989
	 * @return null|false|string Sanitized query string, null if there is no query, false if there is an error and string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   990
	 * 	if there was something to prepare
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   991
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   992
	function prepare( $query, $args ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   993
		if ( is_null( $query ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   994
			return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   995
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   996
		$args = func_get_args();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   997
		array_shift( $args );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   998
		// If args were passed as an array (as in vsprintf), move them up
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   999
		if ( isset( $args[0] ) && is_array($args[0]) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1000
			$args = $args[0];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1001
		$query = str_replace( "'%s'", '%s', $query ); // in case someone mistakenly already singlequoted it
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1002
		$query = str_replace( '"%s"', '%s', $query ); // doublequote unquoting
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1003
		$query = preg_replace( '|(?<!%)%f|' , '%F', $query ); // Force floats to be locale unaware
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1004
		$query = preg_replace( '|(?<!%)%s|', "'%s'", $query ); // quote the strings, avoiding escaped strings like %%s
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1005
		array_walk( $args, array( $this, 'escape_by_ref' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1006
		return @vsprintf( $query, $args );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1007
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1008
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1009
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1010
	 * Print SQL/DB error.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1011
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1012
	 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1013
	 * @global array $EZSQL_ERROR Stores error information of query and error string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1014
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1015
	 * @param string $str The error to display
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1016
	 * @return bool False if the showing of errors is disabled.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1017
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1018
	function print_error( $str = '' ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1019
		global $EZSQL_ERROR;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1020
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1021
		if ( !$str )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1022
			$str = mysql_error( $this->dbh );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1023
		$EZSQL_ERROR[] = array( 'query' => $this->last_query, 'error_str' => $str );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1024
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1025
		if ( $this->suppress_errors )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1026
			return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1027
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1028
		wp_load_translations_early();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1029
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1030
		if ( $caller = $this->get_caller() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1031
			$error_str = sprintf( __( 'WordPress database error %1$s for query %2$s made by %3$s' ), $str, $this->last_query, $caller );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1032
		else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1033
			$error_str = sprintf( __( 'WordPress database error %1$s for query %2$s' ), $str, $this->last_query );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1034
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1035
		error_log( $error_str );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1036
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1037
		// Are we showing errors?
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1038
		if ( ! $this->show_errors )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1039
			return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1040
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1041
		// If there is an error then take note of it
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1042
		if ( is_multisite() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1043
			$msg = "WordPress database error: [$str]\n{$this->last_query}\n";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1044
			if ( defined( 'ERRORLOGFILE' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1045
				error_log( $msg, 3, ERRORLOGFILE );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1046
			if ( defined( 'DIEONDBERROR' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1047
				wp_die( $msg );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1048
		} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1049
			$str   = htmlspecialchars( $str, ENT_QUOTES );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1050
			$query = htmlspecialchars( $this->last_query, ENT_QUOTES );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1051
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1052
			print "<div id='error'>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1053
			<p class='wpdberror'><strong>WordPress database error:</strong> [$str]<br />
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1054
			<code>$query</code></p>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1055
			</div>";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1056
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1057
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1058
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1059
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1060
	 * Enables showing of database errors.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1061
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1062
	 * This function should be used only to enable showing of errors.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1063
	 * wpdb::hide_errors() should be used instead for hiding of errors. However,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1064
	 * this function can be used to enable and disable showing of database
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1065
	 * errors.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1066
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1067
	 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1068
	 * @see wpdb::hide_errors()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1069
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1070
	 * @param bool $show Whether to show or hide errors
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1071
	 * @return bool Old value for showing errors.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1072
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1073
	function show_errors( $show = true ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1074
		$errors = $this->show_errors;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1075
		$this->show_errors = $show;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1076
		return $errors;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1077
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1078
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1079
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1080
	 * Disables showing of database errors.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1081
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1082
	 * By default database errors are not shown.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1083
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1084
	 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1085
	 * @see wpdb::show_errors()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1086
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1087
	 * @return bool Whether showing of errors was active
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1088
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1089
	function hide_errors() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1090
		$show = $this->show_errors;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1091
		$this->show_errors = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1092
		return $show;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1093
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1094
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1095
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1096
	 * Whether to suppress database errors.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1097
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1098
	 * By default database errors are suppressed, with a simple
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1099
	 * call to this function they can be enabled.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1100
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1101
	 * @since 2.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1102
	 * @see wpdb::hide_errors()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1103
	 * @param bool $suppress Optional. New value. Defaults to true.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1104
	 * @return bool Old value
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1105
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1106
	function suppress_errors( $suppress = true ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1107
		$errors = $this->suppress_errors;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1108
		$this->suppress_errors = (bool) $suppress;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1109
		return $errors;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1110
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1111
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1112
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1113
	 * Kill cached query results.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1114
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1115
	 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1116
	 * @return void
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1117
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1118
	function flush() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1119
		$this->last_result = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1120
		$this->col_info    = null;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1121
		$this->last_query  = null;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1122
		$this->rows_affected = $this->num_rows = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1123
		$this->last_error  = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1124
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1125
		if ( is_resource( $this->result ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1126
			mysql_free_result( $this->result );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1127
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1128
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1129
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1130
	 * Connect to and select database
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1131
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1132
	 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1133
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1134
	function db_connect() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1135
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1136
		$this->is_mysql = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1137
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1138
		$new_link = defined( 'MYSQL_NEW_LINK' ) ? MYSQL_NEW_LINK : true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1139
		$client_flags = defined( 'MYSQL_CLIENT_FLAGS' ) ? MYSQL_CLIENT_FLAGS : 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1140
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1141
		if ( WP_DEBUG ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1142
			$this->dbh = mysql_connect( $this->dbhost, $this->dbuser, $this->dbpassword, $new_link, $client_flags );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1143
		} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1144
			$this->dbh = @mysql_connect( $this->dbhost, $this->dbuser, $this->dbpassword, $new_link, $client_flags );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1145
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1146
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1147
		if ( !$this->dbh ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1148
			wp_load_translations_early();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1149
			$this->bail( sprintf( __( "
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1150
<h1>Error establishing a database connection</h1>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1151
<p>This either means that the username and password information in your <code>wp-config.php</code> file is incorrect or we can't contact the database server at <code>%s</code>. This could mean your host's database server is down.</p>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1152
<ul>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1153
	<li>Are you sure you have the correct username and password?</li>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1154
	<li>Are you sure that you have typed the correct hostname?</li>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1155
	<li>Are you sure that the database server is running?</li>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1156
</ul>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1157
<p>If you're unsure what these terms mean you should probably contact your host. If you still need help you can always visit the <a href='http://wordpress.org/support/'>WordPress Support Forums</a>.</p>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1158
" ), htmlspecialchars( $this->dbhost, ENT_QUOTES ) ), 'db_connect_fail' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1159
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1160
			return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1161
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1162
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1163
		$this->set_charset( $this->dbh );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1164
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1165
		$this->ready = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1166
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1167
		$this->select( $this->dbname, $this->dbh );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1168
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1169
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1170
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1171
	 * Perform a MySQL database query, using current database connection.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1172
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1173
	 * More information can be found on the codex page.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1174
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1175
	 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1176
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1177
	 * @param string $query Database query
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1178
	 * @return int|false Number of rows affected/selected or false on error
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1179
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1180
	function query( $query ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1181
		if ( ! $this->ready )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1182
			return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1183
		/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1184
		 * Filter the database query.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1185
		 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1186
		 * Some queries are made before the plugins have been loaded, and thus cannot be filtered with this method.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1187
		 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1188
		 * @since 2.1.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1189
		 * @param string $query Database query.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1190
		 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1191
		$query = apply_filters( 'query', $query );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1192
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1193
		$return_val = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1194
		$this->flush();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1195
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1196
		// Log how the function was called
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1197
		$this->func_call = "\$db->query(\"$query\")";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1198
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1199
		// Keep track of the last query for debug..
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1200
		$this->last_query = $query;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1201
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1202
		if ( defined( 'SAVEQUERIES' ) && SAVEQUERIES )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1203
			$this->timer_start();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1204
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1205
		$this->result = @mysql_query( $query, $this->dbh );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1206
		$this->num_queries++;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1207
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1208
		if ( defined( 'SAVEQUERIES' ) && SAVEQUERIES )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1209
			$this->queries[] = array( $query, $this->timer_stop(), $this->get_caller() );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1210
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1211
		// If there is an error then take note of it..
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1212
		if ( $this->last_error = mysql_error( $this->dbh ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1213
			// Clear insert_id on a subsequent failed insert.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1214
			if ( $this->insert_id && preg_match( '/^\s*(insert|replace)\s/i', $query ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1215
				$this->insert_id = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1216
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1217
			$this->print_error();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1218
			return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1219
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1220
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1221
		if ( preg_match( '/^\s*(create|alter|truncate|drop)\s/i', $query ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1222
			$return_val = $this->result;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1223
		} elseif ( preg_match( '/^\s*(insert|delete|update|replace)\s/i', $query ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1224
			$this->rows_affected = mysql_affected_rows( $this->dbh );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1225
			// Take note of the insert_id
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1226
			if ( preg_match( '/^\s*(insert|replace)\s/i', $query ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1227
				$this->insert_id = mysql_insert_id($this->dbh);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1228
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1229
			// Return number of rows affected
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1230
			$return_val = $this->rows_affected;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1231
		} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1232
			$num_rows = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1233
			while ( $row = @mysql_fetch_object( $this->result ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1234
				$this->last_result[$num_rows] = $row;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1235
				$num_rows++;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1236
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1237
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1238
			// Log number of rows the query returned
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1239
			// and return number of rows selected
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1240
			$this->num_rows = $num_rows;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1241
			$return_val     = $num_rows;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1242
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1243
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1244
		return $return_val;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1245
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1246
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1247
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1248
	 * Insert a row into a table.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1249
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1250
	 * <code>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1251
	 * wpdb::insert( 'table', array( 'column' => 'foo', 'field' => 'bar' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1252
	 * wpdb::insert( 'table', array( 'column' => 'foo', 'field' => 1337 ), array( '%s', '%d' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1253
	 * </code>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1254
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1255
	 * @since 2.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1256
	 * @see wpdb::prepare()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1257
	 * @see wpdb::$field_types
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1258
	 * @see wp_set_wpdb_vars()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1259
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1260
	 * @param string $table table name
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1261
	 * @param array $data Data to insert (in column => value pairs). Both $data columns and $data values should be "raw" (neither should be SQL escaped).
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1262
	 * @param array|string $format Optional. An array of formats to be mapped to each of the value in $data. If string, that format will be used for all of the values in $data.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1263
	 * 	A format is one of '%d', '%f', '%s' (integer, float, string). If omitted, all values in $data will be treated as strings unless otherwise specified in wpdb::$field_types.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1264
	 * @return int|false The number of rows inserted, or false on error.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1265
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1266
	function insert( $table, $data, $format = null ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1267
		return $this->_insert_replace_helper( $table, $data, $format, 'INSERT' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1268
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1269
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1270
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1271
	 * Replace a row into a table.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1272
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1273
	 * <code>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1274
	 * wpdb::replace( 'table', array( 'column' => 'foo', 'field' => 'bar' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1275
	 * wpdb::replace( 'table', array( 'column' => 'foo', 'field' => 1337 ), array( '%s', '%d' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1276
	 * </code>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1277
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1278
	 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1279
	 * @see wpdb::prepare()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1280
	 * @see wpdb::$field_types
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1281
	 * @see wp_set_wpdb_vars()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1282
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1283
	 * @param string $table table name
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1284
	 * @param array $data Data to insert (in column => value pairs). Both $data columns and $data values should be "raw" (neither should be SQL escaped).
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1285
	 * @param array|string $format Optional. An array of formats to be mapped to each of the value in $data. If string, that format will be used for all of the values in $data.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1286
	 * 	A format is one of '%d', '%f', '%s' (integer, float, string). If omitted, all values in $data will be treated as strings unless otherwise specified in wpdb::$field_types.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1287
	 * @return int|false The number of rows affected, or false on error.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1288
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1289
	function replace( $table, $data, $format = null ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1290
		return $this->_insert_replace_helper( $table, $data, $format, 'REPLACE' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1291
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1292
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1293
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1294
	 * Helper function for insert and replace.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1295
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1296
	 * Runs an insert or replace query based on $type argument.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1297
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1298
	 * @access private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1299
	 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1300
	 * @see wpdb::prepare()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1301
	 * @see wpdb::$field_types
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1302
	 * @see wp_set_wpdb_vars()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1303
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1304
	 * @param string $table table name
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1305
	 * @param array $data Data to insert (in column => value pairs). Both $data columns and $data values should be "raw" (neither should be SQL escaped).
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1306
	 * @param array|string $format Optional. An array of formats to be mapped to each of the value in $data. If string, that format will be used for all of the values in $data.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1307
	 * 	A format is one of '%d', '%f', '%s' (integer, float, string). If omitted, all values in $data will be treated as strings unless otherwise specified in wpdb::$field_types.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1308
	 * @param string $type Optional. What type of operation is this? INSERT or REPLACE. Defaults to INSERT.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1309
	 * @return int|false The number of rows affected, or false on error.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1310
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1311
	function _insert_replace_helper( $table, $data, $format = null, $type = 'INSERT' ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1312
		if ( ! in_array( strtoupper( $type ), array( 'REPLACE', 'INSERT' ) ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1313
			return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1314
		$this->insert_id = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1315
		$formats = $format = (array) $format;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1316
		$fields = array_keys( $data );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1317
		$formatted_fields = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1318
		foreach ( $fields as $field ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1319
			if ( !empty( $format ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1320
				$form = ( $form = array_shift( $formats ) ) ? $form : $format[0];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1321
			elseif ( isset( $this->field_types[$field] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1322
				$form = $this->field_types[$field];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1323
			else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1324
				$form = '%s';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1325
			$formatted_fields[] = $form;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1326
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1327
		$sql = "{$type} INTO `$table` (`" . implode( '`,`', $fields ) . "`) VALUES (" . implode( ",", $formatted_fields ) . ")";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1328
		return $this->query( $this->prepare( $sql, $data ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1329
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1330
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1331
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1332
	 * Update a row in the table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1333
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1334
	 * <code>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1335
	 * wpdb::update( 'table', array( 'column' => 'foo', 'field' => 'bar' ), array( 'ID' => 1 ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1336
	 * wpdb::update( 'table', array( 'column' => 'foo', 'field' => 1337 ), array( 'ID' => 1 ), array( '%s', '%d' ), array( '%d' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1337
	 * </code>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1338
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1339
	 * @since 2.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1340
	 * @see wpdb::prepare()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1341
	 * @see wpdb::$field_types
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1342
	 * @see wp_set_wpdb_vars()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1343
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1344
	 * @param string $table table name
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1345
	 * @param array $data Data to update (in column => value pairs). Both $data columns and $data values should be "raw" (neither should be SQL escaped).
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1346
	 * @param array $where A named array of WHERE clauses (in column => value pairs). Multiple clauses will be joined with ANDs. Both $where columns and $where values should be "raw".
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1347
	 * @param array|string $format Optional. An array of formats to be mapped to each of the values in $data. If string, that format will be used for all of the values in $data.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1348
	 * 	A format is one of '%d', '%f', '%s' (integer, float, string). If omitted, all values in $data will be treated as strings unless otherwise specified in wpdb::$field_types.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1349
	 * @param array|string $where_format Optional. An array of formats to be mapped to each of the values in $where. If string, that format will be used for all of the items in $where. A format is one of '%d', '%f', '%s' (integer, float, string). If omitted, all values in $where will be treated as strings.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1350
	 * @return int|false The number of rows updated, or false on error.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1351
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1352
	function update( $table, $data, $where, $format = null, $where_format = null ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1353
		if ( ! is_array( $data ) || ! is_array( $where ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1354
			return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1355
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1356
		$formats = $format = (array) $format;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1357
		$bits = $wheres = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1358
		foreach ( (array) array_keys( $data ) as $field ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1359
			if ( !empty( $format ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1360
				$form = ( $form = array_shift( $formats ) ) ? $form : $format[0];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1361
			elseif ( isset($this->field_types[$field]) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1362
				$form = $this->field_types[$field];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1363
			else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1364
				$form = '%s';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1365
			$bits[] = "`$field` = {$form}";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1366
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1367
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1368
		$where_formats = $where_format = (array) $where_format;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1369
		foreach ( (array) array_keys( $where ) as $field ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1370
			if ( !empty( $where_format ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1371
				$form = ( $form = array_shift( $where_formats ) ) ? $form : $where_format[0];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1372
			elseif ( isset( $this->field_types[$field] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1373
				$form = $this->field_types[$field];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1374
			else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1375
				$form = '%s';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1376
			$wheres[] = "`$field` = {$form}";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1377
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1378
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1379
		$sql = "UPDATE `$table` SET " . implode( ', ', $bits ) . ' WHERE ' . implode( ' AND ', $wheres );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1380
		return $this->query( $this->prepare( $sql, array_merge( array_values( $data ), array_values( $where ) ) ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1381
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1382
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1383
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1384
	 * Delete a row in the table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1385
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1386
	 * <code>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1387
	 * wpdb::delete( 'table', array( 'ID' => 1 ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1388
	 * wpdb::delete( 'table', array( 'ID' => 1 ), array( '%d' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1389
	 * </code>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1390
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1391
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1392
	 * @see wpdb::prepare()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1393
	 * @see wpdb::$field_types
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1394
	 * @see wp_set_wpdb_vars()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1395
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1396
	 * @param string $table table name
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1397
	 * @param array $where A named array of WHERE clauses (in column => value pairs). Multiple clauses will be joined with ANDs. Both $where columns and $where values should be "raw".
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1398
	 * @param array|string $where_format Optional. An array of formats to be mapped to each of the values in $where. If string, that format will be used for all of the items in $where. A format is one of '%d', '%f', '%s' (integer, float, string). If omitted, all values in $where will be treated as strings unless otherwise specified in wpdb::$field_types.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1399
	 * @return int|false The number of rows updated, or false on error.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1400
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1401
	function delete( $table, $where, $where_format = null ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1402
		if ( ! is_array( $where ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1403
			return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1404
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1405
		$bits = $wheres = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1406
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1407
		$where_formats = $where_format = (array) $where_format;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1408
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1409
		foreach ( array_keys( $where ) as $field ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1410
			if ( !empty( $where_format ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1411
				$form = ( $form = array_shift( $where_formats ) ) ? $form : $where_format[0];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1412
			} elseif ( isset( $this->field_types[ $field ] ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1413
				$form = $this->field_types[ $field ];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1414
			} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1415
				$form = '%s';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1416
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1417
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1418
			$wheres[] = "$field = $form";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1419
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1420
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1421
		$sql = "DELETE FROM $table WHERE " . implode( ' AND ', $wheres );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1422
		return $this->query( $this->prepare( $sql, $where ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1423
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1424
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1425
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1426
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1427
	 * Retrieve one variable from the database.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1428
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1429
	 * Executes a SQL query and returns the value from the SQL result.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1430
	 * If the SQL result contains more than one column and/or more than one row, this function returns the value in the column and row specified.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1431
	 * If $query is null, this function returns the value in the specified column and row from the previous SQL result.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1432
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1433
	 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1434
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1435
	 * @param string|null $query Optional. SQL query. Defaults to null, use the result from the previous query.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1436
	 * @param int $x Optional. Column of value to return. Indexed from 0.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1437
	 * @param int $y Optional. Row of value to return. Indexed from 0.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1438
	 * @return string|null Database query result (as string), or null on failure
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1439
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1440
	function get_var( $query = null, $x = 0, $y = 0 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1441
		$this->func_call = "\$db->get_var(\"$query\", $x, $y)";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1442
		if ( $query )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1443
			$this->query( $query );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1444
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1445
		// Extract var out of cached results based x,y vals
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1446
		if ( !empty( $this->last_result[$y] ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1447
			$values = array_values( get_object_vars( $this->last_result[$y] ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1448
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1449
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1450
		// If there is a value return it else return null
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1451
		return ( isset( $values[$x] ) && $values[$x] !== '' ) ? $values[$x] : null;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1452
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1453
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1454
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1455
	 * Retrieve one row from the database.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1456
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1457
	 * Executes a SQL query and returns the row from the SQL result.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1458
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1459
	 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1460
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1461
	 * @param string|null $query SQL query.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1462
	 * @param string $output Optional. one of ARRAY_A | ARRAY_N | OBJECT constants. Return an associative array (column => value, ...),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1463
	 * 	a numerically indexed array (0 => value, ...) or an object ( ->column = value ), respectively.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1464
	 * @param int $y Optional. Row to return. Indexed from 0.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1465
	 * @return mixed Database query result in format specified by $output or null on failure
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1466
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1467
	function get_row( $query = null, $output = OBJECT, $y = 0 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1468
		$this->func_call = "\$db->get_row(\"$query\",$output,$y)";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1469
		if ( $query )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1470
			$this->query( $query );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1471
		else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1472
			return null;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1473
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1474
		if ( !isset( $this->last_result[$y] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1475
			return null;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1476
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1477
		if ( $output == OBJECT ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1478
			return $this->last_result[$y] ? $this->last_result[$y] : null;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1479
		} elseif ( $output == ARRAY_A ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1480
			return $this->last_result[$y] ? get_object_vars( $this->last_result[$y] ) : null;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1481
		} elseif ( $output == ARRAY_N ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1482
			return $this->last_result[$y] ? array_values( get_object_vars( $this->last_result[$y] ) ) : null;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1483
		} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1484
			$this->print_error( " \$db->get_row(string query, output type, int offset) -- Output type must be one of: OBJECT, ARRAY_A, ARRAY_N" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1485
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1486
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1487
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1488
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1489
	 * Retrieve one column from the database.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1490
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1491
	 * Executes a SQL query and returns the column from the SQL result.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1492
	 * If the SQL result contains more than one column, this function returns the column specified.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1493
	 * If $query is null, this function returns the specified column from the previous SQL result.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1494
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1495
	 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1496
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1497
	 * @param string|null $query Optional. SQL query. Defaults to previous query.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1498
	 * @param int $x Optional. Column to return. Indexed from 0.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1499
	 * @return array Database query result. Array indexed from 0 by SQL result row number.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1500
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1501
	function get_col( $query = null , $x = 0 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1502
		if ( $query )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1503
			$this->query( $query );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1504
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1505
		$new_array = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1506
		// Extract the column values
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1507
		for ( $i = 0, $j = count( $this->last_result ); $i < $j; $i++ ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1508
			$new_array[$i] = $this->get_var( null, $x, $i );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1509
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1510
		return $new_array;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1511
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1512
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1513
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1514
	 * Retrieve an entire SQL result set from the database (i.e., many rows)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1515
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1516
	 * Executes a SQL query and returns the entire SQL result.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1517
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1518
	 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1519
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1520
	 * @param string $query SQL query.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1521
	 * @param string $output Optional. Any of ARRAY_A | ARRAY_N | OBJECT | OBJECT_K constants. With one of the first three, return an array of rows indexed from 0 by SQL result row number.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1522
	 * 	Each row is an associative array (column => value, ...), a numerically indexed array (0 => value, ...), or an object. ( ->column = value ), respectively.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1523
	 * 	With OBJECT_K, return an associative array of row objects keyed by the value of each row's first column's value. Duplicate keys are discarded.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1524
	 * @return mixed Database query results
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1525
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1526
	function get_results( $query = null, $output = OBJECT ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1527
		$this->func_call = "\$db->get_results(\"$query\", $output)";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1528
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1529
		if ( $query )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1530
			$this->query( $query );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1531
		else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1532
			return null;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1533
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1534
		$new_array = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1535
		if ( $output == OBJECT ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1536
			// Return an integer-keyed array of row objects
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1537
			return $this->last_result;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1538
		} elseif ( $output == OBJECT_K ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1539
			// Return an array of row objects with keys from column 1
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1540
			// (Duplicates are discarded)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1541
			foreach ( $this->last_result as $row ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1542
				$var_by_ref = get_object_vars( $row );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1543
				$key = array_shift( $var_by_ref );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1544
				if ( ! isset( $new_array[ $key ] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1545
					$new_array[ $key ] = $row;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1546
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1547
			return $new_array;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1548
		} elseif ( $output == ARRAY_A || $output == ARRAY_N ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1549
			// Return an integer-keyed array of...
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1550
			if ( $this->last_result ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1551
				foreach( (array) $this->last_result as $row ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1552
					if ( $output == ARRAY_N ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1553
						// ...integer-keyed row arrays
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1554
						$new_array[] = array_values( get_object_vars( $row ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1555
					} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1556
						// ...column name-keyed row arrays
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1557
						$new_array[] = get_object_vars( $row );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1558
					}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1559
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1560
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1561
			return $new_array;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1562
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1563
		return null;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1564
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1565
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1566
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1567
	 * Load the column metadata from the last query.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1568
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1569
	 * @since 3.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1570
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1571
	 * @access protected
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1572
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1573
	protected function load_col_info() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1574
		if ( $this->col_info )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1575
			return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1576
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1577
		for ( $i = 0; $i < @mysql_num_fields( $this->result ); $i++ ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1578
			$this->col_info[ $i ] = @mysql_fetch_field( $this->result, $i );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1579
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1580
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1581
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1582
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1583
	 * Retrieve column metadata from the last query.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1584
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1585
	 * @since 0.71
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1586
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1587
	 * @param string $info_type Optional. Type one of name, table, def, max_length, not_null, primary_key, multiple_key, unique_key, numeric, blob, type, unsigned, zerofill
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1588
	 * @param int $col_offset Optional. 0: col name. 1: which table the col's in. 2: col's max length. 3: if the col is numeric. 4: col's type
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1589
	 * @return mixed Column Results
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1590
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1591
	function get_col_info( $info_type = 'name', $col_offset = -1 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1592
		$this->load_col_info();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1593
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1594
		if ( $this->col_info ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1595
			if ( $col_offset == -1 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1596
				$i = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1597
				$new_array = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1598
				foreach( (array) $this->col_info as $col ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1599
					$new_array[$i] = $col->{$info_type};
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1600
					$i++;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1601
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1602
				return $new_array;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1603
			} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1604
				return $this->col_info[$col_offset]->{$info_type};
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1605
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1606
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1607
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1608
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1609
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1610
	 * Starts the timer, for debugging purposes.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1611
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1612
	 * @since 1.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1613
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1614
	 * @return true
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1615
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1616
	function timer_start() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1617
		$this->time_start = microtime( true );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1618
		return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1619
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1620
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1621
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1622
	 * Stops the debugging timer.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1623
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1624
	 * @since 1.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1625
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1626
	 * @return float Total time spent on the query, in seconds
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1627
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1628
	function timer_stop() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1629
		return ( microtime( true ) - $this->time_start );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1630
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1631
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1632
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1633
	 * Wraps errors in a nice header and footer and dies.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1634
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1635
	 * Will not die if wpdb::$show_errors is false.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1636
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1637
	 * @since 1.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1638
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1639
	 * @param string $message The Error message
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1640
	 * @param string $error_code Optional. A Computer readable string to identify the error.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1641
	 * @return false|void
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1642
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1643
	function bail( $message, $error_code = '500' ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1644
		if ( !$this->show_errors ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1645
			if ( class_exists( 'WP_Error' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1646
				$this->error = new WP_Error($error_code, $message);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1647
			else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1648
				$this->error = $message;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1649
			return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1650
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1651
		wp_die($message);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1652
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1653
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1654
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1655
	 * Whether MySQL database is at least the required minimum version.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1656
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1657
	 * @since 2.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1658
	 * @uses $wp_version
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1659
	 * @uses $required_mysql_version
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1660
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1661
	 * @return WP_Error
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1662
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1663
	function check_database_version() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1664
		global $wp_version, $required_mysql_version;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1665
		// Make sure the server has the required MySQL version
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1666
		if ( version_compare($this->db_version(), $required_mysql_version, '<') )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1667
			return new WP_Error('database_version', sprintf( __( '<strong>ERROR</strong>: WordPress %1$s requires MySQL %2$s or higher' ), $wp_version, $required_mysql_version ));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1668
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1669
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1670
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1671
	 * Whether the database supports collation.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1672
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1673
	 * Called when WordPress is generating the table scheme.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1674
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1675
	 * @since 2.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1676
	 * @deprecated 3.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1677
	 * @deprecated Use wpdb::has_cap( 'collation' )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1678
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1679
	 * @return bool True if collation is supported, false if version does not
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1680
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1681
	function supports_collation() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1682
		_deprecated_function( __FUNCTION__, '3.5', 'wpdb::has_cap( \'collation\' )' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1683
		return $this->has_cap( 'collation' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1684
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1685
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1686
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1687
	 * The database character collate.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1688
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1689
	 * @since 3.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1690
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1691
	 * @return string The database character collate.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1692
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1693
	public function get_charset_collate() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1694
		$charset_collate = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1695
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1696
		if ( ! empty( $this->charset ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1697
			$charset_collate = "DEFAULT CHARACTER SET $this->charset";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1698
		if ( ! empty( $this->collate ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1699
			$charset_collate .= " COLLATE $this->collate";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1700
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1701
		return $charset_collate;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1702
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1703
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1704
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1705
	 * Determine if a database supports a particular feature.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1706
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1707
	 * @since 2.7.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1708
	 * @see wpdb::db_version()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1709
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1710
	 * @param string $db_cap The feature to check for.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1711
	 * @return bool
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1712
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1713
	function has_cap( $db_cap ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1714
		$version = $this->db_version();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1715
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1716
		switch ( strtolower( $db_cap ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1717
			case 'collation' :    // @since 2.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1718
			case 'group_concat' : // @since 2.7.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1719
			case 'subqueries' :   // @since 2.7.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1720
				return version_compare( $version, '4.1', '>=' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1721
			case 'set_charset' :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1722
				return version_compare( $version, '5.0.7', '>=' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1723
		};
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1724
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1725
		return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1726
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1727
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1728
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1729
	 * Retrieve the name of the function that called wpdb.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1730
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1731
	 * Searches up the list of functions until it reaches
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1732
	 * the one that would most logically had called this method.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1733
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1734
	 * @since 2.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1735
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1736
	 * @return string The name of the calling function
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1737
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1738
	function get_caller() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1739
		return wp_debug_backtrace_summary( __CLASS__ );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1740
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1741
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1742
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1743
	 * The database version number.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1744
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1745
	 * @since 2.7.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1746
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1747
	 * @return false|string false on failure, version number on success
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1748
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1749
	function db_version() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1750
		return preg_replace( '/[^0-9.].*/', '', mysql_get_server_info( $this->dbh ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1751
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1752
}