File Stream yapısı, varbinary(MAX) BLOB nesneleri(doküman, resim, video vb.) sunucu üzerindeki NTFS File system üzerinde veritabanı ile bütünleşik yapıda tutar. File system üzerinde file stream dosyaları oluşturur ve bu dosyaları veritabanının bir parçası yapar. Blob nesneleri NTFS file system’de file stream yapıda tutmak yerine, tabloda varbinary(MAX) veri tipini kullanarak veritabanının içine de gömebiliriz. Eğer dosyalarınız genel olarak 1 MB’tan küçükse veritabanı üzerinde tutmanız performansı arttıracaktır. Bununla beraber BLOB verilerin boyutu büyük olduğu için veritabanı yönetimini zorlaştıracaktır.(Backup, DBCC CHECKDB,Restore vb.)
BLOB nesneleri File Stream kullanarak file system üzerinde tuttuğumuzda sanki veritabanının içindeymiş gibi tsql ile insert, update ve delete yapabiliyoruz. Ayrıca full backup aldığımız zaman, file stream verinin de backup’ını almış oluyoruz.
File Stream yapısının ne olduğunu daha açık bir şekilde anlatmak için FileStream kullanan bir veritabanı oluşturalım.
Öncelikle instance seviyesinde File Stream’i enable etmemiz gerekir. SQL Server Configuration Manager’ı açarak SQL Server Services kısmına geliyoruz ve sağ tarafta file stream’i enable etmek istediğimiz instance üzerinde sağ tıklayarak properties diyoruz.
Açılan ekranda FILESTREAM tab’ına geliyoruz ve Enable FILESTREAM for Transact-SQL access seçeneğini seçerek ok diyoruz.
Enable FILESTREAM for Transact-SQL access seçeneği file stream veriye transact sql erişimi için izin verdiğimiz anlamına geliyor.
Enable FILESTREAM for file I/O access seçeneği ise filestream için bir şeyi değiştirmez. Bu özelliği aktifleştirdiğinizde File Table’lara Windows üzerinden bir share gibi erişebilirsiniz. “ File Table Nedir ve File Stream’den Farkları Neler ” isimli makaleyi okumanızı öneririm.
Allow remote clients access to FILESTREAM data seçeneği ise file stream verisine uzak bilgisayarlardan erişim için izin vermemizi sağlıyor. Bu seçeneği de aktif etmenizi güvenlik gereği önermiyorum.
Daha sonra aşağıdaki script yardımıyla sp_configure üzerinden filestream’i açıyoruz. Sp_configure üzerinden yapılabilecek diğer işlemler için “ sp_configure(SQL Server’da Server Seviyesinde Konfigurasyonlar) ” isimli makalemi okumak isteyebilirsiniz.
EXEC sys.sp_configure N'filestream access level', N'1' GO RECONFIGURE WITH OVERRIDE GO
Aynı işlemi instance üzerinde sağ tıklayarak properties dedikten sonra Advanced sekmesinden FILESTREAM Access Level’den Transact-SQL access enabled seçeneğini seçerek de gerçekleştirebiliriz.
Bu işlemler bittikten sonra SQL Server Configuration Manager üzerinden SQL Server’ı restart etmemiz gerekiyor.
“ SQL Server Configuration Manager Ayarları ” isimli makalemde Configuration Manager üzerinden yapılabilecek diğer işlemleri görebilirsiniz.
FileStream kullanan bir veritabanı oluşturmak:
SSMS üzerinde Instance’ın altında Databases sekmesinde sağ tıklayarak aşağıdaki gibi New Database… diyoruz.
Öncelikle FileStream içermeden normal bir veritabanını aşağıdaki gibi oluşturalım. Veritabanı oluşturmak basit bir iş gibi gözükebilir fakat büyük sistemler için default değerlerle veritabanı oluşturursanız sonrasında başınız çok ağrıyacaktır. Bu yüzden “ Veritabanı Oluşturmak Deyip Geçmeyin! ” isimli makalemi okumanızı tavsiye ediyorum.
Veritabanını oluşturduktan sonra SSMS üzerinde veritabanına sağ tıklayarak properties diyoruz ve Filegroups sekmesinden aşağıda gördüğünüz gibi Add Filegroup diyerek filegroup’a bir isim veriyoruz. Ben FILESTREAMGROUP ismini verdim.
File Stream için bir filegroup oluşturduktan sonra veritabanına SSMS üzerinden tekrar sağ tıklıyoruz ve properties diyoruz.
Daha sonra aşağıdaki ekrandan Add diyerek Logical Name’ bir isim veriyoruz. Ben FileStreamVeri ismini verdim.
File Type kısmından FILESTREAM Data seçeneğini seçiyoruz.
Filegroups kısmından da, daha önce oluşturduğumuz FILESTREAMGROUP filegroup’unu seçiyoruz.
Path kısmındanda File Stream verinin konumlanacağı diski ve klasörü seçerek ok diyoruz.
Bu oluşturduğum veritabanının create script’ini almak için aşağıdaki gibi veritabanı üzerinde sağ tıklayarak Script Database as-> Create to->New query editor diyebilirsiniz.
Veritabanının create script’i aşağıdaki gibidir:
USE [master] GO CREATE DATABASE [FileStreamDB] CONTAINMENT = NONE ON PRIMARY ( NAME = N'FileStreamDB', FILENAME = N'C:\MSSQL\FileStreamDB.mdf' , SIZE = 262144KB , MAXSIZE = UNLIMITED, FILEGROWTH = 262144KB ), FILEGROUP [FILESTREAMGROUP] CONTAINS FILESTREAM DEFAULT ( NAME = N'FileStreamVeri', FILENAME = N'C:\MSSQL\FileStreamVeri' , MAXSIZE = UNLIMITED) LOG ON ( NAME = N'FileStreamDB_log', FILENAME = N'C:\MSSQL\FileStreamDB_log.ldf' , SIZE = 262144KB , MAXSIZE = 2048GB , FILEGROWTH = 262144KB ) GO ALTER DATABASE [FileStreamDB] SET COMPATIBILITY_LEVEL = 120 GO IF (1 = FULLTEXTSERVICEPROPERTY('IsFullTextInstalled')) begin EXEC [FileStreamDB].[dbo].[sp_fulltext_database] @action = 'enable' end GO ALTER DATABASE [FileStreamDB] SET ANSI_NULL_DEFAULT OFF GO ALTER DATABASE [FileStreamDB] SET ANSI_NULLS OFF GO ALTER DATABASE [FileStreamDB] SET ANSI_PADDING OFF GO ALTER DATABASE [FileStreamDB] SET ANSI_WARNINGS OFF GO ALTER DATABASE [FileStreamDB] SET ARITHABORT OFF GO ALTER DATABASE [FileStreamDB] SET AUTO_CLOSE OFF GO ALTER DATABASE [FileStreamDB] SET AUTO_SHRINK OFF GO ALTER DATABASE [FileStreamDB] SET AUTO_UPDATE_STATISTICS ON GO ALTER DATABASE [FileStreamDB] SET CURSOR_CLOSE_ON_COMMIT OFF GO ALTER DATABASE [FileStreamDB] SET CURSOR_DEFAULT GLOBAL GO ALTER DATABASE [FileStreamDB] SET CONCAT_NULL_YIELDS_NULL OFF GO ALTER DATABASE [FileStreamDB] SET NUMERIC_ROUNDABORT OFF GO ALTER DATABASE [FileStreamDB] SET QUOTED_IDENTIFIER OFF GO ALTER DATABASE [FileStreamDB] SET RECURSIVE_TRIGGERS OFF GO ALTER DATABASE [FileStreamDB] SET DISABLE_BROKER GO ALTER DATABASE [FileStreamDB] SET AUTO_UPDATE_STATISTICS_ASYNC OFF GO ALTER DATABASE [FileStreamDB] SET DATE_CORRELATION_OPTIMIZATION OFF GO ALTER DATABASE [FileStreamDB] SET TRUSTWORTHY OFF GO ALTER DATABASE [FileStreamDB] SET ALLOW_SNAPSHOT_ISOLATION OFF GO ALTER DATABASE [FileStreamDB] SET PARAMETERIZATION SIMPLE GO ALTER DATABASE [FileStreamDB] SET READ_COMMITTED_SNAPSHOT OFF GO ALTER DATABASE [FileStreamDB] SET HONOR_BROKER_PRIORITY OFF GO ALTER DATABASE [FileStreamDB] SET RECOVERY FULL GO ALTER DATABASE [FileStreamDB] SET MULTI_USER GO ALTER DATABASE [FileStreamDB] SET PAGE_VERIFY CHECKSUM GO ALTER DATABASE [FileStreamDB] SET DB_CHAINING OFF GO ALTER DATABASE [FileStreamDB] SET FILESTREAM( NON_TRANSACTED_ACCESS = OFF ) GO ALTER DATABASE [FileStreamDB] SET TARGET_RECOVERY_TIME = 0 SECONDS GO ALTER DATABASE [FileStreamDB] SET DELAYED_DURABILITY = DISABLED GO ALTER DATABASE [FileStreamDB] SET READ_WRITE GO
Veritabanını oluşturduktan sonra sıra file stream veri içeren tablo oluşturmaya geldi.
Aşağıdaki script yardımıyla tabloyu oluşturuyoruz.
USE FileStreamDB GO CREATE TABLE FileStreamOrnekTablo ( [ID] [uniqueidentifier] ROWGUIDCOL NOT NULL UNIQUE, [DocumanAdi] varchar(500), [DokumanDetay] VARBINARY(MAX) FILESTREAM NULL ) GO
Eğer tabloda uniqueidentifier tipinde bir kolon ROWGUIDCOL ve NOT NULL olarak bulunmassa tablo oluştururken aşağıdaki gibi hata alırsınız.
Msg 5505, Level 16, State 1, Line 1
A table that has FILESTREAM columns must have a nonnull unique column with the ROWGUIDCOL property.
FileStream veri içeren bir veritabanının backup ve restore işlemini normal backup restore işlemleri gibi yapabiliriz.
FileStream veri içeren bir veritabanının detach ve attach işlemlerini yapmak için “ FileStream Veri İçeren Veritabanının Detach ve Attach Edilmesi ” isimli makalemden faydalanabilirsiniz.