Notes
L’accès à cette page nécessite une autorisation. Vous pouvez essayer de vous connecter ou de modifier des répertoires.
L’accès à cette page nécessite une autorisation. Vous pouvez essayer de modifier des répertoires.
S'applique à :SQL Server
Pour créer un type défini par l’utilisateur (UDT) sur le client, l’assembly inscrit en tant qu’UDT dans une base de données SQL Server doit être disponible pour l’application cliente. L'assembly de type défini par l'utilisateur (UDT) peut être placé dans le même répertoire que l'application, ou dans le Global Assembly Cache (GAC). Vous pouvez également définir une référence à l'assembly dans votre projet.
Conditions requises pour l’utilisation des UDT dans ADO.NET
L’assembly chargé dans SQL Server et l’assembly sur le client doivent être compatibles pour que l’UDT soit créé sur le client. Pour les UDT définis avec le format de sérialisation Native
, les assemblys doivent être structurellement compatibles. Pour les assemblys définis avec le format UserDefined
, l’assembly doit être disponible sur le client.
Vous n’avez pas besoin d’une copie de l’assembly UDT sur le client pour récupérer les données brutes d’une colonne UDT dans une table.
Remarque
SqlClient
risque de ne pas charger un UDT en cas de défaillance des versions UDT ou d’autres problèmes. Dans ce cas, utilisez des mécanismes de dépannage réguliers pour déterminer pourquoi l’assembly contenant l’UDT est introuvable par l’application appelante. Pour plus d’informations, consultez Diagnostiquer les erreurs avec les assistants de débogage managé.
Accéder aux UDT avec un SqlDataReader
Un System.Data.SqlClient.SqlDataReader
peut être utilisé à partir du code client pour récupérer un jeu de résultats qui contient une colonne UDT, qui est exposée en tant qu’instance de l’objet.
Exemple
Cet exemple montre comment utiliser la méthode Main
pour créer un objet SqlDataReader
. Les actions suivantes se produisent dans l'exemple de code :
La méthode Main crée un objet
SqlDataReader
et récupère les valeurs de la table Points, qui a une colonne UDT nommée Point.L’UDT
Point
expose les coordonnées X et Y définies en tant qu’entiers.L’UDT définit une méthode
Distance
et une méthodeGetDistanceFromXY
.L'exemple de code extrait les valeurs de la clé primaire et les colonnes UDT pour montrer les fonctions de l'UDT.
L’exemple de code appelle les méthodes
Point.Distance
etPoint.GetDistanceFromXY
.Les résultats s'affichent dans la fenêtre de la console.
Remarque
L'application doit déjà avoir une référence à l'assembly UDT.
using System;
using System.Data.Sql;
using System.Data.SqlClient;
namespace Microsoft.Samples.SqlServer
{
class ReadPoints
{
static void Main()
{
string connectionString = GetConnectionString();
using (SqlConnection cnn = new SqlConnection(connectionString))
{
cnn.Open();
SqlCommand cmd = new SqlCommand(
"SELECT ID, Pnt FROM dbo.Points", cnn);
SqlDataReader rdr = cmd.ExecuteReader();
while (rdr.Read())
{
// Retrieve the value of the Primary Key column
int id = rdr.GetInt32(0);
// Retrieve the value of the UDT
Point pnt = (Point)rdr[1];
// You can also use GetSqlValue and GetValue
// Point pnt = (Point)rdr.GetSqlValue(1);
// Point pnt = (Point)rdr.GetValue(1);
Console.WriteLine(
"ID={0} Point={1} X={2} Y={3} DistanceFromXY={4} Distance={5}",
id, pnt, pnt.X, pnt.Y, pnt.DistanceFromXY(1, 9), pnt.Distance());
}
rdr.Close();
Console.WriteLine("done");
}
static private string GetConnectionString()
{
// To avoid storing the connection string in your code,
// you can retrieve it from a configuration file.
return "Data Source=(local);Initial Catalog=AdventureWorks2022"
+ "Integrated Security=SSPI";
}
}
}
}
Lier des UDT en tant qu’octets
Dans certains cas, vous souhaiterez peut-être récupérer les données brutes de la colonne UDT. Le type n’est peut-être pas disponible localement ou vous ne souhaitez pas instancier une instance de l’UDT. Vous pouvez lire les octets bruts dans un tableau d’octets à l’aide de la méthode GetBytes
d’un SqlDataReader
. Cette méthode lit un flux d'octets à partir de l'offset de colonne spécifié dans la mémoire tampon d'un tableau commençant à un offset de mémoire tampon donné. Une autre option consiste à utiliser l’une des méthodes GetSqlBytes
ou GetSqlBinary
et à lire tout le contenu dans une seule opération. Dans les deux cas, l’objet UDT n’est jamais instancié. Vous n’avez donc pas besoin de définir une référence à l’UDT dans l’assembly client.
Exemple
Cet exemple montre comment récupérer les données Point
sous forme d’octets bruts dans un tableau d’octets à l’aide d’un SqlDataReader
. Le code utilise un System.Text.StringBuilder
pour convertir les octets bruts en représentation sous forme de chaîne à afficher dans la fenêtre de console.
using System;
using System.Data.Sql;
using System.Data.SqlClient;
using System.Data.SqlTypes;
using System.Text;
class GetRawBytes
{
static void Main()
{
string connectionString = GetConnectionString();
using (SqlConnection cnn = new SqlConnection(connectionString))
{
cnn.Open();
SqlCommand cmd = new SqlCommand("SELECT ID, Pnt FROM dbo.Points", cnn);
SqlDataReader rdr = cmd.ExecuteReader();
while (rdr.Read())
{
// Retrieve the value of the Primary Key column
int id = rdr.GetInt32(0);
// Retrieve the raw bytes into a byte array
byte[] buffer = new byte[32];
long byteCount = rdr.GetBytes(1, 0, buffer, 0, 32);
// Format and print bytes
StringBuilder str = new StringBuilder();
str.AppendFormat("ID={0} Point=", id);
for (int i = 0; i < byteCount; i++)
str.AppendFormat("{0:x}", buffer[i]);
Console.WriteLine(str.ToString());
}
rdr.Close();
Console.WriteLine("done");
}
static private string GetConnectionString()
{
// To avoid storing the connection string in your code,
// you can retrieve it from a configuration file.
return "Data Source=(local);Initial Catalog=AdventureWorks2022"
+ "Integrated Security=SSPI";
}
}
}
Exemple utilisant GetSqlBytes
Cet exemple montre comment récupérer les données Point
sous forme d’octets bruts dans une seule opération à l’aide de la méthode GetSqlBytes
. Le code utilise un StringBuilder
pour convertir les octets bruts en représentation sous forme de chaîne à afficher dans la fenêtre de console.
using System;
using System.Data.Sql;
using System.Data.SqlClient;
using System.Data.SqlTypes;
using System.Text;
class GetRawBytes
{
static void Main()
{
string connectionString = GetConnectionString();
using (SqlConnection cnn = new SqlConnection(connectionString))
{
cnn.Open();
SqlCommand cmd = new SqlCommand(
"SELECT ID, Pnt FROM dbo.Points", cnn);
SqlDataReader rdr = cmd.ExecuteReader();
while (rdr.Read())
{
// Retrieve the value of the Primary Key column
int id = rdr.GetInt32(0);
// Use SqlBytes to retrieve raw bytes
SqlBytes sb = rdr.GetSqlBytes(1);
long byteCount = sb.Length;
// Format and print bytes
StringBuilder str = new StringBuilder();
str.AppendFormat("ID={0} Point=", id);
for (int i = 0; i < byteCount; i++)
str.AppendFormat("{0:x}", sb[i]);
Console.WriteLine(str.ToString());
}
rdr.Close();
Console.WriteLine("done");
}
static private string GetConnectionString()
{
// To avoid storing the connection string in your code,
// you can retrieve it from a configuration file.
return "Data Source=(local);Initial Catalog=AdventureWorks2022"
+ "Integrated Security=SSPI";
}
}
}
Utiliser des paramètres UDT
Les paramètres UDT peuvent être utilisés comme paramètres d'entrée et de sortie dans votre code ADO.NET.
Utiliser des UDT dans les paramètres de requête
Les UDT peuvent être utilisés comme valeurs de paramètre lors de la configuration d’un SqlParameter
pour un objet System.Data.SqlClient.SqlCommand
. L’énumération SqlDbType.Udt
d’un objet SqlParameter
est utilisée pour indiquer que le paramètre est un UDT lors de l’appel de la méthode Add
à la collection Parameters
. La propriété UdtTypeName
d’un objet SqlCommand
est utilisée pour spécifier le nom complet de l’UDT dans la base de données à l’aide de la syntaxe <database>.<schema_name>.<object_name>
. Vous devez utiliser le nom complet pour éviter toute ambiguïté dans votre code.
Une copie locale de l'assembly UDT doit être accessible par le projet client.
Exemple
Le code de cet exemple crée des objets SqlCommand
et SqlParameter
pour insérer des données dans une colonne UDT dans une table. Le code utilise l’énumération SqlDbType.Udt
pour spécifier le type de données et la propriété UdtTypeName
de l’objet SqlParameter
pour spécifier le nom complet de l’UDT dans la base de données.
using System;
using System.Data;
using System.Data.Sql;
using System.Data.SqlClient;
class Class1
{
static void Main()
{
string ConnectionString = GetConnectionString();
using (SqlConnection cnn = new SqlConnection(ConnectionString))
{
SqlCommand cmd = cnn.CreateCommand();
cmd.CommandText =
"INSERT INTO dbo.Points (Pnt) VALUES (@Point)";
cmd.CommandType = CommandType.Text;
SqlParameter param = new SqlParameter("@Point", SqlDbType.Udt); param.UdtTypeName = "TestPoint.dbo.Point"; param.Direction = ParameterDirection.Input; param.Value = new Point(5, 6); cmd.Parameters.Add(param);
cnn.Open();
cmd.ExecuteNonQuery();
Console.WriteLine("done");
}
static private string GetConnectionString()
{
// To avoid storing the connection string in your code,
// you can retrieve it from a configuration file.
return "Data Source=(local);Initial Catalog=AdventureWorks2022"
+ "Integrated Security=SSPI";
}
}
}