この記事は最後に更新してから1年以上経過しています。

3.6リリース直前チェック

説明

$wpdbは、WordPressのデータベースにアクセスする際に使用できる便利なオブジェクト。独自テーブルの利用やデータ検索の最適化など、標準提供される関数では実現できないことを手助けしてくれる。そんな$wpdbのescapeメソッドが3.6で非推奨(deprecated)になる。

$wpdbのescapeメソッドは、データベースの検索や更新時の文字列データをエスケープ処理(addslashes関数を呼び出して文字列中の'(シングルクォート)や"(ダブルクォート)などをスラッシュでクォートする)に使用できる。

global $wpdb;
$data = $wpdb->escape( $data );

WordPress 3.6ではこのescapeメソッドが非推奨になるわけだが、代替には$wpdbのprepareメソッドや esc_sql関数がある。まあ、もともとescapeメソッドを単独で利用していることはないだろうから、素直にprepareメソッドを利用するのが簡単だろう。

global $wpdb;
$result = $wpdb->get_results( $wpdb->prepare( "SELECT * FROM {$wpdb->postmeta} WHERE meta_value = %s", $data ) );

escapeメソッドはWordPress 0.71から提供されており、3.6で非推奨(deprecated)になる。3.6になってすぐ使えなくなるわけではないが、今後のことを考え、自身で作ったテーマやプラグインで使われていないかチェックしておこう。


最終更新 : 2013年07月26日 13:57


お勧め

utf8_uri_encode(2014年2月4日 更新)

string utf8_uri_encode( string $utf8_string [ , int $length = 0 ] )
文字列をURIエンコードする。

get_http_origin(2018年5月27日 更新)

string get_http_origin()
リクエスト元のオリジンを取得する。

tag_description(2012年1月16日 更新)

string tag_description( [ int $tag = 0 ] )
投稿タグの説明文を取得する。

is_user_admin(2011年6月23日 更新)

bool is_user_admin( )
リクエストページがユーザ管理者ページ(/wp-admin/user/内)か調べる。

get_tag_feed_link(2012年2月23日 更新)

string get_tag_feed_link( int $tag_id [ , string $feed = '' ] )
投稿タグフィードのURLを取得する。