[ad_1]

بحث امروز ما دربارۀ یک سیستم مدیریت پایگاه داده، به نام Microsoft SQL Server است.

قبل از اینکه شروع کنیم، پیشنهاد می‌کنم برای درک بهتر این مقاله، نگاهی به مقاله پایگاه داده چیست بیندازید و در بخش انواع سیستم مدیریت پایگاه داده، به مدل رابطه‌ای (Relational) دقت کنید. اگر هم وقت این کار را ندارید، اشکالی ندارد؛ در همین مقاله، مفاهیم مورد نیاز را مرور خواهیم کرد.

خب؛ اول برویم سراغ داده (Data) و ببینیم که چرا باید از داده‌ها سر دربیاوریم؟ اصلاً داده‌ها چه اهمیتی دارند؟

داده قدرت می‌بخشد!

اقتصاددان معروف بریتانیایی، آقای رونالد کوز (Ronald Coase)، جملۀ معروفی دارد؛ او می‌گوید:Ronald Coase

«داده (Data) را شکنجه کنید، تا به همه‌چیز اعتراف کند!»

شاید بپرسید که اعتراف به چه چیزی؟

اعتراف به اینکه:

  • افرادی که از سایت شما بازدید کرده‌اند، بیشتر در کدام رده سنی قرار می‌گیرند
  • چند درصد از بازدیدکنندگان سایت شما به مشتری تبدیل شده‌اند
  • مشتری‎های شما به چه رنگی بیشتر واکنش نشان می‌دهند
  • طرفداران آقای ایکس (نامزد انتخاباتی) از چه وسیله نقلیه‌ای بیشتر استفاده می‌کنند
  • چه ساعتی برای پخش مناظره انتخاباتی بهتر است
  • اصلاً طرفداران دوست دارند چه چیزهایی بشوند

و کلی نمونه دیگر که بدون آنکه حس‌شان کنیم، قدم به قدمِ ما را لو می‌دهند!

خب؛ فکر می‌کنم با همین جملۀ آقای کوز، اهمیت خیلی خیلی پررنگ شکنجۀ داده‌ها (یا همان تحلیل داده‌ها) را فهمیدید.

حالا حدس می‌زنید برای اینکه به یک شکنجه‌گر ماهر تبدیل شویم و بتوانیم خیلی خوب از دیتاها حرف بکشیم، به چه لوازم یا ابزارهایی نیاز داریم؟

آفرین!

  • پایگاه داده (Database)؛ برای ذخیره داده‌ها و نظم دادن به آن‌ها
  • نرم‌افزار مدیریت پایگاه داده (DBMS)؛ برای مدیریت، اضافه‌کردن، فراخوانی و ویرایش داده‌ها

اینجا یک توقف کوتاه داریم و تعریف دیتابیس و نرم‌افزار مدیریت دیتابیس مرور می‌کنیم (برای کسانی که مقاله قبلی را نخوانده‌اند.)

مروری بر تعریف دیتابیس و DBMS

تصور کنید قدیم‌ها که اینترنتی وجود نداشت، کار ادارۀ ثبت احوال به چه شکل بود؟

در هر شهر، یک ساختمان غول‌پیکر، با چندین انبار بایگانی که تا خرخره از پوشه و برگه پر شده بودند، وجود داشت. داخل این پوشه‌ها، اطلاعات هویتی ما ثبت شده بود.

حالا فکر کنید قرار بود این اطلاعات را از انبار بیرون بکشیم یا تغییراتی در آن‌ها اعمال کنیم… اول از همه باید تا آن شهر می‌رفتیم و بعد، چندین نفر باید درگیر این می‌شدند که اطلاعات ما را از آن انبار بزرگ پیدا کنند و کارهای لازم را انجام دهند.

ثبت احوال قدیم

الان هم کار ثبت احوال، تقریباً به همین شکل است! منتها، به‌صورت اینترنتی و مجازی!

یعنی هنوز هم یک ساختمان غول پیکر وجود دارد؛ ولی سرورها، جایگزین انباری شده‌اند. هنوز هم فایل و برگه‌هایی که اطلاعات هویتی ما را دربردارند، وجود دارند؛ ولی به‌صورت الکترونیکی و داخل پایگاه داده!

هنوز هم برای فراخوانی و ویرایش اطلاعات به آن انباری سر می‎زنند؛ ولی آن انباری با پایگاه داده (Database) مرتب شده و به‌جای درگیر کردن چندین نفر، با یک نرم‌افزار مدیریت پایگاه داده (DBMS) خیلی راحت‌تر می‌شود با دیتاها کار کرد!

پایگاه داده

خب، حالا که با پیش‌نیازها به‌خوبی آشنا شدید، برویم سراغ اصل مطلب، یعنی SQL Server.

Microsoft SQL Server چیست؟

SQL Server، یک سیستم مدیریت پایگاه داده – از نوع رابطه‌ای – است. این سیستم توسط کمپانی مایکروسافت توسعه داده شده است و از زبان ANSI SQL پشتیبانی می‌کند.

یک پرانتز باز کنیم.

ANSI SQL چیست؟

SQL مخفف Structured Query Language و به معنی نوعی زبان است که برای جستجوهای ساختاریافته استفاده می‌شود (شبیه زبان برنامه‌نویسی، ولی با عملکردی متفاوت).

ANSI هم مخفف American National Standards Institute و اینجا به معنی است که SQL از استاندارد بین‌المللی ANSI پیروی می‌کند.

? در واقع، SQL Server که یک نرم‌افزار مدیریت پایگاه داده است، برای اینکه منظورش را به پایگاه داده برساند، از زبان SQL استفاده می‌کند.

سیستم مدیریت پایگاه داده رابطه‌ای (RDBMS) چیست؟

نرم‌افزارهای مدیریت پایگاه داده، انواع مختلفی دارند که یکی از آن‌ها مدل Relational یا رابطه‌ای است. در مدل رابطه‌ای، به‌جای اینکه داده‌ها خیلی ساده داخل فایل قرار داده شوند، داخل یک سری جدول (Table) سازماندهی شده و بعد ذخیره می‌شوند.

هر جدول یا Table، شامل تعدادی سطر و ستون است که به آن‌ها Tuples و Attributes می‌گویند.

RDBMS

اگر با حجم بزرگی از داده‌ها (در حد چندین ترابایت) سروکار داشته باشید، خیلی زود متوجه می‌شوید که مدیریت آن‌ها با DBMS غیرممکن است و باید از مدل‌های دیگر، مثل RDBMS استفاده کنید.

برای اینکه بهتر درک کنید، Microsoft Access که احتمالاً الان داخل کامپیوترتان دارید، یک DBMS است و به درد استفاده شخصی می‌خورد. در مقابل، SQL Server، MySQL، PostgreSQL، MariaDB و Oracle همگی سیستم‌های RDBMS هستند.

خب؛ همانطور که متوجه شدید، SQL Server شرکت مایکروسافت، رقبای قدری مثل MySQL و Oracle هم دارد. در بخش بعدی می‌خواهیم مزایای اس کیو ال سرور را بررسی کنیم و ببینیم که چه چیزی باعث می‌شود در برخی موارد، از رقبا جلوتر باشد.

مزایای مایکروسافت اس کیو ال سرور چیست؟

  • نصب، پیکربندی و راه‌اندازی آن ساده است
  • رابط کاربری خوبی دارد که کار کردن با داده‌ها را آسان‌تر کرده است
  • امنیت بالایی دارد
  • در صورت نیاز می‌توانید اطلاعات از دسته رفته را بازیابی کنید
  • از پایگاه داده‌های ابری و On-premises پشتیبانی می‌کند
  • نسخه‌های مختلفی دارد که برای کارهای مختلف بهینه‌سازی شده‌اند
  • آموزش‌ها و مستندات زیادی (به زبان انگلیسی) برای آن تهیه شده است
  • روی سیستم عامل لینوکس هم قابل‌استفاده است

این از مزایا؛ بد نیست نگاهی هم به معایب داشته باشیم.

معایب مایکروسافت اس کیو ال سرور چیست؟

  • قیمت بالایی دارد (البته اگر بخواهید لایسنس قانونی آن را تهیه کنید)
  • در مقایسه با Oracle، برای پارتیشن‌بندی گزینه‌های زیادی ندارد (مثلاً پارتیشن‌بندی کلیدهای خارجی (Foreign Key) که در اوراکل وجود دارد، در MS SQL Server نیست.
  • پشتیبانی رسمی آن نیازمند پرداخت هزینه است
  • در اتصال به نرم‌افزارهایی غیر از نرم‌افزارهای شرکت مایکروسافت، ممکن است مشکلاتی پیش بیاید (که اغلب قابل حل هستند)

اگر شما هم دربارۀ مزایا و معایب SQL Server مایکروسافت نظری دارید، خوشحال می‌شویم که آن را با ما در میان بگذارید و از تجربه‌هایتان بگویید.

همانطور که بالاتر اشاره کردیم، اس کیو ال سرور، نسخه‌های مختلفی دارد. در ادامه این نسخه‌ها را بررسی می‌کنیم.

با نسخه های مختلف Microsoft SQL Server آشنا شوید

تا الان نسخه‌های مختلفی برای اس کیو ال سرور ارائه شده است که برخی از آن‌ها رایگان هستند، برخی پولی، برخی تخصصی و برخی دیگر از رده خارج شده‌اند.

ما در این بخش نسخه‌های مهم‌تر و محبوب‌تر را بررسی می‌کنیم و اگر فرصتی بود، در مقاله‌های بعدی وبلاگ ایران‌سرور، راجع‌به تمام نسخه‌ها صحبت می‌کنیم.

اگر دوست داشتید راجع‌به سایر نسخه‌ها هم اطلاعات کسب کنید، حتماً به ما بگویید.

SQL Server Express

پایه‌ای‌ترین نسخۀ اسکیوال سرور است و همه می‌توانند آن را به‌صورت رایگان دانلود کرده و استفاده کنند. امکانات این نسخه محدود است و در نسخۀ ۲۰۱۹، در صورتی که اندازه پایگاه داده بیشتر از ۱۰ گیگ نباشد، می‌توانید از آن استفاده کنید.

نسخه اکسپرس اس کیو ال سرور، بیشتر  به درد افرادی می‌خورد که در حال یادگیری هستند و می‌خواهند برنامه‌های کوچک داده‌محوری  بسازند. توجه کنید که در صورت پیشرفت، می‌توانید SQL Server Express را به نسخه‌های دیگر ارتقاء دهید.

SQL Server Developer

این نسخه مشابه نسخۀ اینترپرایز است؛ اما محدود به تست و توسعه نرم‌افزار است و نمی‌توان از آن به‌عنوان سرور تولید استفاده کرد. نسخۀ دولوپر اس کیو ال سرور، به درد  توسعه‌دهنده‌هایی می‌خورد که می‌خواهند برنامه بسازند و آن را تست کنند .

SQL Server Enterprise

این نسخه، کامل‌ترین نسخۀ SQL Server است و برای انجام ماموریت‌های مهم، پردازش‌های سنگین، مدیریت و تحلیل داده‌ها در مقیاس‌های خیلی بزرگ از آن استفاده می‌شود. امنیت نسخه اینترپرایز، فوق‌العاده بالاست و قادر است حافظه‌ای ۱۲ ترابایتی را آدرس‌دهی و دیتابیسی با حجم ۵۲۴ پتابایت را مدیریت کند.

اداره‌هایی که حجم زیادی داده دارند (مثل ثبت احوال) یا  فروشگاه‌های اینترنتی بزرگ  (مثل آمازون) از این سیستم می‌توانند استفاده کنند.

و … همانطور که پیداست، این نسخه رایگان نیست و برای استفاده از آن باید لایسنس تهیه کنید.

SQL Server Standard

نسخه استاندارد اسکیوال، یک سری امکانات پایه‌ای برای مدیریت داده‌ها و همچنین هوش تجاری دارد. امکانات این نسخه از نسخۀ Enterprise کمتر است؛ مثلاً در هر کلاستر (Cluster) از تعداد نود (Node) کمتری پشتیبانی می‌شود.

 شرکت‌ها و سازمان‌های کوچک ، فروشگاه‌های اینترنتی با تعداد مخاطبین کم و کسانی که در شروع کار هستند، می‌توانند از SQL Server Standard استفاده کنند و هزینه کمتری هم بایت لاینس قانونی آن بپردازند.

SQL Server WEB

این نسخه، یکی از انتخاب‌های مقرون‌به‌صرفه برای کسانی هست که کار میزبانی وب (هاستینگ) انجام می‌دهند. امکانات نسخۀ وب اس کیو ال سرور، تقریباً یک چیزی بین نسخه Standard و Express است.

 شرکت‌های هاستینگ  می‌توانند با این سیستم، قابلیت‌هایی مثل مقیاس‌پذیری، ارتقاء، مدیریت ظرفیت‌ها و صرفه‌جویی در هزینه‌ها را برای کسب‌وکارهای مختلف فراهم کنند.

تا اینجا با نسخه‌های مهم SQL Server آشنا شدید. در بخش بعدی می‌خواهیم راجع‌به Instance یا نصب نسخه‌های مختلف اس کیو ال سرور روی ماشین صحبت کنیم.

SQL Server Instance چیست؟

SQL Server instance

یکی از قابلیت‌های خوب SQL سرور این است که شما می‌توانید چندین نسخه از آن را، که در Version، Edition و Platform تفاوت دارند، به‌صورت مستقل روی یک ماشین نصب کنید. به تک‌تکِ SQL Server های نصب شده روی این ماشین، یک Instance (نمونه) از SQL Server گفته می‌شود.

شما می‌توانید به هر Instance یک نام مشخص را اختصاص دهید؛ فقط دقت کنید که اگر به یکی از Instanceها در زمان نصب هیچ نامی اختصاص ندهید و با ماشینی که روی آن نصب می‌شود هم‌نام بماند، به عنوان نمونه پیشفرض (Default Instance) در نظر گرفته می‌شود.

یک سوال: وجود این Instance ها به چه دردی می‌خورد؟

شما یک سری نرم‌افزار روی سرور نصب کرده‌اید و گاهی ممکن است چندتا از نرم‌افزارها، فقط با یکی از ورژن‌های اس کیو ال سرور سازگاری داشته باشد. در این شرایط، شاید لازم باشد که چند Instance (مثلاً ۲۰۰۸، ۲۰۱۲ و …) برای نرم‌افزارهای مختلف نصب کنید.

SQL Server Studio چیست؟

اس کیو ال سرور استودیو، یک محیط یکپارچه، برای مدیریت هر نوع زیرساخت SQL (ازSQL Server Instances گرفته تا Azure SQL Database) است.

خب، بدون شک مدیریت Instance های مختلف کار راحتی نیست؛ اما SQL Server Studio یک رابط گرافیکی برای این کار در اختیار شما می‌گذارد و کار را تا جای ممکن ساده می‌کند.

حرف آخر

خب فکر می‌کنم که تا اینجا به‌خوبی با SQL Server و طرز کار آن آشنا شدید. به عنوان آخرین نکته می‌خواهم درباره تلفظ SQL Server هم نکته‌ای را بگویم. ببینید، در ویدئوهای مختلف ممکن است تلفظ‌های مختلفی مثل اس کیو ال سرور و سیکوئل (SEQUEL) سرور را بشنوید. هر دوی این تلفظ‌ها درست هستند؛ ولی خب خود بیل گیتس این کلمه را سیکوئل تلفظ می‌کند.

همین دیگر. امیدوارم که این مقاله حسابی به دردتان خورده باشد. اگر سوال، نظر یا پیشنهادی دارید، حتماً حتماً آن را با ما در میان بگذارید ?

[ad_2]

اشتراک گذاری