引数のタイプとルール - Advanced SQL Engine - Teradata Database

Teradata Vantage™ - SQL関数、式、および述部

Product
Advanced SQL Engine
Teradata Database
Release Number
17.10
Published
2021年7月
Language
日本語
Last Update
2021-09-23
dita:mapPath
ja-JP/djk1612415574830.ditamap
dita:ditavalPath
ja-JP/wrg1590696035526.ditaval
dita:id
B035-1145
Product Category
Software
Teradata Vantage
BITANDは、オーバーロード スカラー関数です。target_argパラメータのデータ型は、以下のいずれかになります。
  • BYTEINT
  • SMALLINT
  • INTEGER
  • BIGINT
  • DECIMAL
  • NUMBER
  • VARBYTE(n)
DECIMAL入力は暗黙的にNUMBER(38,0)に変換されます。target_argはDECIMALでは定義されていませんが、NUMBER(38,0)に対して定義されています。UDFの暗黙的な型変換ルールのため、DECIMALは入力として受け入れられます。

bit_mask_argパラメータのデータ型は、target_argパラメータのデータ型に応じて多様に変化します。次に示す入力の組み合わせ(target_arg, bit_mask_arg)が許容されています。

target_arg bit_mask_arg
BYTEINT BYTE(1)
BYTEINT BYTEINT
SMALLINT BYTE(2)
SMALLINT SMALLINT
INTEGER BYTE(4)
INTEGER INTEGER
BIGINT BYTE(8)
BIGINT BIGINT
NUMBER(38,0) VARBYTE(16)
NUMBER(38,0) NUMBER(38,0)
VARBYTE(n) VARBYTE(n)

VARBYTEの(n)に対する最大対応サイズは、8192バイトです。

この関数に渡す式は、上記に明示したデータ型と一致するか、UDFに適用される暗黙のデータ型変換ルールを使用して、上記のタイプに変換できる必要があります。例えば、BITAND(BYTEINT, INTEGER)は、暗黙的にBITAND(INTEGER, INTEGER)に変換できるため許容されます。

UDFの暗黙の型変換ルールは、Vantageで通常使用される暗黙の型変換ルールよりも制限されています。UDFの暗黙の変換ルールに従って上記に明示したデータ型のいずれかに変換できない引数がある場合は、その引数を明示的にキャストする必要があります。詳細については、<Teradata Vantage™ - SQL外部ルーチン プログラミング、B035-1147>の互換データ型とオーバーロード関数のパラメータ型を参照してください。

いずれかの引数が、上記に明示したデータ型に変換できない場合は、実行依頼されたDML UDF式と一致する関数が存在しないことを示すエラーが返されます。