Doctrine Hydration คืออะไร? [ปิด]


90

ฉันได้อ่านเกี่ยวกับการขาดน้ำในเอกสารของหลักคำสอน แต่ฉันยังไม่เข้าใจว่ามันคืออะไร

ใครช่วยอธิบายหน่อย


เอกสารอ้างอิง Doctrine2 อธิบาย HYDRATION: doctrine-project.org/docs/orm/2.0/th/reference/…
Dawid Ohia

29
ไม่สร้างสรรค์? นี่เป็นแนวคิดพื้นฐานที่สุดประการหนึ่งสำหรับการทำความเข้าใจว่าหลักคำสอนภายในทำงานอย่างไร
csvan

6
ฉันคิดว่าคำถามนี้ควรได้รับการปกป้องมากกว่าที่จะปิด
Simon

2
@ ไซม่อนเห็นด้วย. คำถามและคำตอบที่ได้รับการยอมรับนั้นเป็นที่นิยมทำไมไม่ย้ายไปอยู่ในสถานะที่ได้รับการคุ้มครอง ?
Denis Kulagin

คำตอบ:


92

Hydration เป็นวิธีที่ใช้ในการส่งคืนผลลัพธ์ของคิวรี ตัวอย่างเช่น:

  1. HYDRATE_ARRAY - สิ่งนี้จะส่งคืนอาร์เรย์ของระเบียนที่แสดงโดยอาร์เรย์อื่น:

    $q = Doctrine_Query::create()
       ->from('Post p')
       ->setHydrationMode(Doctrine::HYDRATE_ARRAY);
    
    $resultSet = $q->execute(); // $resultSet is an array
    
    foreach ($resultSet as $post) {
        // $post is an array
        echo $post['title'];
    }
    
  2. HYDRATE_RECORD- สิ่งนี้จะส่งคืนคอลเล็กชัน ( Doctrine_Collection ) ของวัตถุให้คุณ:

    $q = Doctrine_Query::create()
       ->from('Post p')
       ->setHydrationMode(Doctrine::HYDRATE_RECORD); // Unnecessary, HYDATE_RECORD is default method
    
    $resultSet = $q->execute(); // $resultSet is an Doctrine_Collection object
    
    foreach ($resultSet as $post) {
        // $post is an Post object
        echo $post->getTitle();
        echo $post['title']; // Each Doctrine's Model object implements ArrayAccess interface so this is possible
        echo $post->myCustomMethod();
    }
    
  3. HYDRATE_SINGULAR_SCALAR - จะส่งคืนค่าของคอลัมน์แรกของผลลัพธ์ของแบบสอบถาม:

     $q = Doctrine_Query::create()
       ->select('p.created_at')
       ->from('Post p')
       ->where('p.id = ?', 321)
       ->setHydrationMode(Doctrine::HYDRATE_SINGULAR_SCALAR); 
    
    $createdAt = $q->execute(); // $createdAt has value of first column from first record from result set (eg.: 2008-04-06 21:22:35)
    

มีวิธีการอีกสองสามวิธีคุณสามารถอ่านเกี่ยวกับแต่ละวิธีได้ในเอกสาร


ตกลง.. โดยปกติเมื่อฉันใช้ sql มันจะส่งคืนอ็อบเจ็กต์ mysql และฉันต้องใช้ mysqli_fetch_assoc จากนั้นเรียงลำดับด้วยตัวเองไปเรื่อย ๆ ... แต่ตอนนี้มันถูกจัดเรียงให้ฉันทั้งหมด นั่นคือสิ่งที่เกี่ยวกับความชุ่มชื้นทำให้ฉันจัดเรียงวัตถุ / อาร์เรย์?
never_had_a_name

4
ไม่มันไม่เกี่ยวกับการเรียงลำดับผลลัพธ์ ( orderBy()จัดการสิ่งนี้) เป็นเรื่องเกี่ยวกับผลลัพธ์การสืบค้นของคุณจะเป็นอะไรไม่ว่าจะเป็นค่าสเกลาร์เดียว ( HYDRATE_SINGULAR_SCALAR) อาร์เรย์หรืออาร์เรย์ที่อาร์เรย์ที่ซ้อนกันแสดงถึงระเบียนฐานข้อมูลแต่ละรายการ ( HYDRATE_ARRAY) หรือชุดของวัตถุ ( HYDRATE_RECORD) ทำvar_dumpกับผลการค้นหาสำหรับโหมดการให้น้ำแต่ละโหมดนั่นคือวิธีที่ดีที่สุดในการดู "วิธีการทำงาน"
Crozin

4
เคล็ดลับเล็ก ๆ น้อย ๆ ใน 1.2 HYDRATE_SINGULAR_SCALARส่งกลับข้อผิดพลาดคงที่ที่ไม่ได้กำหนด HYDRATE_SINGLE_SCALARถูกต้อง
Darmen Amanbayev

1
ตามที่ทราบDoctrine::HYDRATE_RECORDกันในขณะนี้ว่าDoctrine::HYDRATE_OBJECT
Steve Tauber

1
ลิงก์ไปยังเอกสารดังกล่าวจะทำให้คำตอบนี้มีประโยชน์มากขึ้น
Sean the Bean

2
$q->fetchOne(array(), Doctrine_Core::HYDRATE_ARRAY);

มันจะส่งคืนเพียงอาร์เรย์ธรรมดาแทนที่จะเป็นวัตถุรวบรวมหลักคำสอน

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