ORM تکنیکی است که به شما کمک میکند با استفاده از یک الگوی شیگرا دادهها را از پایگاه داده جستجو و دستکاری کنید.امروزه توسعه دهندگان به چندین دلیل دوست دارند از ORM استفاده کنند:
- از آنجا که ما باید یک مدل داده را فقط در یک مکان بنویسیم، به روزرسانی، نگهداری و استفاده مجدد از کد آسانتر میشود
- شما را مجبور به نوشتن کد با معماری MVC میکند که باعث تمیزتر شدن کد شما میشود
- بدون نیاز به نوشتن درخواستهای SQL
- بدون نیاز به تغییر در سطح پایگاه داده
- بیشتر کارها به صورت خودکار انجام میشود
اما ORM معایبی هم دارد:
- مشکل ساخت کوئریهای پیچیده
- ادغام و یادگیری
با وجود این معایب، استفاده از ORM در بین توسعه دهندگان از محبوبیت بیشتری برخوردار است. در این مقاله، من در مورد ۵ کتابخانه ORM صحبت میکنم که میتوانید برای توسعه JavaScript استفاده کنید.
Sequelize
Sequelize یک ORM نودجیاس میباشد که مبتنی بر promise-based است و شما میتوانید با دیتابیسهایی همچون: MySQL ،MariaDB ،SQLite و Microsoft SQL Server و Postgres از آن استفاده کنید. (ORM مبتنی بر promise-based به معنای پشتیبانی از promiseهای نودجیاس است). Sequelize مجموعه گستردهای از ویژگیها را در اختیار توسعهدهندگان قرار میدهد و این کتابخانه به دلیل ویژگیها زیر از شهرت زیادی برخوردار است.
چند مزیت و ویژگی اصلی Sequelize به شرح زیر:
- promise-based
- پشتیبانی از پایگاه دادهها
- پشتیبانی از transaction
- همگام سازی در پایگاه داده
- مهاجرت در پایگاه داده
- اعتبارسنجی مدل
- کوئریهای خام
- مقداردهی داده
- روابط eager
- تست کردن آسان
همانطور که میبینید مزایای بسیاری برای استفاده از Sequelize به عنوان ORM برای شما وجود دارد که دارای داکیومنت غنی میباشد. بنابراین، اگر به دنبال ORM پایدار برای پروژه خود هستید این از همه بهتر است.
TypeORM
TypeORM حدودا در سال ۲۰۱۶ معرفی شد و طی ۲، ۳ سال اخیر محبوبیت آن به سرعت در حال افزایش است. دلیل اصلی محبوبیت این است که TypeORM از تایپاسکریپت و بسیاری از نسخههای JavaScript مانند es6 و... را پشتیبانی میکند. TypeORM اعلام کرد که هدف آنها این است که همچنان از جدیدترین ویژگیهای JavaScript پشتیبانی کنند و ویژگیهای جدیدی را برای کمک به توسعه دهندگان در کار با هر نوع فناوری را فراهم نمایند. TypeORM از طیف وسیعی از سیستمهای مدیریت پایگاه داده از جملهMySQL, MariaDB, Postgres, CockroachDB, SQLite, Microsoft SQL Server, Oracle, SAP Hana, sql.js, و MongoDB پشتیبانی میکند.
ویژگی دیگر TypeORM در مقایسه با سایر ORMهای JavaScript این است که از الگوهای Active Record و Data Mapper پشتیبانی میکند. این به توسعه دهندگان این امکان را میدهد تا کدهایی با کیفیت بالا، بهم پیوسته و مقیاسپذیر برای برنامه خود بنویسند. چند ویژگی دیگر TypeORM:
- شما میتوانید آن را در پلتفرمهای: NodeJS, Browser, Cordova, PhoneGap, Ionic, React Native, NativeScript, Expo, and Electron اجرا کنید
- اتصال به چندین پایگاه داده
- پیکربندی اتصال در فرمتهای JSON ،XML ،YML ،ENV
- روابط eager و lazy.
- روابط یک طرفه و دو طرفه
- جمع شدن اتصال
- مدیر موجودیت
- سازنده کوئری بسیار قدرتمند و انعطافپذیر
با خواندن داکیومنت TypeORM میتوانید از ویژگیهای کاملی از آن مطلع شوید و باید بگویم که اگر عاشق تایپاسکریپت هستید، این مناسبترین ORM برای شماست.
Mongoose
همه شما شنیدهاید یا با مونگو دیبی کار کردهاید، که یک سیستم پایگاه داده NoSQL مبتنی بر داکیومنت است. mongoose ابزاری برای مدل سازی اشیا است که به طور خاص برای مونگو دیبی طراحی شده است. بنابراین متفاوت از Sequelize و TypeORM است زیرا آنها بیش از یک سیستم مدیریت پایگاه داده را پشتیبانی میکنند.
با این حال مونگو دیبی برای کار در یک فضای غیر همزمان طراحی شده است و از promises و callbacks نیز پشتیبانی میکند. استفاده از mongoose با مونگو دیبی به طور مداوم لازم نیست اما استفاده از آن با مونگو دیبی دارای مزایای زیادی است.
- mongoose برای مدلهای شما یک طرح تعریف میکند، بنابراین داکیومنتهای شما از یک ساختار خاص با انواع دادههای از پیش تعریف شده، پیروی میکنند
- تعریف طرح برای اعتبارسنجی داخلی
- mongoose عملیات ذخیره و انجام عملیات اختیاری، قبل و بعد را برای مدلهای داده فراهم میکند. این باعث میشود که هوکها و قابلیتهای سفارشی در خواندن و نوشتن موفقیتآمیز و آسان باشد
- mongoose بازگشت داکیومنتها یا نتایج جستجوی به روز شده را آسانتر میکند
از طرف دیگر، استفاده از mongoose در موارد جستجوی پیشرفته توصیه نمیشود. در چنین مواردی، نوشتن کوئری با استفاده از mongoose نه تنها دشوار است بلکه ممکن است پرفورمنس برنامه را نیز کاهش دهد.
Bookshelf
Bookshelf یک ORM جاوااسکریپتی جدید، در مقایسه با ۳ ORM قبلی که برای نودجیاس است که با Knex SQL ساخته شده است و از سیستمهای مدیریت پایگاه داده PostgreSQL ،MySQL و SQLite3 پشتیبانی میکند.
هدف bookshelf تهیه یک کتابخانه ساده برای کارهای معمولی مانند جستجوی داده در JavaScript و ایجاد روابط بین اشیا است. bookshelf برای خواندن، درک کردن و توسعه ساده است و شما را مجبور نمیکند که از طرح اعتبار سنجی خاصی نیز استفاده کنید.
برخی از ویژگی های قفسه کتاب عبارتند از:
- پشتیبانی از promises
- پشتیبانی از callbacks
- پشتیبانی از transaction
- بارگیری رابطه eager و تو در تو
- انجمنهای چند ریختی
- پشتیبانی از روابط یک به یک، یک به چند و چند به چند
Objection
Objection یکی دیگر از ORMهای در حال ظهور برای نودجیاس است که به شما کمک میکند از قدرت کامل SQL و موتور پایگاه داده آن به راحتی استفاده کنید. بدیهی است که objection را به عنوان یک سازنده کوئری رابطهای معرفی کنیم. objection تمام مزایای یک سازنده کوئری SQL را فراهم میکند، همچنین دارای مجموعهای قدرتمند از ابزارها برای کار با روابط است. objection نیز بر روی Knex SQL ساخته شده است و از سیستمهای مدیریت پایگاه داده PostgreSQL ،MySQL و SQLite3 پشتیبانی میکند.
برخی از ویژگیهای objection:
- پشتیبانی رسمی از تایپاسکریپت
- اعتبار سنجی اختیاری طرحهای JSON
- روشهای ساده برای واکشی، درج، به روز رسانی و حذف اشیا با استفاده از قدرت SQL.
- آسان برای استفاده از transactions
- ایجاد طرح پایگاه دادهای خودکار و مهاجرت به مدل تعریف شده
- نمایش کامل پایگاه داده شما به صورت شیگرا
نتیجه
این فقط مجموعهای از کتابخانه های بسیار مفید بود. اگر شما علاقهمند به استفاده از ORM در پروژههای خود هستید، آشنایی با حداقل چند کتابخانه مهم مانند این کتابخانه ها یک مزیت بزرگ برای شما خواهد بود.
دیدگاه و پرسش
در حال دریافت نظرات از سرور، لطفا منتظر بمانید
در حال دریافت نظرات از سرور، لطفا منتظر بمانید