怎么优化 query_posts 获取 wordpress文章时,减少数据库查询次数?
怎么优化下面的wordpress 代码,目前它是分别查询,导致数据库查询次数过多,其实就是想实现 一次性获取数据后,循环输出 分类名称,分类下的文章篇数。
<code><?php $loop_cate_id=array(1,3,8); //指定要输出的分类id $num=10;//指定每次循环输出的文章篇数 ?> <?php foreach($loop_cate_id as $key=>$value){ ?> <?php $posts = query_posts($query_string . "&cat={$value}&orderby=date&showposts={$num}" ); ?> <h2><a href="<?php%20echo%20get_category_link(%24value);%20?>"><?php single_cat_title(); ?></a></h2> <ul> <?php while(have_posts()) : the_post(); ?> <li> <a href="<?php%20the_permalink()%20?>" rel="bookmark" title="<?php the_title(); ?>"><?php the_title(); ?></a> </li> <?php endwhile; ?> </ul> <?php }?> </code>
回复内容:
怎么优化下面的wordpress 代码,目前它是分别查询,导致数据库查询次数过多,其实就是想实现 一次性获取数据后,循环输出 分类名称,分类下的文章篇数。
<code><?php $loop_cate_id=array(1,3,8); //指定要输出的分类id $num=10;//指定每次循环输出的文章篇数 ?> <?php foreach($loop_cate_id as $key=>$value){ ?> <?php $posts = query_posts($query_string . "&cat={$value}&orderby=date&showposts={$num}" ); ?> <h2><a href="<?php%20echo%20get_category_link(%24value);%20?>"><?php single_cat_title(); ?></a></h2> <ul> <?php while(have_posts()) : the_post(); ?> <li> <a href="<?php%20the_permalink()%20?>" rel="bookmark" title="<?php the_title(); ?>"><?php the_title(); ?></a> </li> <?php endwhile; ?> </ul> <?php }?> </code>
开启缓存不就解决了?
1.现在问题就在分类太多,每次分类要查询一次,那是否可以先查找该页分类的所有数据,因为是查询所有而且你有排序跟文章数要求,这里可以与group by合用获取要求数据。(这样首页分类数据这块应该是只有一次查询)
2.然后在根据代码逻辑为其组成一个数组,数组可以参考我下面给你的格式。
<code>$postList[cate_id]['title']; $postList[cate_id]['article'][];//将文章按分类id当成键值存入数组 foreach($postList as $post) { foreach($post['article'] as $value){ } } </code>
自己顶下吧,期待有熟悉wp的小伙伴看看。
对wp不熟 也没怎么看你的代码。你可以用键值对 那样就只用写一个循环了。
先查所有分类组成键值对数组。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

有四种方法可以调整 WordPress 文章列表:使用主题选项、使用插件(如 Post Types Order、WP Post List、Boxy Stuff)、使用代码(在 functions.php 文件中添加设置)或直接修改 WordPress 数据库。

WordPress 屏蔽 IP 的插件选择至关重要。可考虑以下类型:基于 .htaccess:高效,但操作复杂;数据库操作:灵活,但效率较低;基于防火墙:安全性能高,但配置复杂;自行编写:最高控制权,但需要更多技术水平。

登录 WordPress 网站账号的步骤:访问登录页面:输入网站网址加上 "/wp-login.php"。输入用户名和密码。点击“登录”。验证两步验证(可选)。成功登录后,您将看到网站仪表盘。

在WordPress中创建自定义页头的步骤如下:编辑主题文件“header.php”。添加您的网站名称和描述。创建导航菜单。添加搜索栏。保存更改并查看您的自定义页头。

WordPress 错误解决指南:500 内部服务器错误:禁用插件或检查服务器错误日志。404 未找到页面:检查 permalink 并确保页面链接正确。白屏死机:增加服务器 PHP 内存限制。数据库连接错误:检查数据库服务器状态和 WordPress 配置。其他技巧:启用调试模式、检查错误日志和寻求支持。预防错误:定期更新 WordPress、仅安装必要插件、定期备份网站和优化网站性能。

更换 WordPress 主题头部图片的分步指南:登录 WordPress 仪表盘,导航至“外观”>“主题”。选择要编辑的主题,然后单击“自定义”。打开“主题选项”面板并寻找“网站标头”或“头部图片”选项。单击“选择图像”按钮并上传新的头部图片。裁剪图像并单击“保存并裁剪”。单击“保存并发布”按钮以更新更改。

WordPress 网站中启用评论功能:1. 登录管理面板,转到 "设置"-"讨论",勾选 "允许评论";2. 选择显示评论的位置;3. 自定义评论表单;4. 管理评论,批准、拒绝或删除;5. 使用 <?php comments_template(); ?> 标签显示评论;6. 启用嵌套评论;7. 调整评论外形;8. 使用插件和验证码防止垃圾评论;9. 鼓励用户使用 Gravatar 头像;10. 创建评论指

IIS和PHP可以兼容,通过FastCGI实现。1.IIS通过配置文件将.php文件请求转发给FastCGI模块。2.FastCGI模块启动PHP进程处理请求,提高性能和稳定性。3.实际应用中需注意配置细节、错误调试和性能优化。
