Skip to content
martincostello edited this page Jan 11, 2015 · 18 revisions

SQL LocalDB Wrapper

Introduction

The System.Data.SqlLocalDb assembly provides a managed .NET API for calling the native C/C++ API of Microsoft SQL Server LocalDB.

This makes it easy for .NET projects to use SQL LocalDB to more easily perform lightweight operations with SQL Server where access to a full installation of Microsoft SQL Server (Express) is either unavailable or undesirable.

For example, the primary motivation for this assembly to be created in the first place was to allow for use of SQL LocalDB instances to test .NET code for SQL Server-based data access in continuous integration test scenarios where I wanted to remove the overhead of maintaining an SQL Server instance on which to run such tests.

Features

The assembly exposes all of the features of the SQL Server Express LocalDB Instance API as well as other convenience methods to provide a more object-oriented API that that of the native API. Other functionality is included to make it easy to connect to instances and use them, such as for manipulating connection strings.

Runtime Requirements

The assembly targets .NET 2.0, so is supported for use in projects targeting .NET 2.0 and later. Therefore the .NET 2.0 Runtime is required to be installed on the local computer.

Both the 2012 and 2014 versions of Microsoft SQL Server LocalDB are supported by the assembly. At least one of these must be installed on the local computer to use the functionality of the assembly. If both versions are installed, then unless overridden by configuration, the latest version of the native API's DLL is always loaded.

Configuration

In the majority of cases, no additional configuration is required to use the assembly to manage SQL LocalDB instances.

The default behavior of SQL LocalDB, however, is to keep the files on-disk (such as logs) that are generated by SQL LocalDB instances during the existence. In a continuous integration usage scenario, where instances are frequently created and deleted, this may create large number of redundant files on the local file system that use up large amounts of disk space.

Since v1.11.0.0 it has been possible to change this behavior programmatically via the API surface.

From v1.13.0.0 it is possible to configure this behavior for the entire consuming application using the <system.data.sqlLocalDb> configuration section. This is the recommended way to setup the assembly for such a usage scenario.

Similarly, stopping instances of SQL LocalDB takes a few seconds with the default settings which retain the default behavior of the native SQL LocalDB Instance API. If you are frequently stopping instances, for example in a continuous integration test scenario, you may wish to change the stop timeout and options to improve performance. An example configuration that improves performance for such a scenario is shown below:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="system.data.sqlLocalDb" type="System.Data.SqlLocalDb.Configuration.SqlLocalDbConfigurationSection, System.Data.SqlLocalDb" />
  </configSections>
  <system.data.sqlLocalDb stopOptions="NoWait" stopTimeout="00:00:10" />
</configuration>

For further details about configuration settings see here.

NuGet

Clone this wiki locally