輕量級數(shù)據(jù)庫SQL?Server?Express?LocalDb介紹
一、介紹
1、SqlLocalDb
全稱:SQL Server Express LocalDb。
簡化SQL Server的本地?cái)?shù)據(jù)庫。SqlLocalDb就是一個(gè)輕量級的基于本地的T-SQL數(shù)據(jù)庫。
SQL Server既可以作為遠(yuǎn)程,也可以做本地。而SqlLocalDb只能作為本地使用,不支持聯(lián)網(wǎng),只能本機(jī)連接。
2、輕量級數(shù)據(jù)庫對比(LocalDB vs. SQL Express vs. Compact)
LocalDB并不能完全替代SQL Server Express,它只是對開發(fā)人員提供了另外一種選擇,并保證與SQL Server Express一致的兼容性。
LocalDB與SQL Server Compact之間有很大區(qū)別。
最新的Microsoft SQL Server Compact 4.0 SP1是一種免費(fèi)的嵌入式數(shù)據(jù)庫,軟件開發(fā)人員可以使用它來構(gòu)建 ASP.NET 網(wǎng)站和 Windows 桌面應(yīng)用程序。
SQL Server Compact 4.0 的優(yōu)點(diǎn)是:占用的空間小,支持在應(yīng)用程序文件夾中專門部署其二進(jìn)制文件,輕松地使用 Visual Studio 和 WebMatrix 進(jìn)行應(yīng)用程序開發(fā),以及無縫地將架構(gòu)和數(shù)據(jù)遷移到 SQL Server。
單獨(dú)下載地址:
https://www.microsoft.com/zh-CN/download/details.aspx?id=30709
CompactView(sdf文件查看器):
https://sourceforge.net/projects/compactview/files/
SQL Server Compact的特點(diǎn):
- 運(yùn)行模式:SQL Server Compact是一個(gè)進(jìn)程內(nèi)(in-proc)DLL,LocalDB則作為獨(dú)立進(jìn)程運(yùn)行。
- 磁盤占用:SQL Server Compact的體積僅有4MB,LocalDB安裝之后則有250MB。
- 功能特性:SQL Server Compact僅提供RDBMS的核心功能,而LocalDB則提供更豐富的功能,比如存儲過程、幾何和地理數(shù)據(jù)類型。
二、安裝這個(gè)SqlLocalDb
Visual Studio 安裝時(shí)會自動裝上MSSQLLocalDB 。
1、通過VS Installer安裝:
Visual Studio 2019 內(nèi)置的SQL Server 2016 Express LocalDB。
如果選了.NET負(fù)載,直接在里面勾上就行;如果沒有,選到單個(gè)組件,勾上localdb,會自動勾上下一項(xiàng)那個(gè)依賴。

2、通過SQL Server Express安裝
最新版單獨(dú)下載SQL Server Express:
https://download.microsoft.com/download/7/f/8/7f8a9c43-8c8a-4f7c-9f92-83c18d96b681/SQL2019-SSEI-Expr.exe
(SQL Server Express入口:https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads)
注:SQL Server 2016 Express LocalDB微軟已經(jīng)在SQL Server Express不再提供,目前為最新的為2019版本。
下載之后,打開該引用,并點(diǎn)擊“下載介質(zhì)”:

在彈出的頁面中,選擇LocalDB(第三個(gè)),點(diǎn)擊下一步下載SqlLocalDB.msi

下載后安裝

安裝后:
2012的版本為11,2016的版本為13,2019的版本為15。

三、連接SqlLocalDB
使用 Windows 身份驗(yàn)證,服務(wù)器類型:數(shù)據(jù)庫引挈。
LocalDB的實(shí)例歸類設(shè)置為SQL_Latin1_General_CP1_CI_AS,不能更改,導(dǎo)致的最直接的結(jié)果就是直接新建數(shù)據(jù)庫會存不了中文。
解決辦法是對于每一個(gè)數(shù)據(jù)庫手動指定排序規(guī)則:
create/alter database DBName COLLATE Chinese_PRC_CI_AS
1、SSMS可以連接此實(shí)例。
連接SqlLocalDB2012 :實(shí)例名: (LocalDb)\v11.0
連接SqlLocalDB2019 :實(shí)例名: (LocalDb)\MSSQLLocalDB

2、VS連接到SQLLoalDB
1、打開Visual Studio 2019,依次點(diǎn)擊“視圖”(菜單欄)->“服務(wù)器資源管理器”,將會打開“服務(wù)器資源管理器”窗口:

2、右鍵點(diǎn)擊“數(shù)據(jù)連接”,在彈出的上下文菜單中選擇“添加連接”,在彈出的窗口中將“服務(wù)器名”設(shè)置為(LocalDb)\MSSQLLocalDB,如下圖所示:

然后附加一個(gè)名稱為MusicDBContext.mdf的數(shù)據(jù)庫文件(文件可以自己定義)并點(diǎn)擊確定,此時(shí),MusicDBContext.數(shù)據(jù)庫作為默認(rèn)的數(shù)據(jù)庫,我們可以選擇SQLLocalDB中的其他已有數(shù)據(jù)庫。
生成的連接字符串如下:
Data Source=(LocalDb)\MSSQLLocalDB;AttachDbFilename=C:\Users\CNC\Desktop\MusicDBContext.mdf;Initial Catalog=MusicDBContext;Integrated Security=True
我們可以將mdf文件的路徑改為相對路徑:
Data Source=(LocalDb)\MSSQLLocalDB;AttachDbFilename=|DataDirectory|\MusicDBContext.mdf;Initial Catalog=MusicDBContext;Integrated Security=True
3、SQL Server 對象管理器可以查看已有的連接

3、編寫程序?qū)σ延袛?shù)據(jù)的讀取
如下代碼所示:
using System;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
namespace ConsoleApp
{
class Program
{
static void Main(string[] args)
{
string connectionString = @"Data Source=(LocalDb)\MSSQLLocalDB;Initial Catalog=MusicDBContext;Integrated Security=True";
SqlConnection connection = new SqlConnection(connectionString);
SqlDataAdapter adapter = new SqlDataAdapter("SELECT * FROM Musics",connection);
DataTable table = new DataTable();
adapter.Fill(table);
var result = (from row in table.Rows.Cast<DataRow>() select new { ID = (int)row[0], Title = (string)row[1], ReleaseDate = (DateTime)row[2] });
result.ToList().ForEach(x => Console.WriteLine($"{x.ID},{x.Title},{x.ReleaseDate}"));
}
}
}運(yùn)行結(jié)果如下:

四、SQL 示例數(shù)據(jù)庫下載

SQL 示例數(shù)據(jù)庫:
- northwind-pubs:
https://github.com/microsoft/sql-server-samples/tree/master/samples/databases/northwind-pubs

- adventureworks:
https://github.com/microsoft/sql-server-samples/tree/master/samples/databases/adventure-works
https://github.com/Microsoft/sql-server-samples/releases/tag/adventureworks

到此這篇關(guān)于輕量級數(shù)據(jù)庫SQL Server Express LocalDb的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持本站。
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。
關(guān)注官方微信