Partager via


SqlConnectionStringBuilder Classe

Définition

Fournit un moyen simple de créer et de gérer le contenu de chaînes de connexion utilisées par la classe SqlConnection.

public ref class SqlConnectionStringBuilder sealed : System::Data::Common::DbConnectionStringBuilder
[System.ComponentModel.TypeConverter(typeof(Microsoft.Data.SqlClient.SqlConnectionStringBuilder+SqlConnectionStringBuilderConverter))]
public sealed class SqlConnectionStringBuilder : System.Data.Common.DbConnectionStringBuilder
public sealed class SqlConnectionStringBuilder : System.Data.Common.DbConnectionStringBuilder
[<System.ComponentModel.TypeConverter(typeof(Microsoft.Data.SqlClient.SqlConnectionStringBuilder+SqlConnectionStringBuilderConverter))>]
type SqlConnectionStringBuilder = class
    inherit DbConnectionStringBuilder
type SqlConnectionStringBuilder = class
    inherit DbConnectionStringBuilder
Public NotInheritable Class SqlConnectionStringBuilder
Inherits DbConnectionStringBuilder
Héritage
SqlConnectionStringBuilder
Attributs

Exemples

L’application console suivante génère des chaînes de connexion pour une base de données SQL Server. Le code utilise une classe SqlConnectionStringBuilder pour créer la chaîne de connexion, puis passe la propriété ConnectionString de l'instance de SqlConnectionStringBuilder au constructeur de la classe de connexion. L'exemple analyse également une chaîne de connexion existante et présente plusieurs façons de manipuler le contenu de la chaîne de connexion.

Notes

Cet exemple inclut un mot de passe pour illustrer l'utilisation de SqlConnectionStringBuilder avec les chaînes de connexion. Dans vos applications, nous vous recommandons d'utiliser l'authentification Windows. Si vous devez utiliser un mot de passe, n'incluez pas de mot de passe codé en dur dans votre application.

using Microsoft.Data.SqlClient;

class Program
{
    static void Main()
    {
        // Create a new SqlConnectionStringBuilder and
        // initialize it with a few name/value pairs.
        SqlConnectionStringBuilder builder =
            new SqlConnectionStringBuilder(GetConnectionString());

        // The input connection string used the 
        // Server key, but the new connection string uses
        // the well-known Data Source key instead.
        Console.WriteLine(builder.ConnectionString);

        // Pass the SqlConnectionStringBuilder an existing 
        // connection string, and you can retrieve and
        // modify any of the elements.
        builder.ConnectionString = "server=(local);user id=ab;" +
            "password= a!Pass113;initial catalog=AdventureWorks";

        // Now that the connection string has been parsed,
        // you can work with individual items.
        Console.WriteLine(builder.Password);
        builder.Password = "new@1Password";

        // You can refer to connection keys using strings, 
        // as well. When you use this technique (the default
        // Item property in Visual Basic, or the indexer in C#),
        // you can specify any synonym for the connection string key
        // name.
        builder["Server"] = ".";
        builder["Connect Timeout"] = 1000;
        builder["Trusted_Connection"] = true;
        Console.WriteLine(builder.ConnectionString);

        Console.WriteLine("Press Enter to finish.");
        Console.ReadLine();
    }

    private static string GetConnectionString()
    {
        // To avoid storing the connection string in your code,
        // you can retrieve it from a configuration file. 
        return "Server=(local);Integrated Security=SSPI;" +
            "Initial Catalog=AdventureWorks";
    }
}

Remarques

Le générateur de chaînes de connexion permet aux développeurs de créer par programme des chaînes de connexion correctes du point de vue de la syntaxe, et d'analyser et régénérer des chaînes de connexion existantes, à l'aide de propriétés et de méthodes de la classe. Le générateur de chaînes de connexion fournit des propriétés fortement typées correspondant aux paires clé/valeur connues autorisées par SQL Server. Les développeurs ayant besoin de créer des chaînes de connexion dans le cadre d'applications peuvent utiliser la classe SqlConnectionStringBuilder pour générer et modifier des chaînes de connexion. Cette classe permet également de gérer facilement les chaînes de connexion stockées dans un fichier de configuration de l'application.

SqlConnectionStringBuilder vérifie la validité des paires clé/valeur. Par conséquent, il n'est pas possible d'utiliser cette classe pour créer des chaînes de connexion non valides ; toute tentative d'ajout de paires non valides lève une exception. La classe maintient une collection fixe de synonymes et peut traduire un synonyme vers le nom de la clé connue correspondante.

Par exemple, lorsque vous utilisez la propriété Item pour récupérer une valeur, vous pouvez spécifier une chaîne qui contient n’importe quel synonyme pour la clé dont vous avez besoin. Par exemple, vous pouvez spécifier « Adresse réseau », « addr » ou tout autre synonyme acceptable pour cette clé dans un chaîne de connexion lorsque vous utilisez un membre qui nécessite une chaîne qui contient le nom de la clé, comme la propriété Item ou la Remove méthode. Pour obtenir la liste complète des synonymes acceptables, consultez la propriété ConnectionString.

La propriété Item gère tente d’insérer des entrées malveillantes. Par exemple, le code suivant, qui utilise la propriété Item par défaut (l'indexeur en C#) s'échappe correctement de la paire clé/valeur imbriquée :

Dim builder As New Microsoft.Data.SqlClient.SqlConnectionStringBuilder  
builder("Data Source") = "(local)"  
builder("Integrated Security") = True  
builder("Initial Catalog") = "AdventureWorks;NewValue=Bad"  
Console.WriteLine(builder.ConnectionString)  
Microsoft.Data.SqlClient.SqlConnectionStringBuilder builder =  
  new Microsoft.Data.SqlClient.SqlConnectionStringBuilder();  
builder["Data Source"] = "(local)";  
builder["Integrated Security"] = true;  
builder["Initial Catalog"] = "AdventureWorks;NewValue=Bad";  
Console.WriteLine(builder.ConnectionString);  

Le résultat est la chaîne de connexion suivante qui gère la valeur non valide de manière sécurisée.

Source=(local);Initial Catalog="AdventureWorks;NewValue=Bad";  
Integrated Security=True  

Constructeurs

SqlConnectionStringBuilder()

Initialise une nouvelle instance de la classe SqlConnectionStringBuilder.

SqlConnectionStringBuilder(String)

Initialise une nouvelle instance de la classe SqlConnectionStringBuilder. La chaîne de connexion spécifiée fournit les données pour les informations de connexion internes de l'instance.

Propriétés

ApplicationIntent

Déclare le type de charge de travail de l'application lors de la connexion à une base de données dans un groupe de disponibilité SQL Server. Vous pouvez affecter à cette propriété la valeur ApplicationIntent. Pour plus d’informations sur la prise en charge de SqlClient pour les groupes de disponibilité AlwaysOn, consultez Prise en charge de SqlClient pour la haute disponibilité et la récupération d’urgence.

ApplicationName

Obtient ou définit le nom de l'application associée à la chaîne de connexion.

AsynchronousProcessing
Obsolète.

Obsolète. Obtient ou définit une valeur booléenne qui indique si le traitement asynchrone est autorisé par la connexion créée à l'aide de cette chaîne de connexion.

AttachDBFilename

Obtient ou définit une chaîne qui contient le nom du fichier de données principal. Cela inclut le nom du chemin d'accès complet d'une base de données pouvant être attachée.

AttestationProtocol

Obtient ou définit la valeur du protocole d’attestation.

Authentication

Obtient ou définit la méthode d’authentification utilisée pour la connexion à SQL Database à l’aide de l’authentification Azure Active Directory.

ColumnEncryptionSetting

Obtient ou définit les paramètres de chiffrement de colonne pour le générateur de chaînes de connexion.

CommandTimeout

Temps d’attente par défaut (en secondes) avant de mettre fin à la tentative d’exécution d’une commande et de générer une erreur. La valeur par défaut est 30 secondes.

ConnectionReset
Obsolète.
Obsolète.

Obsolète. Obtient ou définit une valeur booléenne qui indique si la connexion est réinitialisée lorsqu'elle est récupérée du pool de connexions.

ConnectRetryCount

Nombre de tentatives de reconnexion après l’identification de l’échec de connexion inactive. La valeur doit être un entier compris entre 0 et 255. La valeur par défaut pour les points de terminaison non Azure est 1. Pour les points de terminaison Azure SQL, la valeur par défaut est 2. À compter de la version 5.x, pour Azure SQL points de terminaison serverless ou à la demande, la valeur par défaut est 5 pour améliorer la réussite de la connexion pour les connexions à un instance inactif ou en pause. Définissez la valeur sur 0 pour désactiver la reconnexion en cas d’échec de connexion inactive. Une ArgumentException est levée si la valeur n’appartient pas à la plage autorisée.

ConnectRetryInterval

Durée (en secondes) entre chaque tentative de reconnexion après identification d’un échec de connexion inactive. La valeur doit être un entier compris entre 1 et 60. La valeur par défaut est 10 secondes.

ConnectTimeout

Obtient ou définit la durée d'attente (en secondes) préalable à l'établissement d'une connexion au serveur avant que la tentative ne soit abandonnée et qu'une erreur ne soit générée.

ContextConnection
Obsolète.

Obsolète. Obtient ou définit une valeur qui indique si une connexion client/serveur ou in-process à SQL Server doit être établie.

CurrentLanguage

Obtient ou définit la langue utilisée pour les messages d’avertissement ou d’erreur du serveur de base de données.

DataSource

Obtient ou définit le nom ou l'adresse réseau de l'instance de SQL Server à laquelle se connecter.

EnclaveAttestationUrl

Obtient ou définit l’URL d’attestation d’enclave à utiliser avec les Always Encrypted basées sur l’enclave.

Encrypt

Obtient ou définit une SqlConnectionEncryptOption valeur depuis la version 5.0 ou une Boolean valeur pour les versions antérieures qui indique si le chiffrement TLS est nécessaire pour toutes les données envoyées entre le client et le serveur.

Enlist

Obtient ou définit une valeur booléenne qui indique si le pooler de connexion SQL Server inscrit automatiquement la connexion dans le contexte de transaction actuel du thread de création.

FailoverPartner

Obtient ou définit le nom ou l'adresse du serveur partenaire auquel se connecter si le serveur principal est en panne.

FailoverPartnerSPN

Obtient ou définit le nom du principal de service (SPN) du partenaire de basculement pour la connexion.

HostNameInCertificate

Obtient ou définit le nom d’hôte à utiliser lors de la validation du certificat de serveur pour la connexion. Lorsqu’il n’est pas spécifié, le nom du serveur de est utilisé pour la Data Source validation du certificat. (Disponible uniquement dans v5.0+)

InitialCatalog

Obtient ou définit le nom de la base de données associée à la connexion.

IntegratedSecurity

Obtient ou définit une valeur booléenne qui indique si l’ID d’utilisateur et le mot de passe sont spécifiés dans la connexion (quand false) ou si les informations actuelles d’identification du compte Windows sont utilisées pour l’authentification (quand true).

IPAddressPreference

Obtient ou définit la préférence de famille d’adresses IP lors de l’établissement de connexions TCP.

IsFixedSize

Obtient une valeur qui indique si SqlConnectionStringBuilder est de taille fixe.

Item[String]

Obtient ou définit la valeur associée à la clé spécifiée. En C#, cette propriété est l'indexeur.

Keys

Obtient un ICollection qui contient les clés de SqlConnectionStringBuilder.

LoadBalanceTimeout

Obtient ou définit la durée de vie minimale, en secondes, de la connexion dans le pool de connexions avant sa destruction.

MaxPoolSize

Obtient ou définit le nombre maximal de connexions autorisées dans le pool de connexions pour cette chaîne de connexion spécifique.

MinPoolSize

Obtient ou définit le nombre minimal de connexions autorisées dans le pool de connexions pour cette chaîne de connexion spécifique.

MultipleActiveResultSets

Si la valeur est true, une application peut conserver plusieurs jeux MARS (Multiple Active Result Sets). Si la valeur est false, une application doit traiter ou annuler tous les jeux de résultats d’un lot avant de pouvoir exécuter un autre lot sur cette connexion. Pour plus d’informations, consultez MARS (Multiple Active Result Sets).

MultiSubnetFailover

Si votre application se connecte à un groupe de disponibilité AlwaysOn sur des sous-réseaux différents, la définition de MultiSubnetFailover=true permet de détecter plus rapidement le serveur actif (actuellement) et de s’y connecter plus rapidement également. Pour plus d’informations sur la prise en charge de SqlClient pour les groupes de disponibilité AlwaysOn, consultez Prise en charge de SqlClient pour la haute disponibilité et la récupération d’urgence.

NetworkLibrary

Obtient ou définit une chaîne qui contient le nom de la bibliothèque réseau utilisée pour établir une connexion à SQL Server.

PacketSize

Obtient ou définit la taille en octets des paquets réseau permettant de communiquer avec une instance de SQL Server.

Password

Obtient ou définit le mot de passe du compte SQL Server.

PersistSecurityInfo

Obtient ou définit une valeur booléenne indiquant si des informations sensibles à la sécurité, telles que le mot de passe ou le jeton d’accès, doivent être retournées dans le cadre de l’chaîne de connexion sur une connexion créée avec celle-ci SqlConnectionStringBuilder après que cette connexion n’a jamais été dans un état ouvert. Cette propriété ne doit être définie sur true que si votre application a un besoin spécifique de lire le mot de passe d’une connexion de base de données déjà ouverte. La valeur par défaut de false est le paramètre le plus sécurisé ; l’utilisation true de cette propriété ouvre votre application aux risques de sécurité tels que la journalisation accidentelle ou le traçage du mot de passe de la base de données.

PoolBlockingPeriod

Comportement de la période de blocage d'un pool de connexions.

Pooling

Obtient ou définit une valeur booléenne qui indique si la connexion sera regroupée ou ouverte explicitement chaque fois que la connexion est demandée.

Replication

Obtient ou définit une valeur booléenne qui indique si la réplication est prise en charge avec la connexion.

ServerCertificate

Obtient ou définit le chemin d’accès à un fichier de certificat pour qu’il corresponde au certificat TLS/SSL SQL Server pour la connexion. Les formats de certificat acceptés sont PEM, DER et CER. S’il est spécifié, le certificat SQL Server est vérifié en vérifiant si le ServerCertificate fourni correspond exactement. (Disponible uniquement dans v5.1+)

ServerSPN

Obtient ou définit le nom du principal de service (SPN) de la source de données.

TransactionBinding

Obtient ou définit une valeur de chaîne indiquant comment la connexion continue d’être associée à la transaction System.Transactions inscrite.

TransparentNetworkIPResolution

Lorsque la valeur de cette clé est définie sur true, l’application doit récupérer toutes les adresses IP pour une entrée DNS spécifique et essayer de se connecter à la première dans la liste. Si la connexion n’est pas établie dans un délai de 0,5 seconde, l’application tente de se connecter à toutes les autres en parallèle. Lorsque la première répond, l’application établit une connexion avec l’adresse IP qui répond.

TrustServerCertificate

Obtient ou définit une valeur qui indique si le canal sera chiffré dans le cas où l'approbation de la chaîne de certificats est ignorée.

TypeSystemVersion

Obtient ou définit une valeur de chaîne qui indique le système de type que l'application attend.

UserID

Obtient ou définit l'ID d'utilisateur à utiliser lors de la connexion à SQL Server.

UserInstance

Obtient ou définit une valeur qui indique s'il faut rediriger la connexion de l'instance de SQL Server Express par défaut vers une instance lancée à l'exécution qui s'exécute sous le compte de l'appelant.

Values

Obtient un objet ICollection qui contient les valeurs de l'objet SqlConnectionStringBuilder.

WorkstationID

Obtient ou définit le nom de la station de travail se connectant à SQL Server.

Méthodes

Clear()

Efface le contenu de l'instance SqlConnectionStringBuilder.

ContainsKey(String)

Détermine si SqlConnectionStringBuilder contient une clé spécifique.

Remove(String)

Supprime l'entrée contenant la clé spécifiée dans l'instance de SqlConnectionStringBuilder.

ShouldSerialize(String)

Indique si la clé spécifiée existe dans cette instance de SqlConnectionStringBuilder.

TryGetValue(String, Object)

Récupère une valeur correspondant à la clé fournie à partir de cet objet SqlConnectionStringBuilder.

S’applique à