私は実行したSQLクエリをその直後に出力できる方法を探しています。
$wpdb->query(
$wpdb->prepare("INSERT
INTO tbl_watchprosite SET
keywords=%s,url_to_post=%s,description=%s,
date_captured=%s,crawl_id=%d,
image_main=%s,images=%s,brand=%s,
series=%s,model=%s,condition=%s,box=%s,
papers=%s,year=%s,case_size=%s,status=%s,listed=%s,
asking_price=%s,retail_price=%s,payment_info=%s,forum_id=%d",
$this->getForumSettings()->search_meta,$element->href,$post_meta['description'],current_time('mysql'),$cid,$post_meta['image_main'],$images,$post_meta[0],$post_meta[1],$post_meta[2],$post_meta[3],$post_meta[4],$post_meta[5],$post_meta[6],$post_meta[7],$status,$post_meta[9],$post_meta[10],$post_meta[11],$this->getForumSettings()->ID)
);
クエリにどのような値が入力されているのかを確認できるのであれば、これは素晴らしいことです。
ありがとう
$wpdb
オブジェクトには、そのために設定されるいくつかのプロパティがあります。
// Print last SQL query string
$wpdb->last_query
// Print last SQL query result
$wpdb->last_result
// Print last SQL query Error
$wpdb->last_error
wp-config.php
にdefined( 'SAVEQUERIES', true );
を設定した場合にのみ結果が出ることに注意してください。
これをあなたのwp-config.phpに追加してください。
define('SAVEQUERIES', true);
それからあなたのテーマのフッターにこれを入れてください:
<?php
if (current_user_can('administrator')){
global $wpdb;
echo "<pre>";
print_r($wpdb->queries);
echo "</pre>";
}//Lists all the queries executed on your page
?>
また使用することができます
global $wpdb;
echo $wpdb->last_query;//lists only single query
クエリの後にクエリページで。
私は@kaiserによる最高の賛成回答が完全に正しくないことを付け加えたいと思いました:
// Print last SQL query string
$wpdb->last_query
その戻り値は _ array _ であり、文字列ではありません。最後のクエリを出力するには、こうします。
echo 'Last query: '.var_export($wpdb->last_query, TRUE);