บ้าน การเงินส่วนบุคคล ลักษณะทั่วไปของ NoSQL - Dummies

ลักษณะทั่วไปของ NoSQL - Dummies

สารบัญ:

วีดีโอ: SQL Index โดย 9Expert Training 2025

วีดีโอ: SQL Index โดย 9Expert Training 2025
Anonim

หนังสือและบล็อก NoSQL มีความคิดเห็นแตกต่างกันไปในฐานข้อมูล NoSQL คุณลักษณะหลักสี่ประการของ NoSQL ที่แสดงในรายการต่อไปนี้นำไปใช้กับฐานข้อมูล NoSQL ส่วนใหญ่ รายการเปรียบเทียบ NoSQL กับ DBMS เชิงสัมพันธ์แบบเดิม:

  • Schema Agnostic: สคีมาฐานข้อมูลคือคำอธิบายของข้อมูลและโครงสร้างข้อมูลทั้งหมดที่เป็นไปได้ในฐานข้อมูลเชิงสัมพันธ์ ด้วยฐานข้อมูล NoSQL สคีมาไม่จำเป็นต้องทำให้คุณมีอิสระในการจัดเก็บข้อมูลโดยไม่ต้องออกแบบสคีมาล่วงหน้า

  • ฮาร์ดแวร์สินค้าโภคภัณฑ์: ฐานข้อมูลบางแห่งได้รับการออกแบบเพื่อให้ทำงานได้ดีที่สุด (หรือเฉพาะ) ด้วยฮาร์ดแวร์จัดเก็บและประมวลผลเฉพาะ ด้วยฐานข้อมูล NoSQL สามารถใช้เซิร์ฟเวอร์ราคาถูกแบบปิดได้ การเพิ่มมากขึ้นของเซิร์ฟเวอร์ราคาถูกเหล่านี้ช่วยให้ฐานข้อมูล NoSQL สามารถปรับขนาดเพื่อจัดการข้อมูลได้มากขึ้น

  • Schema Agnostic

    ฐานข้อมูล NoSQL เป็น schema agnostic คุณไม่จำเป็นต้องทำมากก่อนงานออกแบบก่อนที่คุณจะสามารถจัดเก็บข้อมูลในฐานข้อมูล NoSQL คุณสามารถเริ่มเขียนโค้ดและจัดเก็บและดึงข้อมูลโดยไม่ต้องรู้ว่าฐานข้อมูลมีการจัดเก็บและใช้งานได้ภายใน (ถ้าและเมื่อคุณต้องการฟังก์ชันการทำงานขั้นสูงคุณสามารถเพิ่มดัชนีเพิ่มเติมหรือปรับแต่งโครงสร้างการจัดเก็บข้อมูลด้วยตนเองได้) Schema agnosticism อาจเป็นความแตกต่างที่สำคัญที่สุดระหว่าง NoSQL และฐานข้อมูลเชิงสัมพันธ์
  • ประโยชน์ที่ยิ่งใหญ่สำหรับฐานข้อมูลไม่ระบุชื่อของ schema คือเวลาในการพัฒนาจะสั้นลง ประโยชน์นี้เพิ่มขึ้นเมื่อคุณผ่านการเผยแพร่การพัฒนาหลายและต้องแก้ไขโครงสร้างข้อมูลภายในในฐานข้อมูล

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

คุณอาจต้องปรับเปลี่ยนคำค้นหาตามลำดับอาจเพิ่มดัชนี

เฉพาะบางครั้ง

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

RDBMS ใช้งานได้เนื่องจากมีความยืดหยุ่นและเนื่องจากโดยใช้ SQL ทำให้การค้นหาเปลี่ยนไปอย่างรวดเร็ว ฐานข้อมูล NoSQL มีความยืดหยุ่นในการเปลี่ยนทั้งแบบแผนและแบบสอบถามซึ่งเป็นหนึ่งในเหตุผลสำคัญที่จะนำมาใช้ในช่วงเวลาต่างๆมากขึ้น

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

เลขที่บัญชี

และหากองค์ประกอบมีชื่อเหมือนกันในเอกสารก็จะยังคงมีอยู่สำหรับข้อความค้นหาที่ไม่มีการเปลี่ยนแปลงกลไกการสืบค้นข้อมูลของคุณ โปรดทราบว่าฐานข้อมูล NoSQL บางส่วนไม่สามารถใช้งาน schema ได้อย่างเต็มที่ บางอย่างเช่น HBase กำหนดให้คุณต้องหยุดฐานข้อมูลเพื่อแก้ไขคำจำกัดความของคอลัมน์ พวกเขายังคงพิจารณาฐานข้อมูล NoSQL เนื่องจากไม่กำหนดฟิลด์ทั้งหมด (คอลัมน์ในกรณีนี้) จะต้องรู้จักล่วงหน้าสำหรับแต่ละระเบียน - เฉพาะกลุ่มคอลัมน์เท่านั้น RDBMS อนุญาตให้ระบุแต่ละฟิลด์ในระเบียนเป็นค่า ค่าว่าง ปัญหาเกี่ยวกับ RDBMS คือขนาดและประสิทธิภาพของข้อมูลที่เก็บไว้จะได้รับผลกระทบในทางลบเมื่อการจัดเก็บข้อมูลสงวนไว้สำหรับค่า null เพียงในกรณีที่เร็กคอร์ดอาจมีค่าในคอลัมน์ในอนาคต ใน Cassandra คุณไม่ได้ระบุข้อมูลของคอลัมน์นั้นซึ่งจะแก้ปัญหาได้

Nonrelational

ระบบการจัดการฐานข้อมูลเชิงสัมพันธ์เป็นวิธีที่โดดเด่นในการจัดเก็บข้อมูลแอพพลิเคมานานกว่า 20 ปี การทำงานทางคณิตศาสตร์ได้ดำเนินการอย่างมากเพื่อพิสูจน์ทฤษฎีที่เป็นรากฐานของพวกเขา การหนุนนี้อธิบายว่าตารางต่างๆเกี่ยวข้องกันอย่างไร แถวคำสั่งซื้อเดียวอาจเกี่ยวข้องกับแถวที่อยู่จัดส่ง แต่แต่ละแถวที่อยู่การส่งมอบยังเกี่ยวข้องกับแถวลำดับอีกด้วย นี่คือ หลาย

-

ถึง

- ความสัมพันธ์มากมาย ฐานข้อมูล NoSQL ไม่มีแนวคิดเกี่ยวกับความสัมพันธ์ระหว่างเร็กคอร์ด พวกเขาแทน denormalize ข้อมูล ซึ่งหมายความว่าในฐานข้อมูล NoSQL จะมีโครงสร้างคำสั่งซื้อที่มีที่อยู่จัดส่งอยู่ ซึ่งหมายความว่าที่อยู่จัดส่งจะมีการทำซ้ำในทุกแถวใบสั่งซื้อที่ใช้ วิธีนี้มีข้อดีคือไม่ต้องใช้เวลาในการสืบค้นข้อมูลแบบซับซ้อนในโครงสร้างข้อมูลหลาย ๆ (ตาราง) ฐานข้อมูล NoSQL จะไม่เก็บข้อมูลเกี่ยวกับการที่แต่ละระเบียนเกี่ยวข้องกับระเบียนอื่น ๆ ในฐานข้อมูลซึ่งอาจฟังดูเหมือนข้อ จำกัด อย่างไรก็ตามฐานข้อมูล NoSQL มีความยืดหยุ่นมากขึ้นในแง่ของโครงสร้างข้อมูลที่คุณสามารถจัดเก็บได้ พิจารณาใบสั่งจากผู้ค้าปลีกออนไลน์ คำสั่งซื้ออาจรวมถึงรหัสผลิตภัณฑ์ปริมาณราคาสินค้าและคำอธิบายรายการรวมทั้งข้อมูลเกี่ยวกับบุคคลที่สั่งซื้อเช่นที่อยู่จัดส่งและข้อมูลการชำระเงิน แทนที่จะแทรกแถว 10 แถวลงในตารางต่างๆในฐานข้อมูลเชิงสัมพันธ์คุณสามารถเก็บโครงสร้างเดียวสำหรับข้อมูลคำสั่งซื้อทั้งหมดนี้เช่นเอกสาร JSON หรือ XML

ในทฤษฎีฐานข้อมูลเชิงสัมพันธ์เป้าหมายคือ

ทำให้ข้อมูลของคุณเป็นแบบปกติ

(นั่นคือเพื่อจัดระเบียบเขตข้อมูลและตารางเพื่อลบข้อมูลที่ซ้ำกัน) ใน NoSQL ฐานข้อมูล - โดยเฉพาะอย่างยิ่งเอกสารหรือฐานข้อมูลรวม - คุณมักจะ denormately denormalize ข้อมูลการจัดเก็บข้อมูลบางอย่างหลายครั้ง

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

มีข้อดีสองอย่างในการจัดเก็บข้อมูลหลาย ๆ ครั้ง: การจัดเก็บและเรียกค้นข้อมูลได้ง่าย: เพียงบันทึกและรับระเบียนเดียว

ความเร็วในการค้นหา:

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

  • มุมมองเชิงสัมพันธ์และการ denormalizations ของ NoSQL เป็นแนวทางที่แตกต่างสำหรับปัญหาการแพร่กระจายข้อมูลข้ามระเบียน ใน NoSQL คุณอาจต้องรักษาข้อมูลซ้ำหลาย ๆ อันที่แสดงมุมมองที่แตกต่างกันของข้อมูลเดียวกัน วิธีนี้จะเพิ่มต้นทุนในการจัดเก็บข้อมูล แต่ช่วยให้คุณได้เวลาสืบค้นข้อมูลที่ดีมากขึ้น เนื่องจากต้นทุนในการจัดเก็บข้อมูลที่เพิ่มขึ้นตลอดเวลาและความเร็วในการพัฒนาและการสืบค้นข้อมูลที่เพิ่มขึ้นข้อมูล denormalized (aka

  • materialized views ) ไม่ใช่เหตุผลที่นักฆ่าจะลดปัญหา NoSQL นี่เป็นวิธีที่แตกต่างในการแก้ไขปัญหาเดียวกันโดยมีข้อดีและข้อเสียของตัวเอง

NoSQL สามารถแบ่งจำหน่ายได้เป็นอย่างมากและใช้ฮาร์ดแวร์สินค้าโภคภัณฑ์

ในฐานข้อมูล NoSQL จำนวนมากการตัดสินใจในการออกแบบที่สำคัญคือการใช้คอมพิวเตอร์หลายเครื่องในการจัดเก็บข้อมูลสำหรับฐานข้อมูลเดียวแทนที่จะมีฐานข้อมูลทั้งหมดบนเซิร์ฟเวอร์เครื่องเดียว การจัดเก็บข้อมูลระหว่างเครื่องหลายเครื่องและทำให้สามารถสอบถามข้อมูลได้ยาก คุณต้องส่งแบบสอบถามไปยังเซิร์ฟเวอร์ทั้งหมดและรอการตอบกลับ หวังว่าคุณจะติดตั้งเครื่องเพื่อให้เร็วพอที่จะพูดคุยกันเพื่อจัดการกับการแจกจ่ายแบบสอบถาม! ข้อได้เปรียบหลักของวิธีนี้คือในกรณีของชุดข้อมูลขนาดใหญ่มากเนื่องจากความต้องการในการจัดเก็บข้อมูลบางอย่างแม้แต่เซิร์ฟเวอร์เดียวที่ใหญ่ที่สุดที่มีอยู่ไม่สามารถจัดเก็บหรือประมวลผลข้อมูลทั้งหมดที่คุณต้องการได้ พิจารณาข้อความทั้งหมดใน Twitter และ Facebook คุณต้องมีกลไกการกระจายข้อมูลเพื่อจัดการข้อมูลทั้งหมดได้อย่างมีประสิทธิภาพแม้ว่าส่วนใหญ่จะเป็นเรื่องเกี่ยวกับสิ่งที่ผู้คนเคยทานอาหารเช้าและวิดีโอน่ารักสำหรับแมว

ข้อดีของการกระจายฐานข้อมูลของคุณคือคุณสามารถใช้เซิร์ฟเวอร์ที่มีราคาถูกกว่าที่เรียกว่า

เซิร์ฟเวอร์สินค้า

แม้แต่ชุดข้อมูลขนาดเล็กก็อาจจะมีราคาถูกกว่าที่จะซื้อเซิร์ฟเวอร์สินค้าโภคภัณฑ์สามชุดแทนที่จะเป็นเซิร์ฟเวอร์ที่ใช้พลังงานสูงเพียงเครื่องเดียว

อีกข้อได้เปรียบที่สำคัญคือการเพิ่มความพร้อมใช้งานที่มีประสิทธิภาพสูงจะง่ายขึ้น คุณมีข้อมูลอยู่แล้วครึ่งทาง ถ้าคุณทำซ้ำข้อมูลของคุณหนึ่งครั้งหรือสองครั้งระหว่างเซิร์ฟเวอร์อื่น ๆ ในคลัสเตอร์ข้อมูลของคุณจะยังคงสามารถเข้าถึงได้แม้ว่าเซิร์ฟเวอร์เซิร์ฟเวอร์จะล่มไหม้และเสียชีวิตก็ตาม

ฐานข้อมูลโอเพนซอร์สไม่ทั้งหมดสนับสนุนความพร้อมใช้งานสูงเว้นแต่คุณจะซื้อฐานข้อมูลจากฐานข้อมูลที่ได้รับการสนับสนุนและได้รับการสนับสนุนจาก บริษัท ที่พัฒนาแล้ว ข้อยกเว้นของกฎที่สามารถแจกจ่ายได้คือฐานข้อมูลกราฟ เพื่อที่จะตอบคำถามแบบสอบถามบางอย่างได้อย่างมีประสิทธิภาพในเวลาที่เหมาะสมข้อมูลจะต้องถูกจัดเก็บไว้ในเซิร์ฟเวอร์เครื่องเดียว ยังไม่มีใครแก้ปัญหานี้ให้ได้ พิจารณาอย่างรอบคอบว่าคุณต้องมีร้านสามชั้นหรือร้านกราฟหรือไม่ ร้านค้าที่สามมีจำหน่ายโดยทั่วไปในขณะที่ร้านค้ากราฟไม่ได้ สิ่งที่คุณต้องการขึ้นอยู่กับข้อความค้นหาที่คุณต้องสนับสนุน

ลักษณะทั่วไปของ NoSQL - Dummies

ตัวเลือกของบรรณาธิการ

รูปสัตว์ใกล้เคียงและแมลง - หุ่น

รูปสัตว์ใกล้เคียงและแมลง - หุ่น

การถ่ายภาพสิ่งมีชีวิตขนาดเล็กปิด, คุณสามารถสร้างภาพที่เปิดเผยรายละเอียดที่ละเอียดซึ่งมักมองข้ามหรือมองไม่เห็นด้วยตาเปล่า รายละเอียดประเภทนี้จะช่วยให้ผู้ชมเข้าใจและดึงดูดความสนใจของพวกเขาขณะที่พวกเขาสังเกตเห็นสิ่งที่พวกเขาไม่ได้สังเกตมาก่อน สิ่งมีชีวิตขนาดเล็กและแมลงนอกจากนี้ยังมี ...

Close-up การถ่ายภาพธรรมชาติที่ Dawn - Dummies

Close-up การถ่ายภาพธรรมชาติที่ Dawn - Dummies

องค์ประกอบบางอย่างที่มีอยู่เฉพาะในตอนเช้าช่วยให้ยืมความรู้สึก เล่าเรื่องไปสู่รูปธรรมชาติที่ใกล้ชิดซึ่งทำให้ผู้ดูอ่านได้ หนึ่งในของขวัญหลักที่ถ่ายภาพในตอนเช้าคือแสง แต่องค์ประกอบอื่น ๆ อีกมากมายเพิ่มเรื่องราวของคุณ: Dew เป็นหนึ่งใน ...

เมฆมากความสว่างและสมดุลสีขาว - มัด

เมฆมากความสว่างและสมดุลสีขาว - มัด

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

ตัวเลือกของบรรณาธิการ

การใช้ Dubsmash - Dummies

การใช้ Dubsmash - Dummies

Dubsmash เป็นแอปพลิเคชันมือถือที่ช่วยให้คุณถ่ายคลิปวิดีโอขนาดเล็กที่คุณสามารถแนบไปได้ กัดเสียงตลก แอปพลิเคชันนี้ออกแบบมาเพื่อให้คุณสามารถซิงค์ปากกับกล้องไปยังเสียงที่ให้มาได้ แต่จินตนาการของคุณเป็นขีด จำกัด หลังจากที่คุณสร้างวิดีโอ Dubsmash คุณสามารถบันทึกและแบ่งปัน ...

วิธีการใช้เจลสีและตัวกรองในการสร้างภาพยนตร์ดิจิทัล - มัมมี่

วิธีการใช้เจลสีและตัวกรองในการสร้างภาพยนตร์ดิจิทัล - มัมมี่

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

วิธีการใช้หลอดไส้ในภาพยนตร์ดิจิตอลของคุณ - มัมมี่

วิธีการใช้หลอดไส้ในภาพยนตร์ดิจิตอลของคุณ - มัมมี่

แสงแดดเป็นรูปแบบสุดยอดของแสงสำหรับ การสร้างภาพยนตร์ DSLR นอกจากนี้ยังเป็นแหล่งกำเนิดแสงจากหลอดไส้ที่ดีที่สุดหรือแหล่งกำเนิดแสงที่ให้ความร้อน แม้ว่าอุณหภูมิสีที่แท้จริงจะแตกต่างกันไปขึ้นอยู่กับตำแหน่งและสภาพบรรยากาศ แต่ก็ยังคงมีสีสันอยู่อย่างเต็มรูปแบบ ซึ่งหมายความว่าคุณสามารถปรับความสมดุลของสีได้ที่

ตัวเลือกของบรรณาธิการ

ปรับ Brightness และ Contrast ด้วย Smart Brush Tool ใน Photoshop Elements - Dummies

ปรับ Brightness และ Contrast ด้วย Smart Brush Tool ใน Photoshop Elements - Dummies

Smart เครื่องมือแปรงใน Photoshop Elements ช่วยให้คุณสามารถเลือกใช้การปรับภาพหรือเทคนิคพิเศษที่ปรากฏบนภาพทั้งหมดหรือบางส่วน

ปรับอุณหภูมิสีด้วย Photo Filters ใน Photoshop Elements 10 - Dummies

ปรับอุณหภูมิสีด้วย Photo Filters ใน Photoshop Elements 10 - Dummies

องค์ประกอบจะให้รูปดิจิตอล ของตัวกรองสีสมัยเก่าด้วยคำสั่ง Photo Filter แสงมีอุณหภูมิสีเอง ภาพที่ถ่ายด้วยอุณหภูมิสีสูงกว่าจะทำให้ภาพมีสีฟ้า ตรงกันข้ามภาพที่ถ่ายด้วยอุณหภูมิสีที่ต่ำกว่าจะทำให้ภาพมีสีเหลือง ในสมัยก่อนช่างภาพใช้

ปรับค่า Contrast และ Color ด้วย Photoshop Elements Levels Adjustment - Dummies

ปรับค่า Contrast และ Color ด้วย Photoshop Elements Levels Adjustment - Dummies

การปรับระดับใน Photoshop Elements 11 คือ หนึ่งในคำสั่งที่มีประสิทธิภาพที่สุดในการแก้ไขความคมชัดของภาพ คุณมักใช้ระดับบนเลเยอร์การปรับ การสร้างเลเยอร์การปรับแต่งและการใช้การตั้งค่าจากกล่องโต้ตอบระดับอาจทำให้เกิดความสับสนเล็กน้อย แผงควบคุมแนะนำโชคดีที่แบ่งขั้นตอนที่ซับซ้อนออกเป็น