इस श्रृंखला के भाग 1 में, मैंने प्रदर्शित किया कि वर्डप्रेस को स्थानीय रूप से कैसे स्थापित किया जाए और वर्डप्रेस डेटाबेस को वर्टाबेलो में कैसे आयात किया जाए। इस लेख में, हम Wordpress डेटाबेस में तालिकाओं पर करीब से नज़र डालेंगे।
WordPress डेटाबेस मॉडल और डैशबोर्ड पर एक त्वरित नज़र
पिछले भाग में, मैंने वर्डप्रेस डेटाबेस को हमारे ऑनलाइन डेटाबेस मॉडलिंग टूल में आयात किया था। रिकॉर्ड के लिए, डेटाबेस की संरचना इस प्रकार है:
वर्डप्रेस डेटाबेस मॉडल के बारे में कुछ महत्वपूर्ण तथ्य हैं जिन्हें आपको शुरू करने से पहले समझना चाहिए:
- हर वर्डप्रेस साइट बिल्कुल उसी डेटाबेस संरचना का उपयोग करती है। इसमें 11 टेबल हैं और हर वर्डप्रेस साइट बैकग्राउंड में उनका इस्तेमाल करती है। अधिकांश वर्डप्रेस प्लगइन्स भी डेटाबेस मॉडल में बिना किसी बदलाव के डेटाबेस का उपयोग करते हैं। सभी अलग-अलग प्लगइन्स को समायोजित करने के लिए मॉडल को पर्याप्त लचीला होना चाहिए। बेशक, प्लगइन निर्माता विशिष्ट प्लगइन्स के लिए कस्टम टेबल जोड़ सकते हैं यदि डेटा संरचना काफी भिन्न है या यदि उनका प्लगइन बड़ी मात्रा में डेटा संग्रहीत करता है।
- WordPress डेटाबेस विदेशी कुंजी बाधाओं का अभाव है . यह इस तथ्य के कारण है कि वर्डप्रेस MyISAM स्टोरेज इंजन का उपयोग करता है, जो विदेशी कुंजियों का समर्थन नहीं करता है। टेबल्स इसके चारों ओर काम करते हैं, जो असंबद्ध "विदेशी कुंजी" जैसे मूल्यों को संग्रहीत करते हैं, इसलिए डेटाबेस द्वारा विदेशी कुंजी बाधा की जांच नहीं की जाएगी। उदाहरण के लिए,
post_authorwp_postsतालिकाwp_usersटेबल. - अधिकांश तालिकाएं एकल स्तंभ प्राथमिक कुंजी का उपयोग करती हैं। उन्हें या तो बस "आईडी" नाम दिया गया है (
wp_usersऔरwp_postsटेबल), याmeta_id/umeta_id(मेटा टेबल में:wp_postmeta,wp_commentmetaऔरwp_usermeta), या तालिका नाम और प्रत्यय "_id" (अन्य सभी तालिकाएं) का संयोजन। इन नियमों का एकमात्र अपवाद हैwp_term_relationshipsतालिका, जहां प्राथमिक कुंजी में दो विशेषताएं होती हैं:object_idऔरterm_taxonomy_id. विशेषताएँ जो प्राथमिक कुंजी हैं या प्राथमिक कुंजी का हिस्सा हैं, वे बिगिंट (20) प्रकार के हैं। सिंगल-एट्रिब्यूट प्राइमरी कीज़ में ऑटो-इन्क्रीमेंट प्रॉपर्टी भी "हां" पर सेट होती है।
पोस्ट और पेज
वर्डप्रेस का उपयोग करने का मुख्य कारण सामग्री को बनाना और उसमें हेरफेर करना और उसे जनता के सामने प्रस्तुत करना है। इसके लिए, वर्डप्रेस हमें दो प्रकार की सामग्री प्रदान करता है:पेज और पोस्ट ।

पेज स्थिर सामग्री display प्रदर्शित करने के लिए उपयोग किया जाता है . वे टैग या श्रेणियों का उपयोग नहीं करते हैं और तिथि के अनुसार सूचीबद्ध नहीं हैं। साथ ही वे टिप्पणियों या सोशल मीडिया साझा करने की अनुमति नहीं देते हैं। पृष्ठों में उपपृष्ठ हो सकते हैं। हमारे बारे में पृष्ठ इस प्रकार के अच्छे उदाहरण हैं।
दूसरी ओर, पोस्ट तिथि के अनुसार सूचीबद्ध हैं और श्रेणियों . का उपयोग करके व्यवस्थित किया जा सकता है और टैग . आरएसएस फ़ीड में पोस्ट का उपयोग किया जा सकता है, उनके कालानुक्रमिक क्रम के लिए धन्यवाद। पोस्ट में "सबपोस्ट" नहीं हो सकता है, लेकिन टिप्पणियां और सोशल मीडिया शेयर संभव हैं। पोस्ट अनिवार्य रूप से ब्लॉग पोस्ट हैं। यह समझ में आता है, क्योंकि वर्डप्रेस एक ब्लॉगिंग प्लेटफॉर्म से विकसित हुआ है।
किसी भी वर्डप्रेस पेज पर सामग्री के पीछे की प्राथमिक तालिका को wp_posts :
वर्डप्रेस wp_posts पेज, पोस्ट और अटैचमेंट को स्टोर करने के लिए टेबल। हम इस तालिका को अपने पृष्ठ के मूल के रूप में देख सकते हैं, वह स्थान जहाँ अधिकांश सामग्री संग्रहीत है। यह बताना महत्वपूर्ण है कि अटैचमेंट वास्तव में डिस्क पर संग्रहीत होते हैं और wp_posts तालिका इसके बारे में अधिक जानकारी रखती है (इसे किसने और कब अपलोड किया, आदि)।
wp_posts टेबल हैं:
post_author-wp_usersतालिका, पोस्ट के लेखक को दर्शाती है।post_date- तारीख और समय जब रिकॉर्ड को टेबल में डाला गया था।post_date_gmt- GMT/UTC दिनांक और समय जब तालिका में रिकॉर्ड डाला गया था।post_content- पोस्ट की वास्तविक सामग्री।post_title- पोस्ट का शीर्षक।post_excerpt- सामग्री का सारांश।post_status- वर्तमान पद की स्थिति। वर्डप्रेस 8 डिफ़ॉल्ट स्थितियों का उपयोग करता है:"प्रकाशित करें", "भविष्य", "ड्राफ्ट", "लंबित", "निजी", "ट्रैश", "ऑटो-ड्राफ्ट" और "इनहेरिट"।comment_status- एक पोस्ट या पूरे पेज पर टिप्पणियों को चालू और बंद करता है। दो संभावित मान हैं:"खुला" और "बंद"।ping_status- पहचानता है कि क्या कोई पोस्ट पिंगबैक और ट्रैकबैक की अनुमति देता है। जैसेcomment_status, इसमें केवल "खुले" और "बंद" मान हो सकते हैं।post_password- पोस्ट देखने के लिए इस्तेमाल किया जाने वाला पासवर्ड (वैकल्पिक)।post_name-post_title. का मानव-पठनीय url ।to_ping- यूआरएल की एक सूची वर्डप्रेस को "\ n" द्वारा सीमांकित, पिंगबैक भेजना चाहिए।pinged- यूआरएल की एक सूची जिसे वर्डप्रेस ने पिंगबैक भेजा है, जिसे "\ n" द्वारा सीमांकित किया गया है।post_modified- किसी पोस्ट को संशोधित करने की नवीनतम तिथि और समय।post_modified_gmt-post_modified. के लिए GMT/UTC दिनांक ।post_content_filtered- महंगे पोस्ट कंटेंट ट्रांसफॉर्मेशन को कैश करने के लिए प्लगइन्स द्वारा उपयोग किया जाता है।post_parent- मूल पोस्ट का संदर्भ देता है।guid- किसी पद के लिए वैश्विक विशिष्ट पहचानकर्ता; इसका स्थायी URL.menu_order- सामग्री आदेश देने के लिए उपयोग किया जाता है।post_type- रिकॉर्ड का प्रकार। इसमें "पोस्ट", "पेज", "अटैचमेंट", या उपयोगकर्ता द्वारा परिभाषित कस्टम प्रकार के मान हो सकते हैं।post_mime_type- केवलpost_type = attachmentवाली पोस्ट के लिए परिभाषित अपलोड की गई फ़ाइलों का प्रकार . इसमें "इमेज", "एप्लिकेशन/पीडीएफ" और "एप्लिकेशन/एमएसवर्ड" जैसे मान हो सकते हैं।comment_count- पोस्ट की टिप्पणियों, पिंगबैक और ट्रैकबैक की संख्या।
यहां wp_posts तालिका में "निकोला टेस्ला के बारे में" पृष्ठ जोड़ने के बाद:
जब हम wp_posts तालिका में, हम अपने पृष्ठ के कुछ संस्करण देख सकते हैं। ID = 1 . के साथ रिकॉर्ड में post_status = publish है , जिसका अर्थ है कि पोस्ट सभी के लिए दृश्यमान है। comment_status = closed और ping_status = closed यह दर्शाता है कि इस पोस्ट के लिए टिप्पणियां और पिंग अक्षम हैं।
पोस्ट और पेज पर कोई भी अतिरिक्त जानकारी wp_postmeta तालिका:
इस तालिका के कॉलम इस प्रकार हैं:
meta_id- तालिका की प्राथमिक कुंजी।post_id-wp_postsटेबल.meta_key- एकmeta_value. का विवरण विशेषता।meta_value- संग्रहीत वास्तविक मूल्य।
wp_postmeta तालिका वह जगह है जहां सभी जानकारी wp_posts तालिका संग्रहीत है। इसे कुंजी-मूल्य जोड़े के रूप में संग्रहीत किया जाता है, एक ऐसी तकनीक जिसे अक्सर इकाई-विशेषता-मूल्य कहा जाता है (ईएवी)। टेबल का उपयोग प्लगइन्स द्वारा कस्टम जरूरतों के लिए किया जा सकता है।
वर्डप्रेस टैक्सोनॉमी
वर्गीकरण एक फैंसी शब्द है जो मूल रूप से चीजों को एक साथ समूहित करने के लिए संदर्भित करता है। ग्रुपिंग पोस्ट के लिए वर्डप्रेस में कुछ बिल्ट-इन टैक्सोनॉमी हैं। उदाहरण के लिए, श्रेणियां और टैग बिल्ट-इन वर्डप्रेस टैक्सोनॉमी हैं। आप वर्डप्रेस में अपनी खुद की कस्टम टैक्सोनॉमी भी जोड़ सकते हैं।
टैक्सोनॉमी और उनकी शर्तें wp_terms , wp_term_taxonomy , और wp_term_relationships ।
wp_terms तालिका आपकी वर्डप्रेस साइट में वस्तुओं को वर्गीकृत करने के लिए उपयोग किए जाने वाले शब्दों की एक सूची संग्रहीत करती है:
इस तालिका में सभी टैग और श्रेणी के नाम हैं, साथ ही साथ हमारे कस्टम टैक्सोनॉमी के शब्द भी हैं। विशेषताएं इस प्रकार हैं:
term_id- तालिका की प्राथमिक कुंजी।name- शब्द का नाम।slug-name. का URL ।term_group- शब्दों को एक साथ समूहबद्ध करने के लिए उपयोग किया जाता है।
हमारी उदाहरण साइट की सामग्री यहां दी गई है wp_terms तालिका:
टैक्सोनॉमी को शर्तें wp_term_taxonomy तालिका:
तालिका में विशेषताएँ हैं:
term_taxonomy_id- तालिका की प्राथमिक कुंजी।term_id-wp_termsटेबल.taxonomy- वर्गीकरण नाम।description- उस विशेष वर्गीकरण में एक शब्द का विवरण।parent-wp_termsटेबल.count-wp_postsतालिका जो इस वर्गीकरण में इस शब्द का प्रयोग करती है।
wp_term_taxonomy तालिका हमें अलग-अलग टैक्सोनॉमी में एक ही शब्द का पुन:उपयोग करने में सक्षम बनाती है। ध्यान दें कि रिकॉर्ड जहां term_id = 1 . है इसमें taxonomy = category है , जबकि अन्य रिकॉर्ड में taxonomy = post_tag . है ।
wp_posts और wp_term_taxonomy टेबल, वर्डप्रेस wp_term_relationships तालिका:
ध्यान दें कि यह मॉडल की एकमात्र तालिका है जिसमें एक से अधिक विशेषताओं से बनी कुंजी है।
wp_term_relationships तालिका में निम्नलिखित विशेषताएं हैं:
object_id-wp_postsटेबल.term_taxonomy_id-wp_term_taxonomyटेबल.term_order- किसी विशिष्ट वस्तु के लिए शब्द क्रम।
हमारे यहां छह रिकॉर्ड हैं जो wp_term_taxonomy पोस्ट वाली तालिका (object_id = 6 )।
टिप्पणियां और वर्डप्रेस डेटा मॉडलिंग
हम अपने वर्डप्रेस पेज पर कुछ सामग्री डालने में कामयाब रहे। यह अच्छा है, लेकिन ज्यादातर मामलों में हम जनता से प्रतिक्रिया प्राप्त करना चाहते हैं। और वह है कमेंट फीचर की भूमिका।
पोस्ट पर टिप्पणियों को देखने के लिए, हम बस "एक टिप्पणी छोड़ें" का उपयोग कर सकते हैं या "एक्स टिप्पणी" पर क्लिक कर सकते हैं (जहां एक्स पोस्ट के लिए टिप्पणियों की संख्या के लिए खड़ा है)।
हमारी पहली पोस्ट में पहले से ही एक टिप्पणी है। जब हम इसे क्लिक करते हैं, तो हम देखेंगे कि यह पिंगबैक के कारण होने वाली एक स्वचालित टिप्पणी है। हम उस पोस्ट में एक और टिप्पणी जोड़ेंगे:
अब हम अपनी पोस्ट के लिए दो टिप्पणियाँ देखते हैं, लेकिन डेटाबेस में इसके पीछे क्या है?
आप तालिका के नाम से अनुमान लगा सकते हैं कि wp_comments टेबल का उपयोग हमारे वर्डप्रेस पेज पर टिप्पणियों को स्टोर करने के लिए किया जाता है:
विशेषताएँ अधिकतर स्व-व्याख्यात्मक होती हैं, लेकिन हम अभी भी उनमें से कुछ पर करीब से नज़र डालेंगे।
comment_post_ID wp_posts टेबल; यह दर्शाता है कि किस पोस्ट को टिप्पणियां मिली हैं। पहली टिप्पणी के लिए, हम देख सकते हैं कि यह वास्तव में पिंगबैक था और "लेखक" एक और पोस्ट है। दूसरी टिप्पणी के लिए, हम देख सकते हैं कि मैं लेखक हूँ। comment_agent पर भी ध्यान दें टिप्पणी पोस्ट करने के लिए उपयोग किए जाने वाले सिस्टम और कंप्यूटर के बारे में कुछ बुनियादी जानकारी होती है।
मॉडल में सभी तीन मेटा टेबल के पीछे मुख्य विचार डेटा को स्टोर करना है जिसे हम अपनी प्राथमिक तालिका में स्टोर नहीं करना चाहते हैं। wp_commentmeta wp_comments तालिका उसी तरह से है जैसे wp_postmeta तालिका wp_posts टेबल।
WordPress उपयोगकर्ता देखना
हमारा पेज ऑनलाइन होने के बाद कोई भी इसे देख सकता है। वर्डप्रेस उपयोगकर्ता वे हैं, जो अपनी अनुमति की स्थिति के अनुसार, हमारी साइट और इसकी सामग्री में परिवर्तन कर सकते हैं।
अब हम wp_users और wp_usermeta MySQL डेटाबेस में टेबल।
जैसा अपेक्षित था, wp_users ऊपर दी गई तालिका हमारी वर्डप्रेस साइट पर पंजीकृत सभी उपयोगकर्ताओं के लिए मूल डेटा संग्रहीत करती है। ध्यान दें कि user_pass एन्क्रिप्ट किया गया है और NewUser के पास user_activation_key है edrkusic में वह फ़ील्ड खाली है, जबकि विशेषता भरी हुई है।
जबकि विशेषताएँ wp_users तालिका वह है जिसकी हम किसी भी वर्डप्रेस साइट में अपेक्षा करते हैं, wp_usermeta तालिका का उपयोग उन मूल्यों को संग्रहीत करने के लिए किया जाता है जो किसी निश्चित परियोजना के लिए विशिष्ट हो सकते हैं:
उदाहरण के लिए, ध्यान दें कि umeta_id = 25 . वाला रिकॉर्ड “कुछ जीवनी संबंधी जानकारी” . मान शामिल है , वही पाठ जो हमने NewUser को संपादित करते समय डैशबोर्ड में टाइप किया था। user_id उस रिकॉर्ड की विशेषता का मान 2 . है , जो wp_users टेबल। जाहिर है, user_id wp_users टेबल।
वर्डप्रेस में लिंक और विकल्प
wp_links तालिका अन्य साइटों के लिंक संग्रहीत करने के लिए है:
ब्लॉगिंग युग की शुरुआत में अन्य साइटों से लिंक होना बहुत लोकप्रिय था; आजकल इसका प्रयोग कम होता जा रहा है। वर्डप्रेस संस्करण 3.5 से, लिंक प्रशासन को व्यवस्थापक इंटरफ़ेस से भी हटा दिया गया था। फिर भी, इस तालिका को पुराने संस्करणों के साथ संगतता प्रदान करने के लिए रखा गया है।
wp_options टेबल वर्डप्रेस इंस्टॉलेशन, साइट कॉन्फ़िगरेशन, थीम, प्लगइन्स और विजेट्स के बारे में डेटा स्टोर करता है:
इसका उपयोग अस्थायी कैश्ड डेटा को स्टोर करने के लिए भी किया जाता है। EAV तर्क भी इस तालिका में मौजूद है, जैसा कि wp_usermeta , wp_postmeta और wp_commentmeta . विशेषता option_name कुंजी की भूमिका निभाता है, जबकि विशेषता option_value इसका संगत मान है। तालिका में अन्य दो विशेषताएँ प्राथमिक कुंजी विशेषता हैं option_id और autoload , जो नियंत्रित करता है कि क्या कोई विकल्प स्वचालित रूप से डेटाबेस से लोड होता है।
WordPress के डेटाबेस मॉडल का मूल्यांकन करना
वर्डप्रेस के पीछे का डेटाबेस मॉडल कई अच्छे डेटाबेस डिजाइन नियमों और परंपराओं का पालन नहीं करता है। जब हम किसी विशिष्ट उद्देश्य के लिए डेटाबेस तैयार कर रहे होते हैं, तो इसकी सभी वांछित कार्यक्षमताओं को पहले से जानते हुए, हम उन सभी नियमों का पालन कर सकते हैं। लेकिन वर्डप्रेस को कुछ भी कवर करने की जरूरत है जो किसी के दिमाग में हो, इसलिए विदेशी चाबियों का त्याग करना और ईएवी का उपयोग करना कुछ ऐसा है जो किया जाना चाहिए। मैं सभी तालिकाओं में आईडी विशेषता को समान नाम दूंगा, और "विदेशी कुंजी" के साथ भी ऐसा ही करूंगा। उदाहरण के लिए, मैं post_author . का उपयोग नहीं करूंगा wp_posts तालिका, लेकिन मैं users_id के साथ रहूंगा . इसके अलावा, मुझे इस बात से सहमत होना चाहिए कि वर्डप्रेस डेटाबेस वास्तव में अपने उद्देश्य के लिए एक बेहतरीन मॉडल है।
तुम क्या सोचते हो? हमें कमेंट सेक्शन में बताएं।