本文详解为何 `meta_query` 中用 `=` 匹配空字符串无法查到未填写自定义字段的 wordpress 文章,并提供标准解决方案:使用 `'compare' => 'not exists'` 精准筛选缺失元数据的条目。
在 WordPress 开发中,常需通过 WP_Query 或 get_posts() 查询“尚未填写某自定义字段”的文章(如本例中的 invoice_number)。一个常见误区是:认为只要将 value 设为空字符串 '' 并配合 'compare' => '=',就能匹配“未填发票号”的职位文章。但事实并非如此。
WordPress 的元数据(post meta)机制决定了:只有显式保存过的字段才会写入数据库;若后台从未为某篇文章保存过 invoice_number 字段,该记录根本不存在于 wp_postmeta 表中。因此,'value' => '' 实际是在查找「存在该字段且值为空字符串」的记录——这与“字段未设置”是两个完全不同的数据库状态。
✅ 正确做法是使用 'compare' => 'NOT EXISTS':
$posts = get_posts(array(
'post_type' => 'job', // 注意:建议使用单数形式(见下文说明)
'posts_per_page' => -1,
'meta_key' => 'job_date',
'orderby' => 'meta_value',
'order' => 'ASC',
'tax_query' => array(

array(
'taxonomy' => 'job_status',
'field' => 'slug',
'terms' => 'complete'
),
),
'meta_query' => array(
'relation' => 'AND',
array(
'key' => 'invoice_number',
'compare' => 'NOT EXISTS'
)
)
));? 关键要点说明:
⚠️ 补充提醒:
掌握 NOT EXISTS 的正确用法,能显著提升 WordPress 元数据查询的准确性与健壮性,是构建专业级内容管理逻辑的关键一环。