Types CLR volumineux définis par l'utilisateur (ODBC)

Cette rubrique traite des modifications apportées à ODBC dans SQL Server Native Client pour prendre en charge les types CLR volumineux définis par l'utilisateur.

Pour obtenir un exemple illustrant la prise en charge ODBC pour les types CLR volumineux définis par l'utilisateur, consultez Prise en charge de tables UDT volumineuses.

Pour plus d'informations sur la prise en charge des types CLR volumineux définis par l'utilisateur dans SQL Server Native Client, consultez Types CLR volumineux définis par l'utilisateur.

Format de données

SQL Server Native Client utilise SQL_SS_LENGTH_UNLIMITED pour indiquer que la taille d'une colonne est supérieure à 8 000 octets pour les types d'objets LOB. Depuis SQL Server 2008, la même valeur est utilisée pour les types CLR définis par l'utilisateur lorsque leur taille est supérieure à 8 000 octets.

Les valeurs UDT sont représentées sous la forme de tableaux d'octets. Les conversions en chaînes hexadécimales de même que les conversions depuis des chaînes hexadécimales sont prises en charge. Les valeurs littérales sont représentées sous forme de chaînes hexadécimales avec le préfixe « 0x ».

Le tableau suivant montre le mappage des types de données dans les paramètres et les jeux de résultats :

Type de données SQL Server

SQL data type

Valeur

Type CLR défini par l'utilisateur

SQL_SS_UDT

-151 (sqlncli.h)

Le tableau suivant indique la correspondance entre la structure et le type ODBC C. Fondamentalement, le type CLR défini par l'utilisateur est un type varbinary avec des métadonnées supplémentaires.

SQL data type

Disposition en mémoire

Type de données C

Valeur (sqlext.h)

SQL_SS_UDT

SQLCHAR * (caractère non signé *)

SQL_C_BINARY

SQL_BINARY (-2)

Champs de descripteur pour les paramètres

Les informations suivantes sont retournées dans les champs IPD :

Champ de descripteur

SQL_SS_UDT

(longueur inférieure ou égale à 8 000 octets)

SQL_SS_UDT

(longueur supérieure à 8 000 octets)

SQL_DESC_CASE_SENSITIVE

SQL_FALSE

SQL_FALSE

SQL_DESC_CONCISE_TYPE

SQL_SS_UDT

SQL_SS_UDT

SQL_DESC_DATETIME_INTERVAL_CODE

0

0

SQL_DESC_DATETIME_INTERVAL_PRECISION

n

SQL_SS_LENGTH_UNLIMITED (0)

SQL_DESC_FIXED_PREC_SCALE

SQL_FALSE

SQL_FALSE

SQL_DESC_LENGTH

n

SQL_SS_LENGTH_UNLIMITED (0)

SQL_DESC_LOCAL_TYPE_NAME

"udt"

"udt"

SQL_DESC_OCTET_LENGTH

n

SQL_SS_LENGTH_UNLIMITED (0)

SQL_DESC_PRECISION

n

SQL_SS_LENGTH_UNLIMITED (0)

SQL_DESC_SCALE

0

0

SQL_DESC_TYPE

SQL_SS_UDT

SQL_SS_UDT

SQL_DESC_TYPE_NAME

"udt"

"udt"

SQL_DESC_UNSIGNED

SQL_TRUE

SQL_TRUE

SQL_CA_SS_UDT_CATALOG_NAME

Nom du catalogue contenant le type défini par l'utilisateur (UDT).

Nom du catalogue contenant le type défini par l'utilisateur (UDT).

SQL_CA_SS_UDT_SCHEMA_NAME

Nom du schéma contenant le type défini par l'utilisateur (UDT).

Nom du schéma contenant le type défini par l'utilisateur (UDT).

SQL_CA_SS_UDT_TYPE_NAME

Nom du type défini par l'utilisateur (UDT).

Nom du type défini par l'utilisateur (UDT).

SQL_CA_SS_UDT_ASSEMBLY_TYPE_NAME

Nom complet du type défini par l'utilisateur (UDT).

Nom complet du type défini par l'utilisateur (UDT).

Pour les paramètres UDT, SQL_CA_SS_UDT_TYPE_NAME doit toujours être défini via SQLSetDescField. SQL_CA_SS_UDT_CATALOG_NAME et SQL_CA_SS_UDT_SCHEMA_NAME sont facultatifs.

Si l'UDT est défini dans la même base de données avec un schéma différent de celui de la table, SQL_CA_SS_UDT_SCHEMA_NAME doit être défini.

Si l'UDT est défini dans une base de données différente de celle de la table, SQL_CA_SS_UDT_CATALOG_NAME et SQL_CA_SS_UDT_SCHEMA_NAME doivent être définis.

En cas d'erreurs ou d'omissions dans les paramètres de SQL_CA_SS_UDT_TYPE_NAME, SQL_CA_SS_UDT_CATALOG_NAME ou SQL_CA_SS_UDT_SCHEMA_NAME, un enregistrement de diagnostic est généré avec SQLSTATE HY000 et un message spécifique au serveur.

Champs de descripteur pour les résultats

Les informations suivantes sont retournées dans les champs IRD :

Champ de descripteur

SQL_SS_UDT

(longueur inférieure ou égale à 8 000 octets)

SQL_SS_UDT

(longueur supérieure à 8 000 octets)

SQL_DESC_AUTO_UNIQUE_VALUE

SQL_FALSE

SQL_FALSE

SQL_DESC_CASE_SENSITIVE

SQL_FALSE

SQL_FALSE

SQL_DESC_CONCISE_TYPE

SQL_SS_UDT

SQL_SS_UDT

SQL_DESC_DATETIME_INTERVAL_CODE

0

0

SQL_DESC_DATETIME_INTERVAL_PRECISION

n

SQL_SS_LENGTH_UNLIMITED (0)

SQL_DESC_DISPLAY_SIZE

2n

SQL_SS_LENGTH_UNLIMITED (0)

SQL_DESC_FIXED_PREC_SCALE

SQL_FALSE

SQL_FALSE

SQL_DESC_LENGTH

n

SQL_SS_LENGTH_UNLIMITED (0)

SQL_DESC_LITERAL_PREFIX

"0x"

"0x"

SQL_DESC_LITERAL_SUFFIX

""

""

SQL_DESC_LOCAL_TYPE_NAME

"udt"

"udt"

SQL_DESC_OCTET_LENGTH

n

SQL_SS_LENGTH_UNLIMITED (0)

SQL_DESC_PRECISION

n

SQL_SS_LENGTH_UNLIMITED (0)

SQL_DESC_SCALE

0

0

SQL_DESC_SEARCHABLE

SQL_PRED_NONE

SQL_PRED_NONE

SQL_DESC_TYPE

SQL_SS_UDT

SQL_SS_UDT

SQL_DESC_TYPE_NAME

"udt"

"udt"

SQL_DESC_UNSIGNED

SQL_TRUE

SQL_TRUE

SQL_CA_SS_UDT_CATALOG_NAME

Nom du catalogue contenant le type défini par l'utilisateur (UDT).

Nom du catalogue contenant le type défini par l'utilisateur (UDT).

SQL_CA_SS_UDT_SCHEMA_NAME

Nom du schéma contenant le type défini par l'utilisateur (UDT).

Nom du schéma contenant le type défini par l'utilisateur (UDT).

SQL_CA_SS_UDT_TYPE_NAME

Nom du type défini par l'utilisateur (UDT).

Nom du type défini par l'utilisateur (UDT).

SQL_CA_SS_UDT_ASSEMBLY_TYPE_NAME

Nom complet du type défini par l'utilisateur (UDT).

Nom complet du type défini par l'utilisateur (UDT).

Métadonnées de colonne retournées par SQLColumns et SQLProcedureColumns (métadonnées de catalogue)

Les valeurs de colonne suivantes sont retournées pour les types définis par l'utilisateur (UDT) :

Nom de la colonne

SQL_SS_UDT

(longueur inférieure ou égale à 8 000 octets)

SQL_SS_UDT

(longueur supérieure à 8 000 octets)

DATA_TYPE

SQL_SS_UDT

SQL_SS_UDT

TYPE_NAME

Nom du type défini par l'utilisateur (UDT).

Nom du type défini par l'utilisateur (UDT).

COLUMN_SIZE

n

SQL_SS_LENGTH_UNLIMITED (0)

BUFFER_LENGTH

n

SQL_SS_LENGTH_UNLIMITED (0)

DECIMAL_DIGITS

NULL

NULL

SQL_DATA_TYPE

SQL_SS_UDT

SQL_SS_UDT

SQL_DATETIME_SUB

NULL

NULL

CHAR_OCTET_LENGTH

n

SQL_SS_LENGTH_UNLIMITED (0)

SS_UDT_CATALOG_NAME

Nom du catalogue contenant le type défini par l'utilisateur (UDT).

Nom du catalogue contenant le type défini par l'utilisateur (UDT).

SS_UDT_SCHEMA_NAME

Nom du schéma contenant le type défini par l'utilisateur (UDT).

Nom du schéma contenant le type défini par l'utilisateur (UDT).

SS_UDT_ASSEMBLY_TYPE_NAME

Nom complet du type défini par l'utilisateur (UDT).

Nom complet du type défini par l'utilisateur (UDT).

Les trois dernières colonnes sont spécifiques au pilote. Elles sont ajoutées après toute colonne définie par ODBC, mais avant toute colonne existante spécifique au pilote du jeu de résultats de SQLColumns ou SQLProcedureColumns.

Aucune ligne n'est retournée par SQLGetTypeInfo, pour les UDT individuels ou pour le type générique "udt".

Liaisons et conversions

Les conversions suivantes sont prises en charge entre les types de données SQL et C :

Conversion vers et depuis :

SQL_SS_UDT

SQL_C_WCHAR

Prise en charge *

SQL_C_BINARY

Supported

SQL_C_CHAR

Prise en charge *

* Les données binaires sont converties en chaîne hexadécimale.

Les conversions suivantes sont prises en charge entre les types de données C et SQL :

Conversion vers et depuis :

SQL_SS_UDT

SQL_C_WCHAR

Prise en charge *

SQL_C_BINARY

Supported

SQL_C_CHAR

Prise en charge *

* La conversion d'une chaîne hexadécimale et données binaire est réalisée.

Prise en charge des UDT par SQL_VARIANT

Les UDT ne sont pas pris en charge dans les colonnes SQL_VARIANT.

Prise en charge des UDT par BCP

Les valeurs UDT ne peuvent être importées et exportées qu'en tant que valeurs de type character ou binary.

Comportement des clients de niveau inférieur pour les UDT

Les UDT sont mappés aux clients de niveau inférieur de la manière suivante :

Version du serveur

SQL_SS_UDT

(longueur inférieure ou égale à 8 000 octets)

SQL_SS_UDT

(longueur supérieure à 8 000 octets)

SQL Server 2005

UDT

varbinary(max)

SQL Server 2008 et versions ultérieures

UDT

UDT

Fonctions ODBC prenant en charge les types CLR volumineux définis par l'utilisateur

Cette section indique les modifications apportées aux fonctions ODBC SQL Server Native Client au niveau des types CLR volumineux définis par l'utilisateur.

SQLBindCol

Les valeurs de colonnes de résultats de l'UDT sont converties du type de données SQL en type de données C comme décrit dans la section « Liaisons et conversions » de cette rubrique.

SQLBindParameter

Les valeurs requises pour les UDT sont les suivantes :

Type de données SQL

Parametertype

ColumnSizePtr

DecimalDigitsPtr

SQL_SS_UDT

(longueur inférieure ou égale à 8 000 octets)

SQL_SS_UDT

n

0

SQL_SS_UDT

(longueur supérieure à 8 000 octets)

SQL_SS_UDT

SQL_SS_LENGTH_UNLIMITED (0)

0

SQLColAttribute

Les valeurs retournées pour les UDT sont celles décrites dans la section « Champs de descripteur pour les résultats », plus haut dans cette rubrique.

SQLColumns

Les valeurs retournées pour les UDT sont celles décrites dans la section « Métadonnées de colonne retournées par SQLColumns et SQLProcedureColumns (métadonnées de catalogue) », plus haut dans cette rubrique.

SQLDescribeCol

Les valeurs retournées pour les UDT sont les suivantes :

Type de données SQL

DataTypePtr

ColumnSizePtr

DecimalDigitsPtr

SQL_SS_UDT

(longueur inférieure ou égale à 8 000 octets)

SQL_SS_UDT

n

0

SQL_SS_UDT

(longueur supérieure à 8 000 octets)

SQL_SS_UDT

SQL_SS_LENGTH_UNLIMITED (0)

0

SQLDescribeParam

Les valeurs retournées pour les UDT sont les suivantes :

Type de données SQL

DataTypePtr

ColumnSizePtr

DecimalDigitsPtr

SQL_SS_UDT

(longueur inférieure ou égale à 8 000 octets)

SQL_SS_UDT

n

0

SQL_SS_UDT

(longueur supérieure à 8 000 octets)

SQL_SS_UDT

SQL_SS_LENGTH_UNLIMITED (0)

0

SQLFetch

Les valeurs de colonnes de résultats de l'UDT sont converties du type de données SQL en type de données C comme décrit dans la section « Liaisons et conversions » de cette rubrique.

SQLFetchScroll

Les valeurs de colonnes de résultats de l'UDT sont converties du type de données SQL en type de données C comme décrit dans la section « Liaisons et conversions » de cette rubrique.

SQLGetData

Les valeurs de colonnes de résultats de l'UDT sont converties du type de données SQL en type de données C comme décrit dans la section « Liaisons et conversions » de cette rubrique.

SQLGetDescField

Les champs de descripteur disponibles avec les nouveaux types sont décrits dans les sections « Champs de descripteur pour les paramètres » et « Champs de descripteur pour les résultats », plus haut dans cette rubrique.

SQLGetDescRec

Les valeurs retournées pour les UDT sont les suivantes :

SQL data type

Type

Sous-type

Longueur

Précision

Échelle

SQL_SS_UDT

(longueur inférieure ou égale à 8 000 octets)

SQL_SS_UDT

0

n

n

0

SQL_SS_UDT

(longueur supérieure à 8 000 octets)

SQL_SS_UDT

0

SQL_SS_LENGTH_UNLIMITED (0)

SQL_SS_LENGTH_UNLIMITED (0)

0

SQLGetTypeInfo

Les valeurs retournées pour les UDT sont celles décrites dans la section « Métadonnées de colonne retournées par SQLColumns et SQLProcedureColumns (métadonnées de catalogue) », plus haut dans cette rubrique.

SQLProcedureColumns

Les valeurs retournées pour les UDT sont celles décrites dans la section « Métadonnées de colonne retournées par SQLColumns et SQLProcedureColumns (métadonnées de catalogue) », plus haut dans cette rubrique.

SQLPutData

Les valeurs de paramètre UDT sont converties du type de données C en type de données SQL, comme décrit dans la section « Liaisons et conversions » de cette rubrique.

SQLSetDescField

Les champs de descripteur disponibles avec les nouveaux types sont décrits dans les sections « Champs de descripteur pour les paramètres » et « Champs de descripteur pour els résultats », plus haut dans cette rubrique.

SQLSetDescRec

Les valeurs autorisées pour les UDT sont les suivantes :

SQL data type

Type

Sous-type

Longueur

Précision

Échelle

SQL_SS_UDT

(longueur inférieure ou égale à 8 000 octets)

SQL_SS_UDT

0

n

n

0

SQL_SS_UDT

(longueur supérieure à 8 000 octets)

SQL_SS_UDT

0

SQL_SS_LENGTH_UNLIMITED (0)

SQL_SS_LENGTH_UNLIMITED (0)

0

SQLSpecialColumns

Les valeurs retournées pour les UDT des colonnes DATA_TYPE, TYPE_NAME, COLUMN_SIZE, BUFFER_LENGTH et DECIMAL_DIGTS sont celles décrites dans « Métadonnées retournés par SQLColumns et SQLProcedureColumns (métadonnées de catalogue) », plus haut dans cette rubrique.

Voir aussi

Concepts

Types CLR volumineux définis par l'utilisateur