منبع از: http://fa.wikipedia.org
دادِگان (پایگاه دادهها یا بانک اطلاعاتی) به مجموعهای از اطلاعات
با ساختار منظم و سامانمند گفته میشود. این پایگاههای اطلاعاتی معمولاً
در قالبی که برای دستگاهها و رایانهها قابل خواندن و قابل دسترسی باشند
ذخیره میشوند. البته چنین شیوه ذخیرهسازی اطلاعات تنها روش موجود نیست و
شیوههای دیگری مانند ذخیرهسازی ساده در پروندهها نیز استفاده میگردد.
مسئلهای که ذخیرهسازی دادهها در دادگان را موثر میسازد وجود یک ساختار
مفهومی است برای ذخیرهسازی و روابط بین دادهها است.
پایگاه داده در اصل مجموعهای سازمان یافته از اطلاعات است.این واژه
از دانش رایانه سرچشمه میگیرد ،اما کاربر وسیع و عمومی نیز دارد، این
وسعت به اندازهای است که مرکز اروپایی پایگاه داده (که تعاریف
خردمندانهای برای پایگاه داده ایجاد میکند) شامل تعاریف غیر الکترونیکی
برای پایگاه داده میباشد. در این نوشتار به کاربرد های تکنیکی برای این
اصطلاح محدود میشود.
یک تعریف ممکن این است که: پایگاه داده مجموعهای از رکورد های ذخیره
شده در رایانه با یک روش سیستماتیک (اصولی) مثل یک برنامه رایانهای است
که میتواند به سوالات کاربر پاسخ دهد. برای ذخیره و بازیابی بهتر، هر
رکورد معمولا به صورت مجموعهای از اجزای دادهای یا رویداد ها سازماندهی
میگردد. بخش های بازیابی شده در هر پرسش به اطلاعاتی تبدیل میشود که
برای اتخاذ یک تصمیم کاربرد دارد. برنامه رایانهای که برای مدیریت و پرسش
و پاسخ بین پایگاههای دادهای استفاده میشود را مدیر سیستم پایگاه
دادهای یا به اختصار (DBMS) مینامیم. خصوصیات و طراحی سیستم های پایگاه
دادهای در علم اطلاعات مطالعه میشود.
مفهوم اصلی پایگاه داده این است که پایگاه داده مجموعهای از رکورد
ها یا تکه هایی از یک شناخت است.نوعا در یک پایگاه داده توصیف ساخت
یافتهای برای موجودیت های نگه داری شده در پایگاه داده وجود دارد: این
توصیف با یک الگو یا مدل شناخته میشود. مدل توصیفی، اشیا پایگاههای
داده و ارتباط بین آنها را نشان میدهد. روش های متفاوتی برای سازماندهی
این مدل ها وجود دارد که به آنها مدل های پایگاه داده گوییم.
پرکاربردترین مدلی که امروزه بسیار استفاده میشود، مدل رابطهای است که
به طور عام به صورت زیر تعریف میشود: نمایش تمام اطلاعاتی که به فرم
جداول مرتبط که هریک از سطر ها و ستونها تشکیل شده است(تعریف حقیقی آن در
علم ریاضیات برسی میشود). در این مدل وابستگی ها به کمک مقادیر مشترک در
بیش از یک جدول نشان داده میشود. مدل های دیگری مثل مدل سلسله مراتب و
مدل شبکهای به طور صریح تری ارتباط ها را نشان میدهند.
در مباحث تخصصی تر اصتلاح دادگان یا پایگاه داده به صورت مجموعهای
از رکورد های مرتبط با هم تعریف میشود. بسیاری از حرفهای ها مجموعهای
از داده هایی با خصوصیات یکسان به منظور ایجاد یک پایگاه دادهای یکتا
استفاده میکنند.
معمولا DBMS ها بر اساس مدل هایی که استفاده میکنند تقسیم بندی
میشوند: ارتباطی،شی گرا، شبکهای و امثال آن. مدل های دادهای به تعیین
زبانهای دسترسی به پایگاههای داده علاقه مند هستند. بخش قابل توجهی از
مهندسی DBMS مستقل از مدل های میباشد و به فاکتور هایی همچون اجرا،
همزمانی،جامعیت و بازیافت از خطاهای سخت افزاری وابسطه است.در این سطح
تفاوت های بسیاری بین محصولات وجود دارد.
موارد زیر به صورت خلاصه شرح داده می شود:
•۱ تاریخچه پایگاه داده
•۲ انواع دادگان ها
•۳ مدل های پایگاه داده
۳.۱ مدل تخت
۳.۲ مدل شبکه ای(Network)
۳.۳ مدل رابطه ای
۳.۴ پایگاه دادههای چند بعدی
۳.۵ پایگاه دادههای شیء
•۴ ویژگیهای سیستم مدیریت پایگاه دادهها
•۵ فهرست سیستمهای متداول مدیریت دادگان
1- تاریخچه پایگاه داده
اولین کاربردهای اصطلاح پایگاه داده به June 1963 باز میگردد، یعنی
زمانی که شرکت System Development Corporation مسئولیت اجرایی یک طرح به
نام "توسعه و مدیریت محاسباتی یک پایگاه دادهای مرکزی" را بر عهده گرفت.
پایگاه داده به عنوان یک واژه واحد در اوایل دهه 70 در اروپا و در اواخر
دهه 70 در خبر نامههای معتبر آمریکایی به کار رفت.(بانک دادهای یا
Databank در اوایل سال 1966 در روزنامه واشنگتن کار رفت)
تصویر:اولین سیستم مدیریت پایگاه داده در دهه 60 گسترش یافت. از
پیشگامان این شاخه چارلز باخمن میباشد. مقالات باخمن این را نشان داد که
فرضیات او کاربرد بسیار موثرتری برای دسترسی به وسایل ذخیره سازی را محیا
میکند. در آن زمانها پردازش داده بر پایه کارت های منگنه و نوار های
مغناطیسی بود که پردازش سری اطلاعات را مهیا میکند. دو نوع مدل دادهای
در آن زمانها ایجاد شد:CODASYL موجب توسعه مدل شبکهای شدکه ریشه در
نظریات باخمن داشت و مدل سلسله مراتبی که توسط North American Rockwell
ایجاد شد و بعدا با اقباس از آن شرکت IBM محصولIMS را تولید نمود.
مدل رابطهای توسط E. F. Codd در سال 1970 ارائه شد.او مدل های موجود
را مورد انتقاد قرار میداد. برای مدتی نسبتا طولانی این مدل در مجامع
علمی مورد تایید بود. اولین محصول موفق برای میکرو کامپیوتر ها dBASE
بودکه برای سیستم عامل هایCP/M و PC-DOS/MS-DOS ساخته شد. در جریان سال
1980 پژوهش بر روی مدل توزیع شده (distributed database) و ماشین های
دادگانی (database machines) متمرکز شد، اما تاثیر کمی بر بازار گذاشت. در
سال 1990 توجهات به طرف مدل شی گرا(object-oriented databases) جلب شد.
این مدل جهت کنترل دادههای مرکب لازم بود و به سادگی بر روی پایگاه
دادههای خاص، مهندسی داده(شامل مهندسی نرم افزار منابع) و دادههای چند
رسانهای کار میکرد.
در سال 2000 نوآوری تازهای رخ داد و دادگان اکسامال (XML) به وجود
آمد. هدف این مدل از بین بردن تفاوت بین مستندات و داده ها است و کمک
میکند که منابع اطلاعاتی چه ساخت یافته باشند یا نه در کنار هم قرار
گیرند.
2- انواع دادگان ها
دادگانها از نظر ساختار مفهومی و شیوهای رفتار با دادهها بر دو نوع هستند :
1.دادگان رابطهای
2.دادگان شیگرا
3- مدل های پایگاه داده
شگرد های مختلفی برای مدل های دادهای وجود دارد. بیشتر سیستم های
پایگاه دادهای هر چند که طور معمول بیشتر از یک مدل را مورد حمایت قرار
میدهند، حول یک مدل مشخص ایجاد شده اند. برای هر یک از الگوهای های
منطقی (logical model) اجراهای فیزیکی مختلفی قابل پیاده شدن است و سطوح
کنترل مختلفی در انطباق فیزیکی برای کاربران محیا میکند. یک انتخاب
مناسب تاثیر موثری بر اجرا دارد. مثالی از موارد الگوی رابطهای
(relational model) است: همه رویدادهای مهم در مدل رابطهای امکان ایجاد
نمایههایی که دسترسی سریع به سطرها در جدول را میدهد،فراهم میشود.
یک مدل دادهای تنها شیوه ساختمان بندی داده ها نیست بلکه معمولا به
صورت مجموعهای از عملیات ها که میتواند روی داده ها اجرا شود تعریف
میشوند. برای مثال در مدل رابطهای عملیاتی همچون گزینش (selection)،
طرح ریزی (projection) و اتصال (join) تعریف میگردد.
۳.۱ مدل تخت
مدل تخت یا جدولی (flat (or table) model ) تشکیل شده است از یک آرایه
دو بعدی با عناصر دادهای که همه اجزای یک ستون به صورت دادههای مشابه
فرض میشود و همه عناصر یک سطر با هم در ارتباط هستند. برای نمونه در
ستون هایی که برای نام کاربری و رمز عبور در جزئی از سیستم های پایگاه
دادهای امنیتی مورد استفاده قرار میگیرد هر سطر شامل رمز عبوری است که
مخصوص یک کاربر خاص است. ستون های جدول که با آن در ارتباط هستند به صورت
داده کاراکتری، اطلاعات زمانی، عدد صحیح یا اعداد ممیز شناور تعریف
میشوند. این مدل پایه برنامههای محاسباتی(spreadsheet) است.
پایگاه داده ها با فایل های تخت به سادگی توسط فایل های متنی تعریف
میشوند. هر رکورد یک خط است و فیلد ها به کمک جدا کننده هایی از هم مجزا
میشوند. فرضا به مثال زیر دقت کنید:
id name team
1 Amy Blues
2 Bob Reds
3 Chuck Blues
4 Dick Blues
5 Ethel Reds
6 Fred Blues
7 Gilly Blues
8 Hank Reds
دادههای هر ستون مشابه هم است ما به این ستونها فیلد ها (fields)
گوییم. و هر خط را غیر از خط اول یک رکورد(record) مینامیم. خط اول را
که برخی پایگاههای دادهای آنرا ندارند رکورد برچسب(field labels) گوییم.
هر مقدار دادهای اندازه خاص خود را دارد که اگر به آن اندازه نرسد
میتوان از کاراکنر فاصله برای این منظور استفاده کرد اما این مسئله
مخصوصا زمانی که بخواهیم اطلاعات را بر روی کارت های منگنه قرار دهیم مشکل
ساز خواهد شد. امروزه معمولا از نویسه TAB برای جداسازی فیلد ها و کاراکتر
خط بعد برای رکورد بعدی استفاده میکنیم. البته شیوههای دیگری هم وجود
دارد مثلا به مثال زیر دقت کنید:
"1","Amy","Blues"
"2","Bob","Reds"
"3","Chuck","Blues"
"4","Dick","Blues"
"5","Ethel","Reds"
"6","Fred","Blues"
"7","Gilly","Blues"
"8","Hank","Reds"
این مثال از جدا کننده کاما استفاده میکند.در این نوع مدل تنها
قابلیت حذف،اضافه،دیدن و ویرایش وجود دارد که ممکن است کافی
نباشد.Microsoft Excel این مدل را پیاده سازی میکند.
۳.2 مدل شبکه ای(Network)
در سال 1969 و در کنفرانس زبانهای سیستم های دادهای (CODASYL)
توسطCharles Bachman ارائه شد. در سال 1971 مجددا مطرح شد و اساس کار
پایگاه دادهای قرار گرفت و در اوایل دهه 80 با ثبت آن درسازمان بين
المللي استانداردهاي جهاني یا ISO به اوج رسید.
مدل شبکهای (database model) بر پایه دو سازه مهم یعنی مجموعه ها و
رکورد ها ساخته میشود و برخلاف روش سلسله مراتبی که از درخت استفاده
میکند، گراف را به کار میگیرد. مزیت این روش بر سلسله مراتبی این است
که مدل های ارتباطی طبیعی بیشتری را بین موجودیت ها فراهم میکند. الی
رغم این مزیت ها به دو دلیل اساسی این مدل با شکست مواجه شد: اول اینکه
شرکت IBM با تولید محصولات IMS و DL/I که بر پایه مدل سلسله مراتبی است
این مدل را نادیده گرفت. دوم اینکه سرانجام مدل رابطهای (relational
model) جای آن را گرفت چون سطح بالاتر و واضح تر بود. تا اوایل دهه 80 به
علت کارایی رابط های سطح پایین مدل سلسله مراتبی و شبکهای پیشنهاد میشد
که بسیاری از نیاز های آن زمان را برطرف میکرد. اما با سریعتر شدن سخت
افزار به علت قابلیت انعطاف و سودمندی بیشتر سیستم های رابطهای به پیروزی
رسیدند.
رکورد ها در این مدل شامل فیلد هایی است( ممکن است همچون زبان کوبول
(COBOL) به صورت سلسله مراتب اولویتی باشد). مجموعه ها با ارتباط یک به
چند بین رکورد ها تعریف میشود: یک مالک و چند عضو. عملیات های مدل
شبکهای از نوع هدایت کننده است: یک برنامه در موقعیت جاری خود باقی
میماند و از یک رکورد به رکورد دیگر میرود هر گاه که ارتباطی بین آنها
وجود داشته باشد. معمولا از اشارهگرها(pointers) برای آدرس دهی مستقیم به
یک رکورد در دیسک استفاده میشود. با این تکنیک کارایی بازیابی اضافه
میشود هر چند در نمایش ظاهری این مدل ضروری نیست .
۳.3 مدل رابطه ای
مدل رابطه ای (relational model) در یک مقاله تحصیلی توسط E. F. Codd
در سال 1970 ارائه گشت. این مدل یک مدل ریاضیاتی است که با مفاهیمی چون
مستندات منطقی (predicate logic) و تئوری مجموعه ها (set theory) در
ارتباط است. محصولاتی همچون اینگرس،اراکل، DB2 وسرور اسکیوال (SQL
Server) بر این پایه ایجاد شده است. ساختار داده ها در این محصولات به
صورت جدول است با این تفاوت که میتواند چند سطر داشته باشد. به عبارت
دیگر دارای جداول چند گانه است که به طور صریح ارتباطات بین آنها بیان
نمیشود و در عوض کلید هایی به منظور تطبیق سطر ها در جداول مختلف استفاده
میشود. به عنوان مثال جدول کارمندان ممکن است ستونی به نام "موقعیت"
داشته باشد که کلید جدول موقعیت را با هم تطبیق میدهد.
۳.4 پایگاه دادههای چند بعدی
پایگاه دادههای رابطهای توانست به سرعت بازار را تسخیر كند، هرچند
كارهایی نیز وجود داشت كه این پایگاه دادهها نمیتوانست به خوبی انجام
دهد. به ویژه به كارگیری كليدها در چند ركورد مرتبط به هم و در چند پایگاه
داده مشترك، كندی سیستم را موجب میشد. برای نمونه برای یافتن نشانی
كاربری با نام دیوید، سیستم رابطهای باید نام وی را در جدول كاربر جستجو
كند و كليد اصلی (primary key ) را بیابد و سپس در جدول نشانیها، دنبال
آن كليد بگردد. اگر چه این وضعیت از نظر كاربر، فقط يك عملیات محسوب، اما
به جستجو درجداول نیازمند است كه این كار پیچیده و زمان بر خواهد بود. راه
كار این مشكل این است كه پایگاه دادهها اطلاعات صریح درباره ارتباط بین
دادهها را ذخیره نماید. میتوان به جای یافتن نشانی دیوید با جستجو ی
كليد در جدول نشانی، اشارهگر به دادهها را ذخیره نمود. در واقع، اگر
ركورد اصلی، مالك داده باشد، در همان مكان فیزيكی ذخیره خواهد شد و از سوی
دیگر سرعت دسترسی افزایش خواهد یافت.
چنین سیستمی را پایگاه دادههای چند بعدی مینامند. این سیستم در
هنگامی كه از مجموعه دادههای بزرگ استفاده میشود، بسیار سودمند خواهد
بود. از آنجاييكه این سیستم برای مجموعه دادههای بزرگ به كار میرود،
هیچگاه در بازار به طور مستقیم عمومیت نخواهد یافت.
۳.5 پایگاه دادههای شیء
اگر چه سیستمهای چند بعدی نتوانستند بازار را تسخیر نمایند، اما به
توسعه سیستمهای شیء منجر شدند. این سیستمها كه مبتنی بر ساختار و مفاهیم
سیستمهای چند بعدی هستند، به كاربر امكان میدهند تا اشیاء را به طور
مستقیم در پایگاه دادهها ذخیره نماید. بدین ترتیب ساختار برنامه نویسی
شیء گرا (object oriented ) را میتوان به طور مستقیم و بدون تبدیل نمودن
به سایر فرمتها، در پایگاه دادهها مورد استفاده قرار داد. این وضعیت به
دلیل مفاهیم مالكيت (ownership) در سیستم چند بعدی، رخ میدهد. در برنامه
شیء گرا (OO)، يك شیء خاص "مالك " سایر اشیاء در حافظه است، مثلا دیوید
مالك نشانی خود میباشد. در صورتی كه مفهوم مالكيت در پایگاه دادههای
رابطهای وجود ندارد.
4- ویژگیهای سیستم مدیریت پایگاه دادهها
پس از این مقدمه به توصیف سیستم مدیریت پایگاه دادهها میپردازیم.
سیستم مدیریت پایگاه دادهها، مجموعهای پیچیده از برنامههای نرمافزاری
است كه ذخیره سازی و بازیابی دادههای (فیلدها، ركوردها و فایلها) سازمان
را در پایگاه دادهها، كنترل میكند. این سیستم، كنترل امنیت و صحت پایگاه
دادهها را نیز بر عهده دارد. سیستم مدیریت پایگاه دادهها، درخواستهای
داده را از برنامه میپذیرد و به سیستم عامل دستور میدهد تا دادهها ی
مناسب را انتقال دهد. هنگامی كه چنین سیستمی مورد استفاده قرار میگیرد،
اگر نیازمندیهای اطلاعاتی سازمانی تغییر یابد، سیستمهای اطلاعاتی نیز
آسانتر تغییر خواهند یافت. سیستم مذكور از صحت پایگاه دادهها پشتیبانی
میكند. بدین ترتیب كه اجازه نمیدهد بیش از يك كاربر در هر لحظه، يك
ركورد را به روز رسانی كند. این سیستم ركوردهای تكراری را در خارج پایگاه
دادهها نگاه میدارد. برای مثال، هیچ دو مشترك با يك شماره مشتری،
نمیتوانند در پایگاه دادهها وارد شوند. این سیستم روشی برای ورود و به
روز رسانی تعاملی پایگاه دادهها فراهم میآورد. يك سیستم اطلاعات كسب و
كار از موضوعاتی نظیر (مشتریان، كارمندان، فروشندگان و غیره) و
فعالیتهایی چون (سفارشات، پرداختها، خریدها و غیره) تشكيل شده است.
طراحی پایگاه دادهها، فرایند تصمیم گیری درباره نحوه سازماندهی این
دادهها در انواع ركوردها و برقراری ارتباط بین ركوردهاست.سیستم مدیریت
پایگاه دادهها میتواند ساختار دادهها و ارتباط آنها را در سازمان به
طور اثر بخش نشان دهد. سه نوع مدل متداول سازمانی عبارتند از: سلسله
مراتبی، شبكهای و رابطهای. يك سیستم مدیریت پایگاه دادهها ممكن است يك،
دو یا هر سه روش را فراهم آورد. سرورهای پایگاه دادهها، كامپیوترهایی
هستند كه پایگاه دادههای واقعی را نگاه میدارند و فقط سیستم مدیریت
پایگاه دادهها و نرمافزار مربوطه را اجرا میكنند. معمولا این سرورها
رایانههای چند پردازندهای با آرایههای ديسك RAID برای ذخیره سازی
میباشند.
5- فهرست سیستمهای متداول مدیریت دادگان
معروفترین این نرمافزارهای مدیریت دادگانها میتوان به چند نمونه زیر اشاره کرد:
1.Oracle
2.Microsoft SQL Server
3.MySQL
4.PostregSQL
5.DB2
6.Microsoft Access
واژه دادگان از برابرنهادههای فرهنگستان زبان فارسی میباشد.
|