可変長バイナリ文字列

可変長バイナリ データ型 (VARBINARY、LONG-VARBINARY、および LONG VARCHAR FOR BIT DATA) は、ドライバーが定義する最大長を持つ SQL データ型です。

ホスト変数フォーマット

OpenESQL
01 varbin-field1      SQL TYPE IS VARBINARY(2000).
01 varbin-field2      SQL TYPE IS LONG-VARBINARY(20000).
01 varbin-field3.
   49 varbin-field3-len    PIC S9(4) COMP-5.
   49 varbin-field3-data   PIC X(2000).
  • SQL の BINARY、VARBINARY、および IMAGE データは、COBOL では PIC X (n) フィールドとして表されます。
  • OpenESQL はデータ変換を実行しません。
  • データベースからデータをフェッチする際に、フェッチされたデータ量よりもホスト変数フィールドが小さい場合は、 データが切り捨てられ、SQLCA データ構造体の SQLWARN1 フィールドが「W」に設定されます。また、ホスト変数フィールドがデータ量がよりも大きい場合は、フィールドの空き部分に NULL 文字 (x"00") が付加されます。
  • 次のいずれかを使用すると、BINARY、VARBINARY、または LONG-VARBINARY 列にデータを挿入できます。
    • 動的 SQL 文を使用する
    • ALLOWNULLCHAR 指令を使用してアプリケーションをコンパイルする
    • SQL TYPE ホスト変数を使用する
    • .NET Byte ホスト変数を使用する
  • varbin-field1の形式は VARBINARY SQL TYPE を使用します。
  • varbin-field2の形式は LONG-VARBINARY SQL TYPE を使用します。
OpenESQL .NET Managed Runtime
OpenESQL で有効な定義に加えて、次の定義も OpenESQL .NET Managed Runtime で有効です。
01 varbin-field4      type System.Byte[].

OpenESQL .NET Managed Runtime アプリケーションにはバイト制限はありません。

DB2 ECM
01 varbin-field3.
   49 varbin-field3-len    PIC S9(4) COMP-5.
   49 varbin-field3-data   PIC X(2000).
  • CHAR FOR BIT DATA を使用して BINARY を表します。
  • VARCHAR(n) FOR BIT DATA を使用して VARBINARY を表します。
  • LONG VARCHAR FOR BIT DATA を使用して LONG-VARBINARY を表します。
  • IBM ODBC ドライバーは、IBM のd同等機能の代わりに BINARY、VARBINARY、および LONG VARBINARY データ型を戻します。
  • IMAGE データ型は、BLOB で表現されます。
  • DB2 は LOB (Character Large Object、Binary Large Object、または Graphical Large Object) を使用して、きわめて大きいカラム (最大 2 ギガバイト) を定義します。これらのデータ型とともに静的 SQL を使用することができます。