Wordpress 获取所有以字母A开头的帖子

Wordpress 获取所有以字母A开头的帖子,wordpress,Wordpress,如何获得所有以字母A开头的POAST(在post_标题中) 我的想法是使用正则表达式,但这段代码不起作用 $my_custom_query_args = array( 'cat' => '1', 'post_type' => 'post', 'post_status' => 'publish',

如何获得所有以字母A开头的POAST(在post_标题中)

我的想法是使用正则表达式,但这段代码不起作用

$my_custom_query_args = array(

                'cat'               => '1',
                'post_type'         => 'post',
                'post_status'       => 'publish',                
                'posts_per_page'    => 25,
                'offset'            => 0, 
                'value'             => '^'.$letter.'',
                'compare'           => 'REGEXP'

);  

使用
post_其中
,此操作代码可在自定义模板中使用

add_action( 'posts_where', 'startswithaction' );
function startswithaction( $sql ){
    global $wpdb;
    $startswith = get_query_var( 'A' );

    if( $startswith ){
        $sql .= $wpdb->prepare( " AND $wpdb->posts.post_title LIKE %s ", $startswith.'%' );
    }

    return $sql;
}
或者,您可以通过SQL查询获取以字母
A
开头的所有记录,并在
WP\u query
中传递post ID

//get all post IDs for posts start with letter A, in title order,
//display posts
global $wpdb;
$first_char = 'A';
$postids = $wpdb->get_col($wpdb->prepare("
SELECT      ID
FROM        $wpdb->posts
WHERE       SUBSTR($wpdb->posts.post_title,1,1) = %s
ORDER BY    $wpdb->posts.post_title",$first_char)); 

if ($postids) {
$args=array(
  'post__in' => $postids,
  'post_type' => 'post',
  'post_status' => 'publish',
  'posts_per_page' => -1,
  'caller_get_posts'=> 1
);
$my_query = null;
$my_query = new WP_Query($args);
if( $my_query->have_posts() ) {
 echo 'List of Posts Titles beginning with the letter '. $first_char;
  while ($my_query->have_posts()) : $my_query->the_post(); ?>
    <p><a href="<?php the_permalink() ?>" rel="bookmark" title="Permanent Link to <?php the_title_attribute(); ?>"><?php the_title(); ?></a></p>
    <?php
  endwhile;
}
wp_reset_query();
}
//获取所有以字母A开头的帖子ID,按标题顺序,
//展示柱
全球$wpdb;
$first_char='A';
$postids=$wpdb->get\u col($wpdb->prepare(“
选择ID
从$wpdb->posts
其中SUBSTR($wpdb->posts.post_title,1,1)=%s
按$wpdb->posts.post_title“,$first_char”)排序;
如果($posteds){
$args=数组(
'post_uuin'=>$posteds,
“post_type”=>“post”,
“发布状态”=>“发布”,
“每页帖子数”=>-1,
“来电者获取帖子”=>1
);
$my_query=null;
$my\u query=新的WP\u查询($args);
如果($my\u query->have\u posts()){
echo“以字母开头的帖子标题列表”。$first\u char;
while($my_query->have_posts()):$my_query->the_post();?>


使用
post_其中
,此操作代码可在自定义模板中使用

add_action( 'posts_where', 'startswithaction' );
function startswithaction( $sql ){
    global $wpdb;
    $startswith = get_query_var( 'A' );

    if( $startswith ){
        $sql .= $wpdb->prepare( " AND $wpdb->posts.post_title LIKE %s ", $startswith.'%' );
    }

    return $sql;
}
或者,您可以通过SQL查询获取以字母
A
开头的所有记录,并在
WP\u query
中传递post ID

//get all post IDs for posts start with letter A, in title order,
//display posts
global $wpdb;
$first_char = 'A';
$postids = $wpdb->get_col($wpdb->prepare("
SELECT      ID
FROM        $wpdb->posts
WHERE       SUBSTR($wpdb->posts.post_title,1,1) = %s
ORDER BY    $wpdb->posts.post_title",$first_char)); 

if ($postids) {
$args=array(
  'post__in' => $postids,
  'post_type' => 'post',
  'post_status' => 'publish',
  'posts_per_page' => -1,
  'caller_get_posts'=> 1
);
$my_query = null;
$my_query = new WP_Query($args);
if( $my_query->have_posts() ) {
 echo 'List of Posts Titles beginning with the letter '. $first_char;
  while ($my_query->have_posts()) : $my_query->the_post(); ?>
    <p><a href="<?php the_permalink() ?>" rel="bookmark" title="Permanent Link to <?php the_title_attribute(); ?>"><?php the_title(); ?></a></p>
    <?php
  endwhile;
}
wp_reset_query();
}
//获取所有以字母A开头的帖子ID,按标题顺序,
//展示柱
全球$wpdb;
$first_char='A';
$postids=$wpdb->get\u col($wpdb->prepare(“
选择ID
从$wpdb->posts
其中SUBSTR($wpdb->posts.post_title,1,1)=%s
按$wpdb->posts.post_title“,$first_char”)排序;
如果($posteds){
$args=数组(
'post_uuin'=>$posteds,
“post_type”=>“post”,
“发布状态”=>“发布”,
“每页帖子数”=>-1,
“来电者获取帖子”=>1
);
$my_query=null;
$my\u query=新的WP\u查询($args);
如果($my\u query->have\u posts()){
echo“以字母开头的帖子标题列表”。$first\u char;
while($my_query->have_posts()):$my_query->the_post();?>

检查检查