Wie löst man das Problem diskontinuierlicher Artikel-IDs in WordPress? Der folgende Artikel zeigt Ihnen, wie WordPress das Problem diskontinuierlicher Artikel-IDs perfekt lösen kann. Ich hoffe, er wird Ihnen helfen!
Viele WordPress-Blogs verwenden Artikel-IDs in ihren festen Links, aber WordPress hat aus verschiedenen Gründen das Problem der diskontinuierlichen Artikel-IDs verursacht. Blogger stellen im Forum oft Fragen, um dieses Problem zu lösen, aber nur wenige können eine zufriedenstellende Antwort erhalten Antwort von ihnen.
Heute werde ich Ihnen sagen, wie Sie dieses Problem perfekt lösen können. Versionen nach WordPress 3.0 werden einen automatischen Entwurf haben Es gibt keine Möglichkeit, es zu deaktivieren. Bitte lesen Sie weiter, um zu erfahren, wie Sie das Problem der diskontinuierlichen Artikel-IDs einigermaßen lösen können.
Wenn Sie in Ihrem Permalink keine Post-ID verwenden, ist die Post-ID natürlich für Sie transparent und spielt keine Rolle. Selbst wenn die Beitrags-ID im Permalink verwendet wird und es Ihnen nicht besonders wichtig ist, ist selbst die Diskontinuität irrelevant und dieser Artikel wird für Sie nicht viel Sinn ergeben.
1. Artikelrevisionen deaktivieren
Die sogenannte Artikelrevision bedeutet, dass jedes Mal, wenn Sie einen Artikel ändern, die Artikelversion vor der Änderung automatisch für Sie gespeichert wird. Der Fachbegriff heißt Versionskontrolle, die sicherstellt, dass die In einigen Fällen kann der vorherige Inhalt wiederhergestellt werden, da unser kleiner Blog jedoch keinen großen Nutzen hat die Datenbank, was auch eines der Probleme mit diskontinuierlichen Artikel-IDs verursacht. Um Artikelrevisionen zu deaktivieren, können Sie in der Datei wp-config.php Folgendes hinzufügen:
define('WP_POST_REVISIONS', false);
Sie können auch den folgenden PHP-Code in „functions.php“ des aktuellen Themes hinzufügen:
// 禁用修订版本,2015年3月5日更新 add_filter( 'wp_revisions_to_keep', 'specs_wp_revisions_to_keep', 10, 2 ); function specs_wp_revisions_to_keep( $num, $post ) { if ( 'post_type' == $post->post_type ) $num = 0; return $num; }
2. Artikelrevisionen löschen
Nach dem Deaktivieren von Artikelrevisionen bleiben die zuvor erstellten Artikelrevisionen weiterhin in der Datenbank gespeichert. Diese sind eigentlich von geringem Nutzen und belegen die ID. Zum Löschen können Sie die folgende SQL-Anweisung in phpmyadmin ausführen (sie wirkt sich auf den angehefteten Artikel aus, verwenden Sie ihn mit Vorsicht! Und erstellen Sie ein Backup):
DELETE a,b,c FROM wp_posts a LEFT JOIN wp_term_relationships b ON (a.ID = b.object_id) LEFT JOIN wp_postmeta c ON (a.ID = c.post_id) WHERE a.post_type = 'revision';
3. Löschen Sie unnötige Anhänge
Ich glaube viele Blogger veröffentlichen Artikel. Einige Anhänge werden gleichzeitig hochgeladen/eingefügt, z. B. Bilder, Videos, Musik usw. Diese Anhänge sind im WordPress-Verwaltungshintergrund – Medienbibliothek – zu sehen. Verschiedene Medien entsprechen verschiedenen Artikeln. Beachten Sie jedoch, dass diese Medien auch die Artikel-ID belegen und in derselben Datenbanktabelle wp_posts wie der Artikel gespeichert sind. Wenn Sie besonders Wert darauf legen, dass die IDs der Artikel perfekt fortlaufend sein müssen, laden Sie diese Medien bitte nicht hoch/fügen Sie sie nicht ein, wenn Sie den Artikel veröffentlichen, und löschen Sie bitte die zuvor hochgeladenen Medien im WordPress-Verwaltungshintergrund – Medienbibliothek (beachten Sie, dass dies bei diesem Vorgang nicht der Fall ist). Bitte verwenden Sie FTP, um diese Dateien bei Bedarf erneut hochzuladen.
4. Automatisches Speichern deaktivieren
Der Vorteil des automatischen Speicherns besteht darin, dass das System beim Bearbeiten eines Artikels den bearbeiteten Artikel alle kurze Zeit automatisch für Sie speichert, um zu verhindern, dass die Webseite plötzlich geschlossen wird und Tausende von Artikeln verursacht werden Worte, die vorher geschrieben werden mussten. Plötzlich war es weg. Der Nachteil besteht darin, dass für jeden Artikel automatisch ein Datensatz gespeichert wird, der auch eine Artikel-ID belegt. Dies ist einer der Gründe, warum die Artikel-IDs nicht fortlaufend sind. Wenn Sie diese Funktion nicht benötigen, können Sie den folgenden Code hinzufügen „functions.php“ des aktuellen Themes:
// 禁用自动保存,所以编辑长文章前请注意手动保存。 add_action( 'admin_print_scripts', create_function( '$a', "wp_deregister_script('autosave');" ) );
5. Ordnen Sie diskontinuierliche Artikel-IDs neu an
Methode 1: Sie können den folgenden PHP-Code zu „functions.php“ des aktuellen Themes hinzufügen, sodass, wenn Sie nur Artikel veröffentlichen, Veröffentlichen Sie keine Seiten, fügen Sie keine Menüs hinzu. Wenn Sie keine Medien hochladen, bleiben die nachfolgenden Artikel-IDs grundsätzlich fortlaufend und die zuvor veröffentlichten Artikel-IDs werden nicht geändert und haben keinen Einfluss auf die Suchmaschinenoptimierung:
// WordPress 3.8测试有效 function keep_id_continuous(){ global $wpdb; // 删掉自动草稿和修订版 $wpdb->query("DELETE FROM `$wpdb->posts` WHERE `post_status` = 'auto-draft' OR `post_type` = 'revision'"); // 自增值小于现有最大ID,MySQL会自动设置正确的自增值 $wpdb->query("ALTER TABLE `$wpdb->posts` AUTO_INCREMENT = 1"); } add_filter( 'load-post-new.php', 'keep_id_continuous' ); add_filter( 'load-media-new.php', 'keep_id_continuous' ); add_filter( 'load-nav-menus.php', 'keep_id_continuous' );
Wenn Sie Funktionen wie angeheftete Artikel, Menüs und Eltern-Kind-Seiten verwenden, funktioniert die folgende Methode nicht:
Methode 2: Nach Abschluss der oben genannten Schritte können Sie grundsätzlich garantieren, dass die IDs der veröffentlichten Artikel in Die Zukunft wird kontinuierlich sein, aber dies wurde bereits zuvor getan. Die veröffentlichten Artikel-IDs sind immer noch durcheinander und müssen neu angeordnet werden, um sicherzustellen, dass die IDs kontinuierlich sind. Ich habe ein PHP-Skript geschrieben. Öffnen Sie es nach dem Herunterladen mit einem Texteditor. Laden Sie es dann in Ihren Blog-Bereich hoch siehe OK. Sie können zu phpmyadmin gehen, um zu überprüfen, ob die IDs in der Tabelle wp_posts aufeinanderfolgend sind. Bitte sichern Sie erneut Ihre Datenbank, bevor Sie beginnen. (Wenn Sie die Beitrags-ID als festen Link verwenden, ändert sich möglicherweise die URL aller Artikel, was sich auf die Einbeziehung in Suchmaschinen auswirkt; wenn Sie ein Plug-in zum Erstellen einer neuen Datenbanktabelle verwenden, z. B. ein Abstimmungs-Plug-in usw ., es treten auch Probleme auf; wenn in Ihrem Blog eine Seite mit einer Eltern-Kind-Beziehung erstellt wird, geht diese Beziehung verloren Bitte verwenden Sie es mit Vorsicht!