ฉันจะเพิ่มค่าเริ่มต้นลงในตารางฐานข้อมูลโดยใช้ hook_install () ได้อย่างไร


9

ฉันกำลังสร้างโมดูลที่กำหนดเองด้วยสคีมาของตัวเองไม่กี่ตาราง ตารางเหล่านี้จำเป็นต้องมีค่าบางค่าที่เติมไว้ล่วงหน้าเพื่อให้โมดูลทำงาน (ตำแหน่งเริ่มต้นตัวเลือกที่เลือก ฯลฯ )

อะไรคือวิธีปฏิบัติที่ดีที่สุดในการแทรกค่าเริ่มต้นลงในตารางเหล่านี้ระหว่าง hook_install

เนื่องจาก drupal_write_record ไม่พร้อมใช้งานฉันสามารถใช้ db_query ได้ แต่ฉันแค่ต้องการตรวจสอบให้แน่ใจว่าฉันไม่ได้ละเมิดกฎสำคัญใด ๆ โดยการทำเช่นนั้น

คำตอบ:


7

วิธีที่ดีกว่าคือทำภายในhook_enable () ; ในเวลาเบ็ดถูกเรียกโมดูลมีการติดตั้งแล้วและคีมาของฐานข้อมูลที่สามารถใช้ได้กับ Drupal drupal_write_record()และ เนื่องจาก hook ถูกเรียกใช้ทุกครั้งที่เปิดใช้งานโมดูลและไม่เพียง แต่เมื่อติดตั้งโมดูลแล้วการใช้ hook ควรตรวจสอบว่าไม่ได้เพิ่มแถวฐานข้อมูลเหล่านั้นไปแล้ว (เช่นควรใช้ตัวแปร Drupal ที่มีค่าบูลีน) .

ตัวอย่างของโมดูลที่ใช้hook_enable()เพื่อวัตถุประสงค์ที่คล้ายกันคุณสามารถตรวจสอบforum_enable ()หรือphp_enable () (ซึ่งเพิ่มรูปแบบการป้อน "PHP code")

function php_enable() {
  $format_exists = (bool) db_query_range('SELECT 1 FROM {filter_format} WHERE name = :name', 0, 1, array(':name' => 'PHP code'))->fetchField();
  // Add a PHP code text format, if it does not exist. Do this only for the
  // first install (or if the format has been manually deleted) as there is no
  // reliable method to identify the format in an uninstall hook or in
  // subsequent clean installs.
  if (!$format_exists) {
    $php_format = array(
      'format' => 'php_code', 
      'name' => 'PHP code',
      // 'Plain text' format is installed with a weight of 10 by default. Use a
      // higher weight here to ensure that this format will not be the default
      // format for anyone. 
      'weight' => 11, 
      'filters' => array(
        // Enable the PHP evaluator filter.
        'php_code' => array(
          'weight' => 0, 
          'status' => 1,
        ),
      ),
    );
    $php_format = (object) $php_format;
    filter_format_save($php_format);

    drupal_set_message(t('A <a href="@php-code">PHP code</a> text format has been created.', array('@php-code' => url('admin/config/content/formats/' . $php_format->format))));
  }
}

ดังที่แสดงจากการใช้งาน hook เหล่านั้นจำเป็นต้องมีการเรียกใช้โค้ดทุกครั้งที่มีการเรียกใช้ hook อาจเป็นรหัสที่ต้องใช้งานเพียงครั้งเดียวในกรณีที่ค่าเริ่มต้นที่เพิ่มลงในฐานข้อมูลไม่สามารถเปลี่ยนแปลงได้จากผู้ใช้ที่ไม่มีส่วนต่อประสานผู้ใช้ในการแก้ไข / ลบค่าเหล่านั้น


หากฉันทำสิ่งนี้ใน hook_enable () นั่นหมายความว่าจะมีการรีเซ็ตค่าเริ่มต้นทุกครั้งที่เปิดใช้งานและปิดใช้งานโมดูล ฉันคิดว่าเป็นเรื่องธรรมดาพอสมควรเมื่อเทียบกับการยกเลิกการติดตั้งและการติดตั้งใหม่อย่างสมบูรณ์ (ณ จุดนี้คาดว่าฐานข้อมูลจะได้รับการรีเซ็ต)
ส้ม 13

1
นั่นคือเหตุผลที่ฉันเขียนว่า "การใช้เบ็ดควรตรวจสอบว่ามันไม่ได้เพิ่มแถวฐานข้อมูลเหล่านั้นแล้ว" ซึ่งหมายความว่าควรตรวจสอบว่ามีค่าอยู่ในตารางฐานข้อมูลหรือใช้ตัวแปร Drupal เพื่อตรวจสอบว่าได้ทำภารกิจนั้นแล้ว การตรวจสอบตารางฐานข้อมูลจะทำได้ถ้าจำเป็นต้องมีค่าเหล่านั้นในฐานข้อมูล ตัวอย่างเช่นในกรณีนี้ถ้าจำเป็นต้องใช้ค่าจากโมดูลและผู้ใช้ไม่ได้รับอนุญาตให้ลบค่าเริ่มต้น
kiamlaluno

ขอขอบคุณสำหรับการชี้แจง. มีความแตกต่างในการจัดเก็บค่าเหล่านี้ในตารางที่กำหนดเองของฉันกับเพียงแค่ใช้ variable_set เพื่อเก็บไว้ในตัวแปรถาวร? มันเป็นเพียงอาร์เรย์ของค่าสำหรับกล่องเลือกแบบกำหนดเอง
ส้ม 13

ค่าทั้งหมดที่ตั้งค่าโดยใช้variable_set()ซึ่งไม่ถูกลบvariable_del()จะถูกโหลดในหน่วยความจำเมื่อ Drupal bootstraps และบันทึกในตัวแปรส่วนกลาง นี่หมายความว่าพวกเขาอยู่ในหน่วยความจำไม่ว่าโมดูลจะใช้ค่าเหล่านั้นหรือไม่ ใช้ตารางฐานข้อมูลที่กำหนดเองคุณสามารถมั่นใจได้ว่าค่าเหล่านั้นจะถูกโหลดเฉพาะเมื่อโมดูลต้องการจริงๆ คุณไม่ควรใช้variable_set()หากตัวแปร Drupal มีอาร์เรย์ที่คุณเพิ่มดัชนีอาร์เรย์ใหม่ตลอดเวลาตัวอย่างเช่น
kiamlaluno

ดูรหัส (D7) ฉันเห็นโค้ด 2 บรรทัดระหว่างการเรียกใช้ hook_install และ hook_enable เท่านั้น: การอัปเดตตัวแปรท้องถิ่นและการเรียกไปยังสุนัขเฝ้าบ้าน ดังนั้นในระหว่างการติดตั้งจริงไม่มีความแตกต่างใด ๆ ระหว่าง 2 ตะขอนี้เกี่ยวกับสิ่งที่มีอยู่และการลงทะเบียนและสิ่งที่ไม่ ข้อแตกต่างคือไม่ว่าจะเป็นการติดตั้งครั้งแรกหรือเพียงแค่เปิดใช้งานโมดูลอีกครั้ง
fietserwin

4

ฉันจะไปด้วยdb_query/ db_insert(D6 / D7) ใน hook_install ()

ไม่ถือว่าเป็นการปฏิบัติที่ไม่ดี (และไม่มีใครบังคับให้คุณใช้drupal_write_record())

ไม่ใช่เรื่องแปลกที่คนจะปิดและเปิดใช้งานโมดูลอีกครั้งและในกรณีนั้นโค้ดของคุณhook_enable()จะเริ่มทำงานในแต่ละครั้ง ซึ่งไม่ดี

โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.