پیش از آشنایی با FileTable نیاز است که پیشینهای از شیوههای ذخیرهسازی فایل و یا بهتر بگویم BLOB در SQL Server را داشته باشیم.
نخستین شیوهى نگهداری فایل استفاده از Image است که در SQL Server 2000 کاربرد داشت و هماکنون استفاده از آن به دلیل کاهش بسیار کارآیی منسوخشده است. به دلایل مشکلات بسیار فراوان Image همزمان بسیاری از طراحان پایگاه دادهها، جهت کاهش حجم جدولها و پیروی آن حجم پایگاه دادهها، فایل را در سیستمفایل نگهداری میکردند و تنها مسیر آن را در فیلدی از نوع کاراکتری در پایگاهدادهها ذخیره میکردند. این روش هرچند از حجم پایگاه دادهها میکاست ولی به دلیل عدم دخالت SQL Server در مدیریت فایلها مشکلات دیگری را به وجود آورد.
از SQL Server 2005 نوع دادهى varbinary(max) معرفی شد که برخی از چالشهای بهکاربری Image را کاست و دربارهى بسیاری از موارد مانند ذخیرهى عکس پرسنلی هنوز هم کاربرد دارد؛ ولی توجه داشته باشید که استفاده از این فیلد فقط برای فایلهای کمتر از 256 کیلوبایت سفارش شده است و برای بالاتر از آن، کارآیی کاهش فراوانی خواهد یافت.
در SQL Server 2008 نوع دادهى جدیدی به نام FileStream به وجود آمد به این شکل که یک FileGroup از نوع Data FileStream به پایگاهداده افزوده میشود و در واقع با یک پوشه در سیستم فایل در پیوند است. از این پس هنگام ساخت یک جدول به جای استفاده از نوع دادهى varbinary از نوع FileStream استفاده میکنیم با مد نظر داشتن این نکته که حتماً باید یک فیلد از نوع Uniqueidentifier هم در آن جدول تعریف شده باشد. شیوهى کار نیز به این صورت خواهد بود که خود رکورد در جدول ذخیره میشود و فقط محتوای فایل در آن مسیری از NTFS ذخیره میشود. برخلاف روش درج مسیر فایل در جدول که پس از حذف رکورد، فایل همچنان در سیستم فایل میماند؛ این بار با حذف رکورد فایل مربوطه نیز حذف خواهد شد. افزون بر این مدیریت پشتیبانی از فایلها نیز برعهدهى پایگاه دادهها خواهد بود. اندازهى فایلها در FileStream محدودیتهای پیشین را نخواهد داشت و شما به اندازهى حجم درایو هارددیسک میتوانید فایل در آن ذخیره کنید. نکتهى دیگر دربارهى فایلهای با حجم سنگین که میتوانید Stream مربوط به یک فایل را به صورت بخشبخش در سمت مشتری بارگذاری کنید و به او نشان دهید. در FileStream امنیت و تراکنش فایلها برعهدهى SQL Server است و از این دیدگاه بسیار سادهتر و کارآتر از FileSystem است.
گونهى FileTable از ویژگیهای نوین SQL Server 2012 است که تکمیلکنندهى FileStream است. FileTable آمیزشی از FileStream با hierarchyid و سیستم فایل ویندوز برای ارائهى تواناییهای نوین مدیریت BLOB در SQL Server است. FileTable همانگونه که از دو واژهى تشکیلدهندهاش پیداست؛ همزمان یک جدول و یک سیستم فایل معمولی است.
FileTable به هر روی یک جدول از پایگاهدادههای SQL Server است با یک تفاوت که ساختار آن از پیش تعریفشده است. ستونهای FileTable و نوع دادهى آن از پیش توسط SQL Server مشخص شده است. ستونهای تشکیلدهندهى FileTable دربرگیرندهى جدول زیر است:
هر ردیف از FileTable نمایندهى یک فایل یا پوشه در File System است. ستون path_locator که از نوع hierarchyid است نشاندهندهى مسیر یک فایل یا پوشه است. hierarchyid که از SQL Server 2008 معرفی شده است؛ بهترین نوع داده برای نگهداری ارتباط ساختار سلسلهمراتبی مانند چارت سازمانی، درخت تجهیزات یک کارخانه و یا در همین نمونه درخت فایلها و پوشهها است. پس میتوانیم از همهى امکانات hierarchyid در FileTable نیز برخوردار شویم. اینکه این فایل به ترتیب در چه پوشههایی قرار گرفته است یا اینکه این پوشه شامل چه فایلها یا پوشههایی خواهد بود. اینکه پوشههای همفرزند پوشهى جاری کدام است و یا یا توابع مربوط به جابهجایی فایلها و پوشهها.
بدون دیدگاه