Перейти к содержимому

Как узнать строку подключения к sql server

  • автор:

Синтаксис строки подключения

Каждый поставщик данных платформы .NET Framework имеет объект Connection , наследующий из DbConnection, а также из свойства ConnectionString, зависящего от поставщика. Конкретный синтаксис строки подключения для каждого поставщика приведен в его свойстве ConnectionString . В следующей таблице представлен список четырех поставщиков данных, поставляемых в составе платформы .NET Framework.

Поставщик данных .NET Framework Описание
System.Data.SqlClient Предоставляет доступ к данным для Microsoft SQL Server. Дополнительные сведения о синтаксисе строки подключения см. в разделе ConnectionString.
System.Data.OleDb Предоставляет доступ к данным источников данных OLE DB. Дополнительные сведения о синтаксисе строки подключения см. в разделе ConnectionString.
System.Data.Odbc Предоставляет доступ к данным источников данных ODBC. Дополнительные сведения о синтаксисе строки подключения см. в разделе ConnectionString.
System.Data.OracleClient Предоставляет доступ к данным Oracle версии 8.1.7 или старше. Дополнительные сведения о синтаксисе строки подключения см. в разделе ConnectionString.

Построители строк подключения

В ADO.NET 2.0 появились указанные ниже построители строк соединения для поставщиков данных .NET Framework.

  • SqlConnectionStringBuilder
  • OleDbConnectionStringBuilder
  • OdbcConnectionStringBuilder
  • OracleConnectionStringBuilder

Построители строк соединения позволяют создавать во время выполнения синтаксически правильные строки соединения, и поэтому в коде не требуется вручную объединять значения строк соединения. Дополнительные сведения см. в статье Connection String Builders (Построители строк подключения).

Проверка подлинности Windows

Для соединения с источниками данных рекомендуется использовать проверку подлинности Windows (которую также называют встроенной безопасностью), если эти источники ее поддерживают. Синтаксис строки подключения зависит от поставщика. В следующей таблице показан синтаксис проверки подлинности Windows, который используется с поставщиками данных платформы .NET Framework.

Поставщик Синтаксис
SqlClient Integrated Security=true;

Значение Integrated Security=true вызывает исключение при работе с поставщиком OleDb .

Строки подключения SqlClient

Синтаксис для строки подключения SqlConnection документирован в свойстве SqlConnection.ConnectionString. Свойство ConnectionString используется для возврата или задания строки подключения для базы данных SQL Server. Если необходимо подключиться к более ранней версии SQL Server, следует использовать поставщик данных .NET Framework для OleDb (System.Data.OleDb). Наиболее распространенные ключевые слова строк соединения также соответствуют свойствам SqlConnectionStringBuilder.

Для ключевого слова Persist Security Info используется значение по умолчанию false . Значение true или yes позволяет получить из строки соединения конфиденциальные данные (в том числе идентификатор пользователя и пароль) после открытия соединения. Задайте для Persist Security Info значение false , чтобы убедиться, что ненадежный источник не сможет получить доступ к конфиденциальным данным строки подключения.

Проверка подлинности Windows при работе с SqlClient.

Все следующие формы синтаксиса используют для подключения к базе данных AdventureWorks, размещенной на локальном сервере, проверку подлинности Windows.

"Persist Security Info=False;Integrated Security=true; Initial Catalog=AdventureWorks;Server=MSSQL1" "Persist Security Info=False;Integrated Security=SSPI; database=AdventureWorks;server=(local)" "Persist Security Info=False;Trusted_Connection=True; database=AdventureWorks;server=(local)" 

Проверка подлинности SQL Server с использованием SqlClient.

Для соединения с SQL Server предпочтительно использовать проверку подлинности Windows. Однако если требуется проверка подлинности SQL Server, то имя пользователя и пароль указываются с помощью приведенного ниже синтаксиса. В этом примере символы звездочки представляют допустимое имя пользователя и пароль.

"Persist Security Info=False;User Catalog=AdventureWorks;Server=MySqlServer" 

Если при подключении к Базе данных SQL Azure или хранилищу данных Azure SQL имя входа предоставляется в формате user@servername , значение servername в имени входа должно соответствовать значению, указанному для Server= .

Проверка подлинности Windows имеет приоритет над именами входа SQL Server. Если указать значение Integrated Security=true, а также ввести имя пользователя и пароль, то имя пользователя и пароль не будут учитываться и будет применяться проверка подлинности Windows.

Подключение к именованному экземпляру SQL Server

Чтобы подключиться к именованному экземпляру SQL Server, используйте синтаксис имя_сервера\имя_экземпляра.

"Data Source=MySqlServer\\MSSQL1;" 

Кроме того, в свойстве DataSource объекта SqlConnectionStringBuilder можно задать имя экземпляра при построении строки подключения. Свойство DataSource объекта SqlConnection доступно только для чтения.

Изменения версий системы типов

Ключевое слово Type System Version в SqlConnection.ConnectionString указывает клиентское представление типов SQL Server. Дополнительные сведения о ключевом слове SqlConnection.ConnectionString см. в разделе Type System Version .

Подключение и присоединение к пользовательским экземплярам SQL Server Express

Пользовательские экземпляры являются одной из возможностей SQL Server Express. Они дают пользователям под учетной записью с минимальными правами возможность присоединить и запустить базу данных SQL Server без прав администратора. Пользовательский экземпляр выполняется с учетными данными пользователя Windows, а не службы.

Использование ключевого слова TrustServerCertificate

Ключевое слово TrustServerCertificate применяется только при подключении к экземпляру SQL Server с допустимым сертификатом. Если ключевому слову TrustServerCertificate присвоено значение true , то транспортный уровень будет использовать протокол SSL для шифрования канала и не пойдет по цепочке сертификатов для проверки доверия.

"TrustServerCertificate=true;" 

Если ключевому слову TrustServerCertificate присвоено значение true и включено шифрование, то будет использоваться уровень шифрования, заданный на сервере, даже если в строке подключения Encrypt задано значение false . В противном случае соединение не будет установлено.

Включение шифрования

Чтобы включить шифрование, когда на сервере не представлен сертификат, в диспетчере конфигурации SQL Server необходимо настроить параметры Принудительное шифрование протокола и Доверять сертификату сервера. В этом случае шифрование будет использовать самозаверяющий сертификат сервера, не проверяя наличия подтверждаемого сертификата сервера.

Настройки приложения не могут снизить установленный на SQL Server уровень безопасности, но при необходимости могут повысить его. Приложение может затребовать шифрование, присвоив ключевым словам TrustServerCertificate и Encrypt значение true , гарантируя тем самым, что шифрование будет выполняться, даже если сертификат сервера не подготовлен и для клиента не настроен параметр Принудительное шифрование протокола. Но если на клиенте не установлен параметр TrustServerCertificate , то сертификат сервера, тем не менее, потребуется.

В следующей таблице перечислены все случаи.

Параметр «Принудительное шифрование протокола» на клиенте Параметр «Доверять сертификату сервера» на клиенте Строка или атрибут «Шифровать/Использовать шифрование для подключения к данным» Строка подключения или атрибут «Доверять сертификату сервера» Результат
нет Н/Д Нет (по умолчанию) Не учитывается Шифрование отсутствует.
нет Н/Д Да Нет (по умолчанию) Шифрование применяется только при наличии подтверждаемого сертификата сервера, в противном случае попытка соединения завершается неудачно.
нет Н/Д Да Да Шифрование производится всегда, однако при этом может использоваться самозаверяющий сертификат сервера.
Да нет Не учитывается Не учитывается Шифрование применяется только при наличии подтверждаемого сертификата сервера, в противном случае попытка подключения завершается сбоем.
Да Да Нет (по умолчанию) Не учитывается Шифрование производится всегда, однако при этом может использоваться самозаверяющий сертификат сервера.
Да Да Да Нет (по умолчанию) Шифрование применяется только при наличии подтверждаемого сертификата сервера, в противном случае попытка подключения завершается сбоем.
Да Да Да Да Шифрование производится всегда, однако при этом может использоваться самозаверяющий сертификат сервера.

Строки соединения OleDb

Свойство ConnectionString класса OleDbConnection позволяет получить или задать строку подключения для источника данных OLE DB (например, Microsoft Access). Строку подключения OleDb также можно создать во время выполнения с помощью класса OleDbConnectionStringBuilder.

Синтаксис строки соединения OleDb

В строке соединения OleDbConnection необходимо указать имя поставщика. Следующие строки подключения подключают к базе данных Microsoft Access, использующей поставщик Jet. Обратите внимание, что ключевые слова User ID и Password необязательны, если база данных не защищена (по умолчанию).

Provider=Microsoft.Jet.OLEDB.4.0; Data Source=d:\Northwind.mdb;User >Если база данных Jet защищена на уровне пользователя, необходимо указать местоположение файла сведений рабочей группы (MDW-файла). Файл сведений рабочей группы используется для проверки учетных данных, указанных в строке подключения.
Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d:\Northwind.mdb;Jet OLEDB:System Database=d:\NorthwindSystem.mdw;User 

Сведения о подключении для OleDbConnection можно указать в UDL-файле; однако следует избегать этого. UDL-файлы не подвергаются шифрованию, и строки соединения хранятся в них в виде простого текста. Так как UDL-файл представляет собой внешний файловый ресурс для приложения, его нельзя защитить средствами .NET Framework. UDL-файлы не поддерживаются для SqlClient.

Соединение с Access/Jet с помощью строки замены DataDirectory

Строка замены DataDirectory поддерживается не только клиентом SqlClient . Ее можно также использовать с поставщиками данных .NET для System.Data.OleDb и System.Data.Odbc. В следующем образце строки OleDbConnection приведен синтаксис для подключения к базе данных Northwind.mdb, расположенной в папке приложения app_data. В этой папке также хранится системная база данных (System.mdw).

"Provider=Microsoft.Jet.OLEDB.4.0; Data Source=|DataDirectory|\Northwind.mdb; Jet OLEDB:System Database=|DataDirectory|\System.mdw;" 

Указывать расположение системной базы данных в строке подключения не требуется, если база данных Access/Jet не защищена. Защита снята по умолчанию, все пользователи соединяются как встроенный пользователь Admin с пустым паролем. База данных Jet остается уязвимой для атаки, даже если правильно реализована безопасность на уровне пользователя. Поэтому в базе данных Access/Jet не рекомендуется хранить конфиденциальные данные, поскольку схема безопасности на основе файловой системы неизбежно обладает определенной уязвимостью.

Соединение с Excel

Поставщик Microsoft Jet используется для подключения с книгой Excel. В следующей строке подключения ключевое слово Extended Properties задает специфические свойства Excel. «HDR=Yes;» показывает, что первая строка содержит имена столбцов, а не данные, а «IMEX=1;» дает указания драйверу всегда считывать «смешанные» столбцы данных как текст.

Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\MyExcel.xls;Extended Properties=""Excel 8.0;HDR=Yes;IMEX=1"" 

Обратите внимание, что двойные кавычки, необходимые для ключевого слова Extended Properties , также должны заключаться в двойные кавычки.

Синтаксис строки подключения с поставщиком Data Shape

При соединении с поставщиком Microsoft Data Shape используются оба ключевых слова: Provider и Data Provider . В следующем примере поставщик Data Shape используется для подключения к экземпляру SQL Server.

"Provider=MSDataShape;Data Provider=SQLOLEDB;Data Source=(local);Initial Catalog=pubs;Integrated Security=SSPI;" 

Строки подключения ODBC

Свойство ConnectionString класса OdbcConnection позволяет получить или задать строку подключения для источника данных OLE DB. Строки подключения ODBC также поддерживаются построителем OdbcConnectionStringBuilder.

Следующая строка подключения использует текстовый драйвер Microsoft.

Driver=;DBQ=d:\bin 

Использование строки замены DataDirectory для соединения с Visual FoxPro

Следующий образец строки подключения OdbcConnection демонстрирует использование DataDirectory для соединения с файлом Microsoft Visual FoxPro.

"Driver=; SourceDB=|DataDirectory|\MyData.DBC;SourceType=DBC;" 

Строки подключения Oracle

Свойство ConnectionString класса OracleConnection позволяет получить или задать строку подключения для источника данных OLE DB. Строки подключения Oracle также поддерживаются построителем OracleConnectionStringBuilder.

Data Source=Oracle9i;User 

Дополнительные сведения о синтаксисе строки подключения ODBC см. в разделе ConnectionString.

См. также

  • Строки подключения
  • Подключение к источнику данных
  • Общие сведения об ADO.NET

MS SQL Server в .NET

MS SQL Server — одна из наиболее популярных систем управления базами данных, а при работе с фреймворком .NET, возможно, наиболее часто выбираемая СУБД. И в этой части руководства рассмотрим подключение к MS SQL Server.

Строка подключения для MS SQL Server

Для работы с MS SQL Server естественно нам потребуется MS SQL Server. Можно выбрать как полноценный MS SQL Server (в весиях Enterprise, Developer), так и MS SQL Server Express.

Про установку MS SQL Server в выпусках Developer или Express можно почитать в статье Установка MS SQL Server

Также можно использовать специально предназначенный для целей разработки и тестирования легковесный движок MS SQL Server Express LocalDB, про установку которого можно почитать в статье Установка SQL Server Express LocalDB.

Вначале необходимо определить строку подключения, которая содержит набор параметров сервера MS SQL Server. Строка подключения представляет набор параметров в виде пар ключ=значение , которые отделяются друг от друга точкой с запятой.

Прежде всего, определение строки подключения зависит от типа подключения: либо мы подлючаемся по логину и паролю, либо мы используем доверенное подключение (trusted connection), где не требуются логин и пароль (например, при подключении к локальному серверу SQL Server).

Если подключение производится по логину и паролю, то общий вид строки подключения выглядит следующим образом:

Server=адрес_сервера;Database=имя_базы_данных;User >В данном случае строка подключения состоит из четырех параметров:
  • Server : указывает на название сервера
  • Database : указывает на название базы данных на сервере
  • User Id : логин
  • Password : пароль

Если мы используем так называемое доверенное подключение (trusted connection) и применяем аутентификацию Windwows, например, при подключении к локальному серверу, который запущен на том же компьютере, то строка подключения в общем виде выглядит следующим образом:

Server=адрес_сервера;Database=имя_базы_данных;Trusted_Connection=True;

Вместо параметров User Id и Password , здесь применяется параметр Trusted_Connection=True . Значение True указывает, что будет применяться аутентификация на основе учетных записей Windows.

Список основных параметров строки подключения, которые могут использоваться:

  • Application Name : название приложения. Может принимать в качестве значения любую строку. Значение по умолчанию: «.Net SqlClient Data Provide»
  • AttachDBFileName : хранит полный путь к прикрепляемой базе данных
  • Connect Timeout : временной период в секундах, через который ожидается установка подключения. Принимает одно из значений из интервала 0–32767. По умолчанию равно 15. В качестве альтернативного названия параметра может использоваться Connection Timeout
  • Server : название экземпляра SQL Servera, с которым будет идти взаимодействие. Это может быть название локального сервера, например, «./SQLEXPRESS», «localhost», либо сетевой адрес. В качестве альтернативного названия параметра можно использовать Data Source , Address , Addr и NetworkAddress
  • Encrypt : устанавливает шифрование SSL при подключении. Может принимать значения true , false , yes и no . По умолчанию значение false
  • Database : хранит имя базы данных В качестве альтернативного названия параметра можно использовать Initial Catalog
  • Trusted_Connection : задает режим аутентификации. Может принимать значения true , false , yes , no и sspi . По умолчанию значение false Если значение true , то для аутентификации будет использоваться текущая учетная запись Windows. Подходит для подключения к локальному серверу. В качестве альтернативного названия параметра может использоваться Integrated Security
  • Packet Size : размер сетевого пакета в байтах. Может принимать значение, которое кратно 512. По умолчанию равно 8192
  • Persist Security Info : указывает, должна ли конфиденциальная информация передаваться обратно при подключении. Может принимать значения true , false , yes и no . По умолчанию значение false
  • Pooling : если значение равно true , любое новое подключение при его закрытии добавляется в пул подключений. В следующий раз при создании такого же подключения (которое имеет ту же самую строку подключения) оно будет извлекаться из пула. Может принимать значения true , false , yes и no . По умолчанию значение true
  • Workstation ID : указывает на рабочую станцию — имя локального компьютера, на котором запущен SQL Server
  • Password : пароль пользователя
  • User ID : логин пользователя

В данном случае мы будем использовать к локальному серверу. Если мы подключаемся к полноценному серверу MS SQL Server (например, версия Developer Edition), то в качестве адреса сервера, как правило, выступает localhost :

string connectionString = "Server=localhost;Database=master;Trusted_Connection=True;"; // альтернатива // string connectionString = "Server=.;Database=master;Trusted_Connection=True;";

Если установлен MS SQL Server Express , то адрес сервера — «.\SQLEXPRESS»

string connectionString = "Server=.\SQLEXPRESS;Database=master;Trusted_Connection=True;";

Для подключения к localdb применяется адрес (localdb)\mssqllocaldb :

string connectionString = "Server=(localdb)\\mssqllocaldb;Database=master;Trusted_Connection=True"

Строка подключения MS SQL Server в локальной сети

Добавьте информацию о способе авторизации на MS SQL сервере. Имею ввиду проверка подлинности Windows или SQL?

17 апр 2019 в 6:38

@XelaNimed , по-моему проверка подлинности windows, но могу ошибаться, если владеете информацией по обоим способам, дайте ответ для двух случаев. Спасибо

17 апр 2019 в 6:44
17 апр 2019 в 6:56

2 ответа 2

Сортировка: Сброс на вариант по умолчанию

Повторюсь, но как уже указал @Streletz все возможные виды подключений есть здесь.

Как должна выглядеть строка подключения к MS SQL Server 2008 при условии, что экземпляр MS SQL Server установлен на одном из удалённых компьютеров, расположенных в локальной сети? (Подключаемся к экземпляру с удалённого компьютера в той же локальной сети).

Data Source=ServerName;Initial Catalog=DbName;Integrated Security=True 

или при использовании проверки подлинности SQL сервера

  • как в примере указывать на имя сервера;
  • IP-адрес с портом: 192.168.200.100,1433 ;
  • (localdb)\MsSqlLocalDB для подключения к именованному экземпляру LocalDB
    (например к тому, что устанавливается с Visual Studio);
  • Application Name=MyApplication;
  • Workstation >

Изменится ли строка подключения, если для входа в учётную запись windows компьютера, на котором установлен экземпляр MS SQL Server, требуется ввести логин и пароль пользователя, если да, то как?

Могу быть не прав, но мне кажется, что нет, т.к. Вы подключаетесь к SQL серверу, а не открываете сессию удалённого доступа. Если нет явной необходимости, то используйте проверку подлинности Windows для доступа к БД.

Как быстро проверить подключение к серверу MS SQL

При диагностике проблем в работе приложения одно из стандартных действий — это проверка подключения к базе данных. Протестировать подключение к серверу баз данных можно разными способами и сегодня я расскажу об одном из них. Этот способ отличается тем, что он очень прост и для его использования не требуется никакого дополнительного ПО.

Суть способа заключается в использовании файлов UDL. Файлы формата UDL (Universal Data Link) используются приложениями Windows для хранения информации, необходимой для подключения к источнику данных. Также они могут использоваться для тестирования соединения с источником данных.

Сама процедура проверки крайне проста. Сначала создаем на рабочем столе пустой текстовый файл

создание текстового файла

и изменяем его расширение на udl.

смена расширения файла

По умолчанию файлы UDL открываются с помощью встроенной утилиты «Data Link Properties». Для открытия файла надо дважды кликнуть по нему, после чего откроется диалоговое окно утилиты. Для проверки надо на вкладке «Connection» указать имя сервера, учетные данные для подключения, затем выбрать нужную базу данных и нажать «Test Connection».

основные настройки подключения

В случае успешного подключения будет выведено соответствующее уведомление.

результат подключения

При необходимости можно изменить дополнительные параметры подключения. На вкладке «Provider» можно изменить провайдера для подключения к базе.

выбор провайдера

На вкладке «Advanced» можно указать таймаут подключения и задать дополнительные разрешения.

дополнительные настройки подключения

Ну а если требуется задать какие то специфические свойства подключения, то их можно найти на вкладке «All». Например можно задать атрибут Failover Partner для тестирования Database Mirroring. Обратите внимание, что набор атрибутов зависит от выбранного провайдера.

все настройки

Как видите, способ действительно очень простой. Конечно он не позволяет произвести более сложные проверки, но вполне подходит для первичной диагностики.

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *