What is FILESTREAM?
Much data is unstructured, such as text documents, images, and videos. This unstructured data is often stored outside the database, separate from its structured data. This separation can cause data management complexities. Or, if the data is associated with structured storage, the file streaming capabilities and performance can be limited.
FILESTREAM integrates the SQL Server Database Engine with an NTFS file system by storing varbinary(max) binary large object (BLOB) data as files on the file system. Transact-SQL statements can insert, update, query, search, and back up FILESTREAM data. Win32 file system interfaces provide streaming access to the data.
FILESTREAM uses the NT system cache for caching file data. This helps reduce any effect that FILESTREAM data might have on Database Engine performance. The SQL Server buffer pool is not used; therefore, this memory is available for query processing.
SQL Server 2008’s FILESTREAM support can be very handy, but often overlooked during installation. It is disabled by default in the installer, but can be enabled at install time, and also post-installation.
Obviously, the easier option is to enable during installation, but if you missed it, the steps to enable are relatively straightforward.
Keep in mind that there are two areas you need to consider: SQL Server Configuration and SQL Server Management Studio – both are responsible for enabling Filestream, but for different reasons.
To enable and change FILESTREAM settings (from MSDN)
-
On the Start menu, point to All Programs, point to Microsoft SQL Server 2008 R2, point to Configuration Tools, and then click SQL Server Configuration Manager.
-
In the list of services, right-click SQL Server Services, and then click Open.
-
In the SQL Server Configuration Manager snap-in, locate the instance of SQL Server on which you want to enable FILESTREAM.
-
Right-click the instance, and then click Properties.
-
In the SQL Server Properties dialog box, click the FILESTREAM tab.
-
Select the Enable FILESTREAM for Transact-SQL access check box.
-
If you want to read and write FILESTREAM data from Windows, click Enable FILESTREAM for file I/O streaming access. Enter the name of the Windows share in the Windows Share Name box.
-
If remote clients must access the FILESTREAM data that is stored on this share, select Allow remote clients to have streaming access to FILESTREAM data.
-
Click Apply.
-
In SQL Server Management Studio, click New Query to display the Query Editor.
-
In Query Editor, enter the following Transact-SQL code:
EXEC sp_configure filestream_access_level, 2 RECONFIGURE
-
Click Execute.
Notes
The reason for the two locations (Configuration Manager and SQL Management Studio) is that FILESTREAM needs to be enabled at the network configuration level, and at the database engine level. If you miss one or the other, Filestream will not be accessible or enabled!
Also note that you cannot enable FILESTREAM on a 32-bit version of SQL Server running on a 64-bit operating system.
Reference
3 thoughts on “Did you forget to enable FILESTREAM during setup?”
To enable FILESTREAM settings on Microsoft SQL Server 2012 is the same?
Hi Rob,
Thank you very much for this article. Without this information I could not go further with my study. Sorry, I can’t give you my real information 🙂
Regards,
A friend
I have a 64 bit SQL Server 2012 running on 64 bit windows 2008 R2. When I click on Enable FILESTREAM for filr I/O access and click on apply then I get an error message that says:
There was an unknown error applying the FILESTREAM Settings.
Check the parameters are valid. (0x80070001)
Do you have any idea why? Any help is highly appreciated!