
大家知道wp_postmeta表应该是WordPress网站中数据库中最大的表,如果不是,就有问题。WordPress数据库读取 wp_actionscheduler_actions 和 wp_actionscheduler_logs 表要花大量的时间,特别是一些大型的WordPress网站,文章超过十几万甚至百万的,加载速度都很慢很卡了。这里搬主题就分享一下为MySQL表添加高性能keys,加快WordPress运行速度的教程。
WordPress数据库表分析
首次安装 WordPress 时,会在数据库中创建表,例如 wp_postmeta 表:
CREATE TABLE wp_postmeta ( meta_id bigint(20) unsigned NOT NULL AUTO_INCREMENT, post_id bigint(20) unsigned NOT NULL DEFAULT '0', meta_key varchar(255) DEFAULT NULL, meta_value longtext, PRIMARY KEY (meta_id), KEY post_id (post_id), KEY meta_key (meta_key) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
问题出在哪里?
- AUTO_INCREMENT 会降低大多数查询的速度,因为必须在二级索引中查找 auto_inc ID,然后再在数据中查找所需的实际 ID。
- BIGINT 和 AUTO_INCREMENT 多次一举
- meta_key或meta_value永远不会为空
解决方案:
CREATE TABLE wp_postmeta ( post_id BIGINT UNSIGNED NOT NULL, meta_key VARCHAR(255) NOT NULL, meta_value LONGTEXT NOT NULL, PRIMARY KEY(post_id, meta_key), INDEX(meta_key) ) ENGINE=InnoDB;
在现有表上,我们可以添加与 WordPress 最常见查询相匹配的高性能键:
wp_postmeta
ALTER TABLE wp_postmeta ADD UNIQUE KEY meta_id (meta_id); ALTER TABLE wp_postmeta DROP PRIMARY KEY; ALTER TABLE wp_postmeta ADD PRIMARY KEY (post_id, meta_key, meta_id); ALTER TABLE wp_postmeta DROP KEY post_id; ALTER TABLE wp_postmeta DROP KEY meta_key; ALTER TABLE wp_postmeta ADD KEY meta_key (meta_key, post_id);
这将创建新的高性能Keys:
表 | 标准 WP keys | 新keys |
---|---|---|
wp_postmeta | meta_id: primary key post_id meta_key | post_id, meta_key, meta_id: primary key meta_id: unique key meta_key, post_id |
其他主要表也可以这样做:
wp_posts
ALTER TABLE wp_posts DROP KEY type_status_date; ALTER TABLE wp_posts ADD KEY type_status_date (post_type, post_status, post_date, post_author, ID); ALTER TABLE wp_posts DROP KEY post_author; ALTER TABLE wp_posts ADD KEY post_author (post_author, post_type, post_status, post_date, ID);
表 | 标准 WP keys | 新keys |
---|---|---|
wp_posts | post_type, post_status, post_date,ID post_author | post_type,post_status,post_date,post_author,ID post_author,post_type,post_status,post_date,ID |
wp_options
ALTER TABLE wp_options ADD UNIQUE KEY option_id (option_id); ALTER TABLE wp_options DROP PRIMARY KEY; ALTER TABLE wp_options ADD PRIMARY KEY (autoload, option_id); ALTER TABLE wp_options DROP KEY autoload;
表 | 标准 WP keys | 新keys |
---|---|---|
wp_options | option_id: primary key option_name: unique key autoload | autoload, option_id: primary key option_name: unique_key option_id: unique key |
wp_usermeta
ALTER TABLE wp_usermeta ADD UNIQUE KEY umeta_id (umeta_id); ALTER TABLE wp_usermeta DROP PRIMARY KEY; ALTER TABLE wp_usermeta ADD PRIMARY KEY (user_id, meta_key, umeta_id); ALTER TABLE wp_usermeta DROP KEY user_id; ALTER TABLE wp_usermeta DROP KEY meta_key; ALTER TABLE wp_usermeta ADD KEY meta_key (meta_key, user_id);
表 | 标准 WP keys | 新keys |
---|---|---|
wp_usermeta | umeta_id: primary key user_id meta_key | user_id, meta_key, umeta_id: primary key umeta_id: unique key meta_key, user_id |
wp_termmeta
ALTER TABLE wp_termmeta ADD UNIQUE KEY meta_id (meta_id); ALTER TABLE wp_termmeta DROP PRIMARY KEY; ALTER TABLE wp_termmeta ADD PRIMARY KEY (term_id, meta_key, meta_id); ALTER TABLE wp_termmeta DROP KEY term_id; ALTER TABLE wp_termmeta DROP KEY meta_key; ALTER TABLE wp_termmeta ADD KEY meta_key (meta_key, term_id);
表 | 标准 WP keys | 新keys |
---|---|---|
wp_termmeta | meta_id: primary key term_id meta_key | term_id, meta_key, meta_id: primary key meta_id: unique key meta_key, term_id |
这里提到的模式更改在 Index WP MySQL For Speed WordPress 插件中自动进行。
插件免费下载地址:https://wordpress.org/plugins/index-wp-mysql-for-speed/
当然,本站也分享了汉化中文版的下载,方便国人使用。
评论前必须登录!
立即登录 注册