यह या तो Drupal को पुनर्स्थापित करके या Drupal के एक आदर्श रूप से ताज़ा इंस्टॉलेशन से तालिका को अपने टूटे हुए इंस्टेंस में कॉपी करके तय किया जा सकता है।
या आप निम्नलिखित समाधान आज़मा सकते हैं (केवल तब ही करें जब आपका ड्रुपल उदाहरण पहले से ही टूट गया हो):
पुरानी रजिस्ट्री तालिका को पहले बैकअप लें (बस मामले में):
drush sqlq "CREATE TABLE registry_bak LIKE registry; INSERT INTO registry_bak SELECT * FROM registry;"
drush sqlq "CREATE TABLE system_bak LIKE system; INSERT INTO system_bak SELECT * FROM system;"
बूटस्ट्रैप कैश और रजिस्ट्री तालिका साफ़ करें।
drush sqlq "TRUNCATE cache_bootstrap; TRUNCATE registry"
मूल डेटा को रजिस्ट्री तालिका में डालें:
drush sqlq 'INSERT INTO registry (name, type, filename) VALUES ("SelectQueryExtender", "class", "includes/database/select.inc"), ("DrupalDefaultEntityController", "class", "includes/entity.inc");'
drush eval "registry_update();"
कैश साफ़ करें:
drush -y cc all
यदि 4 में स्पष्ट कैश नहीं है, तो कुछ अन्य लापता वर्गों के कारण, आप या तो:
a) मिसिंग कक्षाओं को मैन्युअल रूप से जोड़ें, उदाहरण के लिए:
$ drush -y cc all
Fatal error: Class 'Entity' not found in profile2.module on line 593
$ grep -Rwl "^class Entity" .
./sites/all/modules/entity/includes/entity.inc
$ drush sqlq 'INSERT INTO registry (name, type, filename) VALUES ("Entity", "class", "sites/all/modules/entity/includes/entity.inc");'
$ drush -y cc all # testing...
# If Fatal error:, repeat 5a. again.
या:
ख) इन असफल कंट्रीब्यूट मॉड्यूल (जैसे प्रोफाइल 2, नियम) को अक्षम करने का प्रयास करें:
drush sqlq 'UPDATE system SET status = 0 WHERE name = "failing_module"'
और 4 से शुरू होने वाले चरणों को दोहराएं।
यदि कुछ इससे अधिक टूट गया था, तो आप अपनी तालिका को मूल बिंदु पर पुनर्स्थापित कर सकते हैं (जो 1. चरण में किया गया था):
drush sqlq "TRUNCATE registry; INSERT INTO registry SELECT * FROM registry_bak;"
drush sqlq "TRUNCATE system; INSERT INTO system SELECT * FROM system_bak;"
और फिर प्रयत्न करें।
drush rrअसफल रहा