คำถามติดแท็ก orm

4
เมื่อใช้ ORM สิ่งที่ต้องระวังในการออกแบบฐานข้อมูลของคุณคืออะไร
Gotchas ออกแบบฐานข้อมูลอะไรบ้างที่ต้องระวังเมื่อคุณรู้ว่าฐานข้อมูลจะถูกเข้าถึงโดยใช้Wikipedia Object Relational Mapper (ORM) ? ดูที่ Entity Framework NHibernate หรือ LLBLGenPro ตัวอย่างเช่นฉันจะบันทึกข้อ จำกัด พารามิเตอร์ 2100 ในการเรียก RPC ของ SqlServer ปัญหานี้เป็นปัญหาเมื่อใช้ LLBLGen และเข้าร่วมเมื่อตารางคีย์หลักสารประกอบถูกนำมาใช้ดูบทความ MSDN สำหรับคีย์สารประกอบ
19 performance  orm 

2
ค่าใช้จ่ายในการอัปเดตคอลัมน์ทั้งหมดคืออะไรแม้แต่คนที่ไม่ได้เปลี่ยนแปลง [ปิด]
ปิด คำถามนี้จะต้องมีมากขึ้นมุ่งเน้น ไม่ยอมรับคำตอบในขณะนี้ ต้องการปรับปรุงคำถามนี้หรือไม่ อัปเดตคำถามเพื่อให้มุ่งเน้นที่ปัญหาเดียวโดยแก้ไขโพสต์นี้ ปิดให้บริการใน2 ปีที่ผ่านมา เมื่อพูดถึงการอัพเดตแถวเครื่องมือ ORM จำนวนมากออกคำสั่ง UPDATE ที่ตั้งค่าทุกคอลัมน์ที่เกี่ยวข้องกับเอนทิตีนั้น ข้อดีคือคุณสามารถแบทช์ข้อความสั่งการอัพเดทได้อย่างง่ายดายเนื่องจากUPDATEข้อความนั้นเหมือนกันไม่ว่าคุณจะเปลี่ยนเอนทิตีแอตทริบิวต์ใด ยิ่งไปกว่านั้นคุณยังสามารถใช้การแคชคำสั่งฝั่งเซิร์ฟเวอร์และไคลเอนต์ได้เช่นกัน ดังนั้นถ้าฉันโหลดเอนทิตีและตั้งค่าคุณสมบัติเดียวเท่านั้น: Post post = entityManager.find(Post.class, 1L); post.setScore(12); คอลัมน์ทั้งหมดจะมีการเปลี่ยนแปลง: UPDATE post SET score = 12, title = 'High-Performance Java Persistence' WHERE id = 1 ทีนี้สมมติว่าเรามีดัชนีในtitleคุณสมบัติเช่นกันฐานข้อมูลไม่ควรตระหนักว่ามูลค่าไม่เปลี่ยนแปลง ในบทความนี้ Markus Winand พูดว่า: การอัปเดตในคอลัมน์ทั้งหมดแสดงรูปแบบเดียวกับที่เราสังเกตเห็นแล้วในส่วนก่อนหน้า: เวลาตอบสนองจะเพิ่มขึ้นพร้อมกับดัชนีเพิ่มเติมแต่ละรายการ ฉันสงสัยว่าทำไมโอเวอร์เฮดนี้เนื่องจากฐานข้อมูลโหลดหน้าข้อมูลที่เกี่ยวข้องจากดิสก์ไปยังหน่วยความจำและเพื่อให้สามารถทราบได้ว่าค่าคอลัมน์จำเป็นต้องเปลี่ยนหรือไม่ แม้สำหรับดัชนีก็ไม่ต้องปรับสมดุลอะไรเลยเนื่องจากค่าดัชนีไม่เปลี่ยนแปลงสำหรับคอลัมน์ที่ไม่ได้เปลี่ยนแปลง แต่รวมอยู่ในการอัพเดท เป็นดัชนี B + …
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.