startDate
という名前のカスタムフィールドがありますが、それはいくつかのイベントでのみです。投稿リストを作成するためにpost_date
を使用することができる投稿に設定されていないのではないかと思いましたか。
// if meta_key _postmeta.startDate isn't set get the rest by posts.post_date
query_posts(
array(
array(
'posts_per_page' => 10,
'meta_key' => 'startDate',
'meta_value' => date('Y-m-d'),
'meta_compare' => '<',
'orderby' => 'meta_value',
'order' => 'ASC'
),
array(
'meta_key' => 'post_date',
'meta_value' => date('Y-m-d'),
'meta_compare' => '<'
)
)
);
SQLでそれを説明できれば、それを照会することができます。デフォルトのクエリを変更したい場所が3箇所あります。
SELECT wp_posts.*
FROM wp_posts
INNER JOIN wp_postmeta ON (wp_posts.ID = wp_postmeta.post_id)
WHERE 1=1
AND wp_posts.post_type = 'post'
AND (wp_posts.post_status = 'publish')
AND wp_postmeta.meta_key = 'startDate'
AND CAST(wp_postmeta.meta_value AS CHAR) < '2011-03-23'
GROUP BY wp_posts.ID
ORDER BY wp_postmeta.meta_value DESC
LIMIT 0, 10
Joinとwhere-clauseは、 _get_meta_sql()
関数 を介して追加されます。出力はフィルタリングされているので、フックすることができます。
add_filter( 'get_meta_sql', 'wpse12814_get_meta_sql' );
function wpse12814_get_meta_sql( $meta_sql )
{
// Move the `meta_key` comparison in the join so it can handle posts without this meta_key
$meta_sql['join'] = " LEFT JOIN wp_postmeta ON (wp_posts.ID = wp_postmeta.post_id AND wp_postmeta.meta_key = 'startDate') ";
$meta_sql['where'] = " AND (wp_postmeta.meta_value IS NULL OR wp_postmeta.meta_value < '" . date('Y-m-d') . "')";
return $meta_sql;
}
Order句はposts_orderby
によってフィルタリングされます。
add_filter( 'posts_orderby', 'wpse12814_posts_orderby' );
function wpse12814_posts_orderby( $orderby )
{
$orderby = 'COALESCE(wp_postmeta.meta_value, wp_posts.post_date) ASC';
return $orderby;
}
これにより、次のSQLクエリが得られます。
SELECT wp_posts.*
FROM wp_posts
LEFT JOIN wp_postmeta ON (wp_posts.ID = wp_postmeta.post_id AND wp_postmeta.meta_key = 'startDate')
WHERE 1=1
AND wp_posts.post_type = 'post'
AND (wp_posts.post_status = 'publish')
AND (wp_postmeta.meta_value IS NULL OR wp_postmeta.meta_value < '2011-03-23')
GROUP BY wp_posts.ID
ORDER BY COALESCE(wp_postmeta.meta_value, wp_posts.post_date) ASC
LIMIT 0, 10
あなたがあなたの質問をした後にフィルタを外すことを忘れないでください、さもなければあなたも他の質問を台無しにするでしょう。そして可能であれば 自分でquery_posts()
を呼び出すべきではありません しかし、ページの設定中にWordPressによって行われるメインのpostクエリを修正してください。
に沿って何かを試してみてください。
$postedtime = get_post_meta($post->ID, 'startDate');
if($postedtime != null){
$orderby = $postedtime;
}else{
$orderby = 'date';
}
クエリポストコールは、2つではなく1つのクエリのみを行います。いいえ、2つの別々のクエリを作成して結果を連結することはできません。
覚えておいて、あなたはここで投稿のいくつかのセットを選択し、そしてそれらを表示しています。そのセットは一度に選択されます。 2つの別々の投稿セットを取得してそれらをマージする場合は、get_postsなどを使用して自分で行う必要があります。