ユーザー定義型の使用
適用対象: SQL Server Azure SQL データベース Azure SQL Managed Instance Azure Synapse Analytics Analytics Platform System (PDW)
SQL Server 2005 (9.x) では、ユーザー定義型 (UDT) が導入されました。 これにより、SQL Server データベースにオブジェクトやカスタム データ構造を格納できるようになり、SQL の型システムが拡張されます。 UDT は複数のデータ型を持つことができ、動作を定義できます。この点は、1 つの SQL Server システム データ型から構成される従来の別名データ型と異なります。 UDT は、検証可能なコードを生成する .NET 共通言語ランタイム (CLR) でサポートされる任意の言語を使用して定義されます。 これには、C# と Visual Basic .NET が含まれます。 データは、.NET のクラスまたは構造体のフィールドやプロパティとして公開され、動作はクラスまたは構造体のメソッドによって定義されます。
UDT は、テーブルの列定義、Transact-SQL バッチの変数、または Transact-SQL 関数やストアド プロシージャの引数として使用できます。
OLE DB Driver for SQL Server
OLE DB Driver for SQL Server では、UDT はメタデータ情報を持つバイナリ型としてサポートされるので、オブジェクトとして管理できます。 UDT 列は、DBTYPE_UDT 型として公開され、この列のメタデータは主要な OLE DB インターフェイスの IColumnRowset と新しいインターフェイスの ISSCommandWithParameters により公開されます。
注意
IRowsetFind::FindNextRow メソッドでは、UDT データ型を処理できません。 UDT が検索列の型として使用されると、DB_E_BADCOMPAREOP が返されます。
データ バインドと強制型変換
次の表に、特定のデータ型を SQL Server の UDT と共に使用した場合に行われるバインドおよび強制型変換を示します。 UDT 列は、OLE DB Driver for SQL Server により DBTYPE_UDT 型として公開されます。 この列のメタデータは、適切なスキーマ行セットを使用して取得できるので、独自に定義した型をオブジェクトとして管理できます。
データ型 | SQL Server の UDT |
SQL Server の UDT 以外から |
サーバーからの UDT |
サーバーからの UDT 以外から |
---|---|---|---|---|
DBTYPE_UDT | サポートされている6 | エラー1 | サポートされている6 | エラー5 |
DBTYPE_BYTES | サポートされている6 | N/A2 | サポートされている6 | N/A2 |
DBTYPE_WSTR | サポートされている3、6 | N/A2 | サポートされている4、6 | N/A2 |
DBTYPE_BSTR | サポートされている3、6 | N/A2 | サポートされている4 | N/A2 |
DBTYPE_STR | サポートされている3、6 | N/A2 | サポートされている4、6 | N/A2 |
DBTYPE_IUNKNOWN | サポートされていません | N/A2 | サポートされていません | N/A2 |
DBTYPE_VARIANT (VT_UI1 | VT_ARRAY) | サポートされている6 | N/A2 | サポートされている4 | N/A2 |
DBTYPE_VARIANT (VT_BSTR) | サポートされている3、6 | N/A2 | 該当なし | N/A2 |
1ICommandWithParameters::SetParameterInfo で DBTYPE_UDT 以外のサーバーの型が指定され、アクセサーの型が DBTYPE_UDT の場合、ステートメントの実行時にエラー (DB_E_ERRORSOCCURRED) が発生します (パラメーターの状態は DBSTATUS_E_BADACCESSOR になります)。 それ以外の場合、データはサーバーに送信されますが、サーバーからは、UDT からパラメーターのデータ型への暗黙的な変換がないことを示すエラーが返されます。
2この記事での説明の対象外です。
3 16 進文字列からバイナリ データへのデータ変換が行われます。
4 バイナリ データから 16 進文字列へのデータ変換が行われます。
5アクセサーの作成時またはフェッチ時に検証が行われることがあります。エラー DB_E_ERRORSOCCURRED が返され、バインドの状態は DBBINDSTATUS_UNSUPPORTEDCONVERSION になります。
6BY_REF を使用できます。
DBTYPE_NULL と DBTYPE_EMPTY は入力パラメーターにバインドできますが、出力パラメーターや結果にはバインドできません。 入力パラメーターにバインドした場合、状態を DBSTATUS_S_ISNULL または DBSTATUS_S_DEFAULT に設定する必要があります。
DBTYPE_UDT 型は、DBTYPE_EMPTY と DBTYPE_NULL に変換できますが、DBTYPE_EMPTY と DBTYPE_NULL は DBTYPE_UDT に変換できません。 この動作は、DBTYPE_BYTES 型と一貫性があります。
Note
UDT をパラメーターとして処理するための新しいインターフェイス ISSCommandWithParameters が導入されました。これは、ICommandWithParameters インターフェイスから継承されます。 アプリケーションでは、少なくとも UDT パラメーターの SSPROP_PARAM_UDT_NAME プロパティ セットの DBPROPSET_SQLSERVERPARAMETER プロパティの設定に、このインターフェイスを使用する必要があります。 これを行わないと、ICommand::Execute から DB_E_ERRORSOCCURRED が返されます。 このインターフェイスとプロパティ セットについては、この記事の後半で説明します。
データをすべて格納できる大きさがない列にユーザー定義型を挿入した場合、ICommand::Execute は状態が DB_E_ERRORSOCCURRED の S_OK を返します。
OLE DB Core Services で提供されるデータ変換 (IDataConvert) は、DBTYPE_UDT 型には適用できません。 また、その他のバインドもサポートされません。
OLE DB 行セットに関する追加事項と変更事項
OLE DB Driver for SQL Server では、多くの主要な OLE DB スキーマ行セットに新しい値が追加され、変更が加えられました。
PROCEDURE_PARAMETERS スキーマ行セット
PROCEDURE_PARAMETERS スキーマ行セットには、次の列が追加されました。
列名 | 種類 | 説明 |
---|---|---|
SS_UDT_CATALOGNAME | DBTYPE_WSTR | 3 部構成の名前の識別子。 |
SS_UDT_SCHEMANAME | DBTYPE_WSTR | 3 部構成の名前の識別子。 |
SS_UDT_NAME | DBTYPE_WSTR | 3 部構成の名前の識別子。 |
SS_UDT_ASSEMBLY_TYPENAME | DBTYPE_WSTR | 型名と、CLR での参照に必要なすべてのアセンブリ ID を含むアセンブリ修飾名。 |
SQL_ASSEMBLIES スキーマ行セット
OLE DB Driver for SQL Server は、登録済みの UDT に関する情報が格納される、プロバイダー固有の新しいスキーマ行セットを公開します。 ASSEMBLY_SERVER を DBTYPE_WSTR 型として指定することはできますが、行セットには格納されません。 指定しない場合、行セットでは既定で現在のサーバーが使用されます。 次の表に、SQL_ASSEMBLIES スキーマ行セットの定義を示します。
列名 | 種類 | 説明 |
---|---|---|
ASSEMBLY_CATALOG | DBTYPE_WSTR | このデータ型を含むアセンブリのカタログ名。 |
ASSEMBLY_SCHEMA | DBTYPE_WSTR | このデータ型を含むアセンブリのスキーマ名 (所有者の名前)。 アセンブリのスコープはスキーマではなくデータベースによって決まりますが、アセンブリには依然として所有者が存在します。 |
ASSEMBLY_NAME | DBTYPE_WSTR | このデータ型を含むアセンブリの名前。 |
ASSEMBLY_ID | DBTYPE_UI4 | このデータ型を含むアセンブリのオブジェクト ID。 |
PERMISSION_SET | DBTYPE_WSTR | アセンブリのアクセスのスコープを示す値。 スコープを示す値には、"SAFE"、"EXTERNAL_ACCESS"、および "UNSAFE" があります。 |
ASSEMBLY_BINARY | DBTYPE_BYTES | アセンブリのバイナリ表記。 |
SQL_ASSEMBLIES_ DEPENDENCIES スキーマ行セット
OLE DB Driver for SQL Server では、特定のサーバーにおけるアセンブリの依存関係に関する情報が格納される、プロバイダー固有の新しいスキーマ行セットを公開します。 ASSEMBLY_SERVER は呼び出し元により DBTYPE_WSTR 型として指定することができますが、行セットには格納されません。 指定しない場合、行セットでは既定で現在のサーバーが使用されます。 次の表に、SQL_ASSEMBLY_DEPENDENCIES スキーマ行セットの定義を示します。
列名 | 種類 | 説明 |
---|---|---|
ASSEMBLY_CATALOG | DBTYPE_WSTR | このデータ型を含むアセンブリのカタログ名。 |
ASSEMBLY_SCHEMA | DBTYPE_WSTR | このデータ型を含むアセンブリのスキーマ名 (所有者の名前)。 アセンブリのスコープはスキーマではなくデータベースによって決まりますが、アセンブリには依然として所有者が存在します。 |
ASSEMBLY_ID | DBTYPE_UI4 | アセンブリのオブジェクト ID。 |
REFERENCED_ASSEMBLY_ID | DBTYPE_UI4 | 参照されるアセンブリのオブジェクト ID。 |
SQL_USER_TYPES スキーマ行セット
OLE DB Driver for SQL Server は、特定サーバーの登録済み UDT が追加されたタイミングに関する情報が格納される、新しいスキーマ行セット SQL_USER_TYPES を公開します。 UDT_SERVER は、呼び出し元により DBTYPE_WSTR 型として指定される必要がありますが、行セットには格納されません。 次の表に、SQL_USER_TYPES スキーマ行セットの定義を示します。
列名 | 種類 | 説明 |
---|---|---|
UDT_CATALOGNAME | DBTYPE_WSTR | UDT 列の場合、このプロパティは、UDT が定義されているカタログの名前を指定する文字列です。 |
UDT_SCHEMANAME | DBTYPE_WSTR | UDT 列の場合、このプロパティは、UDT が定義されているスキーマの名前を指定する文字列です。 |
UDT_NAME | DBTYPE_WSTR | UDT を含むアセンブリの名前。 |
UDT_ASSEMBLY_TYPENAME | DBTYPE_WSTR | 型名の前に名前空間を付けた完全な型名 (AQN) (該当する場合)。 |
COLUMNS スキーマ行セット
COLUMNS スキーマ行セットには、次の列が追加されました。
列名 | 種類 | 説明 |
---|---|---|
SS_UDT_CATALOGNAME | DBTYPE_WSTR | UDT 列の場合、このプロパティは、UDT が定義されているカタログの名前を指定する文字列です。 |
SS_UDT_SCHEMANAME | DBTYPE_WSTR | UDT 列の場合、このプロパティは、UDT が定義されているスキーマの名前を指定する文字列です。 |
SS_UDT_NAME | DBTYPE_WSTR | UDT の名前。 |
SS_UDT_ASSEMBLY_TYPENAME | DBTYPE_WSTR | 型名の前に名前空間を付けた完全な型名 (AQN) (該当する場合)。 |
OLE DB プロパティ セットに関する追加事項と変更事項
OLE DB Driver for SQL Server では、多くの主要な OLE DB プロパティ セットに新しい値が追加され、変更が加えられました。
DBPROPSET_SQLSERVERPARAMETER プロパティ セット
OLE DB で UDT をサポートするため、OLE DB Driver for SQL Server では、次の値を含む新しい DBPROPSET_SQLSERVERPARAMETER プロパティ セットが実装されました。
Name | 種類 | 説明 |
---|---|---|
SSPROP_PARAM_UDT_CATALOGNAME | DBTYPE_WSTR | 3 部構成の名前の識別子。 UDT パラメーターの場合、このプロパティは、ユーザー定義型が定義されているカタログ名を指定する文字列です。 |
SSPROP_PARAM_UDT_SCHEMANAME | DBTYPE_WSTR | 3 部構成の名前の識別子。 UDT パラメーターの場合、このプロパティは、ユーザー定義型が定義されているスキーマ名を指定する文字列です。 |
SSPROP_PARAM_UDT_NAME | DBTYPE_WSTR | 3 部構成の名前の識別子。 UDT 列の場合、このプロパティは、ユーザー定義型の 1 部構成の名前を指定する文字列です。 |
SSPROP_PARAM_UDT_NAME は必須です。 SSPROP_PARAM_UDT_CATALOGNAME と SSPROP_PARAM_UDT_SCHEMANAME は省略可能です。 いずれかのプロパティが適切に指定されていない場合、DB_E_ERRORSINCOMMAND が返されます。 SSPROP_PARAM_UDT_CATALOGNAME プロパティと SSPROP_PARAM_UDT_SCHEMANAME プロパティがどちらも指定されていない場合、UDT は、テーブルと同じデータベースおよびスキーマ内に定義する必要があります。 UDT の定義が、テーブルと同じデータベース内にあって、同じスキーマ内にない場合、SSPROP_PARAM_UDT_SCHEMANAME プロパティを指定する必要があります。 UDT の定義が異なるデータベースにある場合、SSPROP_PARAM_UDT_CATALOGNAME と SSPROP_PARAM_UDT_SCHEMANAME の両方を指定する必要があります。
DBPROPSET_SQLSERVERCOLUMN プロパティ セット
ITableDefinition インターフェイスでのテーブルの作成をサポートするため、OLE DB Driver for SQL Server では、DBPROPSET_SQLSERVERCOLUMN プロパティ セットに次の 3 つの新しい列が追加されました。
Name | Description | Type | 説明 |
---|---|---|---|
SSPROP_COL_UDT_CATALOGNAME | UDT_CATALOGNAME | VT_BSTR | DBTYPE_UDT 型の列の場合、このプロパティは、UDT が定義されているカタログ名を指定する文字列です。 |
SSPROP_COL_UDT_SCHEMANAME | UDT_SCHEMANAME | VT_BSTR | DBTYPE_UDT 型の列の場合、このプロパティは、UDT が定義されているスキーマ名を指定する文字列です。 |
SSPROP_COL_UDT_NAME | UDT_NAME | VT_BSTR | DBTYPE_UDT 型の列の場合、このプロパティは、UDT の 1 部構成の名前を指定する文字列です。 他の列の型の場合、このプロパティでは空文字列が返されます。 |
Note
UDT は PROVIDER_TYPES スキーマ行セットには表示されません。 すべての列は読み取り/書き込みアクセスです。
ADO では、"説明" 列の対応するエントリを使用してこれらのプロパティを参照します。
SSPROP_COL_UDTNAME は必須です。 SSPROP_COL_UDT_CATALOGNAME と SSPROP_COL_UDT_SCHEMANAME は省略可能です。 いずれかのプロパティが適切に指定されていない場合、DB_E_ERRORSINCOMMAND が返されます。
SSPROP_COL_UDT_CATALOGNAME プロパティと SSPROP_COL_UDT_SCHEMANAME プロパティがどちらも指定されていない場合、UDT は、テーブルと同じデータベースおよびスキーマ内に定義する必要があります。
UDT の定義が、テーブルと同じデータベース内にあって、同じスキーマ内にない場合、SSPROP_COL_UDT_SCHEMANAME プロパティを指定する必要があります。
UDT の定義がテーブルと異なるデータベースにある場合、SSPROP_COL_UDT_CATALOGNAME プロパティと SSPROP_COL_UDT_SCHEMANAME プロパティの両方を指定する必要があります。
OLE DB インターフェイスに関する追加事項と変更事項
OLE DB Driver for SQL Server では、多くの主要な OLE DB インターフェイスに新しい値が追加され、変更が加えられました。
ISSCommandWithParameters インターフェイス
OLE DB で UDT をサポートするため、OLE DB Driver for SQL Server では、ISSCommandWithParameters インターフェイスの追加など、多くの変更が加えられました。 この新しいインターフェイスは、主要な OLE DB インターフェイス ICommandWithParameters から継承されます。 ICommandWithParameters インターフェイスから継承される 3 つのメソッド (GetParameterInfo、MapParameterNames、および SetParameterInfo) に加えて、ISSCommandWithParameters では、サーバー固有のデータ型を処理するために使用される GetParameterProperties メソッドと SetParameterProperties メソッドが提供されます。
注意
ISSCommandWithParameters インターフェイスでは、新しい SSPARAMPROPS 構造体も使用されます。
IColumnsRowset インターフェイス
ISSCommandWithParameters インターフェイス以外にも、OLE DB Driver for SQL Server により、IColumnsRowset::GetColumnRowset メソッドの呼び出しで返される行セットに、次のような新しい値が追加されます。
列名 | 種類 | 説明 |
---|---|---|
DBCOLUMN_SS_UDT_CATALOGNAME | DBTYPE_WSTR | UDT カタログ名の識別子。 |
DBCOLUMN_SS_UDT_SCHEMANAME | DBTYPE_WSTR | UDT スキーマ名の識別子。 |
DBCOLUMN_SS_UDT_NAME | DBTYPE_WSTR | UDT 名の識別子。 |
DBCOLUMN_SS_ASSEMBLY_TYPENAME | DBTYPE_WSTR | 型名と、CLR での参照に必要なすべてのアセンブリ ID を含むアセンブリ修飾名。 |
DBCOLUMN_TYPE を DBTYPE_UDT に設定すると、上の表にある追加された UDT メタデータを参照することにより、サーバーの UDT 列と他のバイナリ型列とを区別することができます。 そのデータが部分的に完成している場合、サーバーのデータ型は UDT になります。 サーバーのデータ型が UDT 以外の場合、これらの列は、常に NULL として返されます。
参照
OLE DB Driver for SQL Server の機能
ISSCommandWithParameters (OLE DB)