首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >$wpdb->query() vs. $wpdb->get_results() vs.

$wpdb->query() vs. $wpdb->get_results() vs.
EN

WordPress Development用户
提问于 2019-08-02 18:38:56
回答 2查看 2.4K关注 0票数 2

我有这样的代码:

代码语言:javascript
复制
$query = "SELECT * 
            FROM $wpdb->posts
                INNER JOIN $wpdb->postmeta 
                    ON $wpdb->posts.ID = $wpdb->postmeta.post_id
                INNER JOIN $wpdb->term_relationships 
                    ON $wpdb->posts.ID = $wpdb->term_relationships.object_id
            WHERE ((post_type = 'projects') OR (post_type = 'post_cost_codes'));";

$results = $wpdb->query($query); // Takes 1.5 seconds

我也试过这个:

代码语言:javascript
复制
$query = "SELECT * 
            FROM $wpdb->posts
                INNER JOIN $wpdb->postmeta 
                    ON $wpdb->posts.ID = $wpdb->postmeta.post_id
                INNER JOIN $wpdb->term_relationships 
                    ON $wpdb->posts.ID = $wpdb->term_relationships.object_id
            WHERE ((post_type = 'projects') OR (post_type = 'post_cost_codes'));";

$results = $wpdb->get_results($query); // Still takes 1.5 seconds

但是,当我获取查询并将其放入phpmyadmin时:

代码语言:javascript
复制
(18588 total, Query took 0.0102 seconds.)
SELECT * FROM wp_dev_posts, wp_dev_postmeta, wp_dev_term_relationships WHERE ((post_type = 'projects') OR (post_type = 'post_cost_codes')) AND (wp_dev_posts.ID = wp_dev_postmeta.post_id) AND (wp_dev_posts.ID = wp_dev_term_relationships.object_id)
// Takes 0.0102 seconds

为什么这两个$wpdb方法花费这么长时间?相同的查询是复制并直接粘贴到phpmyadmin上,它需要预期的时间。

EN

回答 2

WordPress Development用户

发布于 2019-08-02 18:44:22

区别在于返回的内容。

WPDB query()方法返回用于创建、更改、截断和删除查询的true,所有其他查询的结果的整数,如果存在错误,则返回false

WPDB get_results()方法实际上返回查询的整个结果(就像在phpMyAdmin中运行查询一样)。可以将结果作为数组或对象返回,这取决于您希望如何处理结果。

票数 0
EN

WordPress Development用户

发布于 2019-08-06 21:08:58

没有多少运气,我用get_transient(.)解决了自己的问题。和set_transient(.)

注意,这是一个只使用wordpress的补丁。第一个电话让人受苦,但一旦缓存,对我来说就足够了。

在我的例子中,这是可以接受的,因为我可以将结果存储一整天。12小时对我来说也没问题。我仍然在寻找原来问题的答案,因为我很好奇到底出了什么问题。

票数 -1
EN
页面原文内容由WordPress Development提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://wordpress.stackexchange.com/questions/344261

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档