这个问题来自对post_meta表的一个慢查询:
SELECT DISTINCT meta_key FROM wp_postmeta WHERE meta_key NOT BETWEEN '_' AND '_z' HAVING meta_key NOT LIKE '\\_%' ORDER BY meta_key LIMIT 30
该查询由WordPress文章编辑器的Meta Box功能发起。
该问题的原因是MySql中普通索引的长度最长为767字节,如果使用的是utf8mb4编码的话,那么总的字符长度就是767/4,约为191,而WordPress的post_meta表的meta_key列的字符长度则是255。
所以此时因为meta_key的长度超范围,索引并未生效。解决方案可以选择把数据库编码更改为utf8或是将meta_key的长度更改为191,再或者是禁用掉Meta Box功能。文章源自玩技e族-https://www.playezu.com/501956.html
当然,提醒一句,这些更改都可能会破坏兼容性,所以更改前请务必做好测试工作。文章源自玩技e族-https://www.playezu.com/501956.html
导致性能问题的原因千奇百怪,具体情况要具体分析再针对性解决。so,本文所述方案不一定对你有用,但可提供一个思考的方向。文章源自玩技e族-https://www.playezu.com/501956.html
WordPress的文章和页面编辑窗口附带了很多功能模块(Meta Boxes),有些不常用的可以选择屏蔽掉,今天给大家分享如何通过代码屏蔽WordPress文章和页面发布页的Meta Boxes。
移除多余模块
根据个人需求,将下面的代码添加到主题的 functions.php 文件中:文章源自玩技e族-https://www.playezu.com/501956.html
//移除文章编辑界面默认的Meta模块 function remove_my_post_metaboxes() { remove_meta_box( 'authordiv','post','normal' ); // 作者模块 remove_meta_box( 'commentstatusdiv','post','normal' ); // 评论状态模块 remove_meta_box( 'commentsdiv','post','normal' ); // 评论模块 remove_meta_box( 'postcustom','post','normal' ); // 自定义字段模块 remove_meta_box( 'postexcerpt','post','normal' ); // 摘要模块 remove_meta_box( 'revisionsdiv','post','normal' ); // 修订版本模块 remove_meta_box( 'slugdiv','post','normal' ); // 别名模块 remove_meta_box( 'trackbacksdiv','post','normal' ); // 引用模块 remove_meta_box( 'categorydiv','post','normal' ); // 分类模块 remove_meta_box( 'formatdiv','post','normal' ); // 文章格式模块 remove_meta_box( 'submitdiv','post','normal' ); // 发布模块 remove_meta_box( 'tagsdiv-post_tag','post','normal' ); // 标签模块 } add_action('admin_menu','remove_my_post_metaboxes'); //移除文章特色图像模块 add_action('do_meta_boxes', 'remove_thumbnail_box'); function remove_thumbnail_box() { remove_meta_box( 'postimagediv','post','side' ); } //移除页面编辑窗口的模块 function remove_my_page_metaboxes() { remove_meta_box( 'postcustom','page','normal' ); // 自定义字段模块 remove_meta_box( 'postexcerpt','page','normal' ); // 摘要模块 remove_meta_box( 'commentstatusdiv','page','normal' ); // 评论模块 remove_meta_box( 'pageparentdiv','page','normal' ); // 页面属性模块 remove_meta_box( 'slugdiv','page','normal' ); // 别名模块 remove_meta_box( 'authordiv','page','normal' ); // 作者模块 remove_meta_box( 'submitdiv','page','normal' ); // 发布模块 } add_action('admin_menu','remove_my_page_metaboxes'); //移除页面特色图像模块 add_action('do_meta_boxes', 'remove_page_thumbnail_box'); function remove_page_thumbnail_box() { remove_meta_box( 'postimagediv','page','side' ); }
移除自定义模块
以上的代码足够移除WordPress自带的Meta模块了,如果要移除主题或插件创建的Meta模块,我们需要在浏览器中查看这个页面的源代码,找到这个模块对应的ID。从源代码可以看到,“主题自带面板”的ID是 tagsdiv-sitetag,接着在主题中通过 do_meta_boxes 这个add_action 来移除:文章源自玩技e族-https://www.playezu.com/501956.html
//移除特定模块 add_action('do_meta_boxes', 'remove_new_custom_box'); function remove_new_custom_box() { remove_meta_box( 'tagsdiv-sitetag','post','normal' ); }
如果只需要为非管理员移除Meta模块,将下面的代码添加到主题的 functions.php 文件中:
//为非管理员移除文章编辑界面默认的Meta模块 function remove_meta_boxes() { if (!current_user_can('administrator') && !current_user_can('subadmin')) { remove_meta_box( 'authordiv','post','normal' ); // 作者模块 remove_meta_box( 'commentstatusdiv','post','normal' ); // 评论状态模块 remove_meta_box( 'commentsdiv','post','normal' ); // 评论模块 remove_meta_box( 'postcustom','post','normal' ); // 自定义字段模块 remove_meta_box( 'postexcerpt','post','normal' ); // 摘要模块 remove_meta_box( 'revisionsdiv','post','normal' ); // 修订版本模块 remove_meta_box( 'slugdiv','post','normal' ); // 别名模块 remove_meta_box( 'trackbacksdiv','post','normal' ); // 引用模块 remove_meta_box( 'categorydiv','post','normal' ); // 分类模块 remove_meta_box( 'formatdiv','post','normal' ); // 文章格式模块 remove_meta_box( 'submitdiv','post','normal' ); // 发布模块 remove_meta_box( 'tagsdiv-post_tag','post','normal' ); // 标签模块 } } add_action('do_meta_boxes', 'remove_meta_boxes');文章源自玩技e族-https://www.playezu.com/501956.html文章源自玩技e族-https://www.playezu.com/501956.html
评论