php - 如何获取以给定字母开头的自定义帖子类型的帖子?

标签 php mysql wordpress

我正在寻找一种解决方案来获取自定义帖子类型的所有帖子一段时间。我找到了一个有用的答案here 。但使用该代码片段的主要问题是,我想获取特定自定义帖子类型的帖子。普通帖子是博客帖子,所以我想过滤那些普通帖子。我不太擅长mysql,所以请求解决方案。

获取给定信件的所有帖子的片段:

<?php
//get all post IDs for posts beginning with cap B, in title order,
//display posts
$first_char = 'B';

$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();  // Restore global post data stomped by the_post().
}

?>

最佳答案

您可以选择帖子类型:

$args=array(
  'post__in' => $postids,
  'post_type' => 'post',
  'post_status' => 'publish',
  'posts_per_page' => -1,
  'caller_get_posts'=> 1
);

将“post_type”值切换为您的自定义帖子类型(而不是默认的“post”)。

例如:

'post_type' => '自定义类型',

关于php - 如何获取以给定字母开头的自定义帖子类型的帖子?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31009178/

相关文章:

mysql - MySQL 中这种查询的最佳索引是什么?

wordpress - 什么是 "Enable AJAX add to cart buttons on archives"复选框?

PHP 正则表达式不工作 - 在本地服务器上返回 NULL,但在其他服务器上工作正常

mysql - 插入多行时如何使用 "ON DUPLICATE KEY UPDATE"增加 MySql 中的字段?

MYSQL/Laravel 迁移将复合键更改为自动增量

MySQL 对连接表的查询条件

javascript - jQuery:向 <a> 元素添加一个类

php - Window.open 在另一个弹出窗口中不起作用

php - 存储公式的 MySQL/PHP

php - Laravel 5.4 与外键的多对多关系