我正在尝试获取我的一个数据库表中的记录数,其中post_id
字段等于我比较的$postID
变量。当我用{$postID}
之类的整数交换130
时,查询会按预期返回结果。但是,每当我尝试使用$postID
变量查询我的数据库时,都不会返回任何结果。我查看了$postID
包含的内容,以确保将post_id
与正确的值进行比较,并且它包含130
的整数值。
如果查询使用硬编码的130
代替$postID
,那么当我使用等同于$postID
的{{1}}时,为什么它不起作用?
130
答案 0 :(得分:4)
变量替换不会在单引号字符串中发生,请参阅Variable parsing。
我建议您使用参数化查询,而不是将有效负载数据混合到实际语句中,请参阅Protect Queries Against SQL Injection Attacks
$postLikes = $wpdb->get_col($wpdb->prepare(
'SELECT COUNT(*) FROM wp_post_likes WHERE post_id = %s',
get_the_ID()
));