SQL 関数、演算子、式および述部 - Teradata

What would you do if you knew?™
Teradata Database
SQL 関数、演算子、式および述部
リリース 15.10
B035-1145-151K-JPN
2015 年 6 月
本書に記載されている製品は、Teradata Corporation またはその関連会社がライセンスを有する製品です。
Teradata、Active Data Warehousing、Active Enterprise Intelligence、Applications-Within、Aprimo Marketing Studio、Aster、BYNET、
Claraview、DecisionCast、Gridscale、MyCommerce、QueryGrid、SQL-MapReduce、Teradata Decision Experts、Teradata Labs ロゴ、
Teradata ServiceConnect、Teradata Source Experts、WebAnalyst、および Xkoto は、Teradata Corporation またはその関連会社の米国および
その他の国における商標または登録商標です。
Adaptec および SCSISelect は、Adaptec, Inc.の商標または登録商標です。
AMD Opteron および Opteron は、Advanced Micro Devices, Inc.の商標です。
Apache、Apache Avro、Apache Hadoop、Apache Hive、Hadoop、および黄色い象のロゴは、Apache Software Foundation の米国およびその
他の国における登録商標または商標です。
Apple、Mac、および OS X すべては、Apple Inc.の登録商標です。
Axeda は、Axeda Corporation の登録商標です。Axeda Agents、Axeda Applications、Axeda Policy Manager、Axeda Enterprise、Axeda
Access、Axeda Software Management、Axeda Service、Axeda ServiceLink、および Firewall-Friendly は、Axeda Corporation の商標であり、
Maximum Results および Maximum Support は、Axeda Corporation の役務商標です。
Data Domain、EMC、PowerPath、SRDF、および Symmetrix は、EMC Corporation の登録商標です。
GoldenGate は、Oracle の商標です。
Hewlett-Packard および HP は、Hewlett-Packard Company の登録商標です。
Hortonworks、Hortonworks ロゴおよびその他の Hortonworks 商標は、Hortonworks Inc.の米国およびその他の国における商標です。
Intel、Pentium、および XEON は、Intel Corporation の登録商標です。
IBM、CICS、RACF、Tivoli、および z/OS は、International Business Machines Corporation の登録商標です。
Linux は、Linus Torvalds の登録商標です。
LSI は、LSI Corporation の登録商標です。
Microsoft、Active Directory、Windows、Windows NT、および Windows Server は、Microsoft Corporation の米国およびその他の国における
登録商標です。
NetVault は、Dell Inc.の米国またはその他の国における商標または登録商標です。
Novell および SUSE は、Novell, Inc.の米国およびその他の国における登録商標です。
Oracle、Java、および Solaris は、Oracle またはその関連会社の登録商標です。
QLogic および SANbox は、QLogic Corporation の商標または登録商標です。
Quantum および Quantum ロゴは、Quantum Corporation の商標であり、米国およびその他の国で登録されています。
Red Hat は、Red Hat, Inc.の商標であり、米国およびその他の国で登録されています。ライセンスに基づいて使用されます。
SAP は、SAP AG のドイツおよびその他のいくつかの国における商標 または登録商標です。
SAS および SAS/C は、SAS Institute Inc.の商標または登録商標です。
SPARC は、SPARC International, Inc.の登録商標です。
Symantec、NetBackup、および VERITAS は、Symantec Corporation またはその関連会社の米国およびその他の国における商標または登録商標
です。
Unicode は、Unicode, Inc.の米国およびその他の国における登録商標です。
UNIX は、The Open Group の米国およびその他の国における登録商標です。
その他記載されている製品名および企業名は、各社の商標です。
本書に記載されている情報は、「現状のまま」提供され、商用および特定の用途での使用に対する適合性、または権利侵害がないことに関す
る暗黙的な保証を含め、明示的または暗黙的なすべての保証は一切ありません。 一部の法域では暗黙的保証の除外を許可しないため、上記制
限が適用されないことがあります。いかなる場合も Teradata Corporation は、逸失利益または逸失財産を含む、あらゆる間接的、直接的、特
殊、付随的、または必然的な損害に対し、たとえそのような損害の可能性を明示的に通知されていたとしても、責任を負うことはありません。
本書に記載されている情報は、日本では発表されていないかもしくは利用できない機能、製品やサービスを参照または相互参照している場合
があります。これらの参照は、必ずしも Teradata Corporation が日本でこれらの機能、製品やサービスを発表する意図があることを意味する
ものではありません。日本で利用可能な機能、製品やサービスについては、日本テラデータ株式会社の担当者に確認ください。
本書に記載されている情報には、技術的に不正確な記述または誤植が含まれている可能性があります。本書の情報は、予告なしに変更または
更新される場合があります。また、Teradata Corporation は、本書に記載されている製品やサービスを随時予告なしに改良または変更すること
ができます。
製品およびサービスの品質を維持するため、本書の正確性、明瞭性、構成、有用性についてコメントを頂けると幸いです。次のアドレスに E
メールで連絡ください。teradata-books@lists.teradata.com
Teradata Corporation に送られたコメントや資料(「フィードバック」と総称する)は、機密情報とは見なされません。Teradata Corporation は、
フィードバックに関していかなる種類の義務も負わず、フィードバックとその派生物を無償で制限なしに使用、複製、開示、公開、表示、変
換、派生物の作成、および配布できるものとします。さらに、Teradata Corporation は、そのようなフィードバックに含まれる、あらゆる考
え、概念、ノウハウや技術を、フィードバックを組み込んだ製品やサービスの開発、製造、または販売を含め、どのような目的にでも自由に
使用できるものとします。
Copyright © 2000 - 2015 by Teradata. All Rights Reserved.
SQL 関数、演算子、式および述部
Release 15.10
B035-1145-151K
2015 年 6 月
序文
目的
このマニュアルでは、Teradata SQL の関数、演算子、式、および述部について解説
しています。
このマニュアルは、SQL マニュアル セットに含まれる他のマニュアル類と一緒に使
用してください。
対象読者
このマニュアルは Teradata Database を使用するデータベース管理者およびその他
の技術担当者を対象としています。
サポートされるソフトウェア リリースとオペレーティング シ
ステム
このマニュアルは、Teradata Database 15.10 用です。
®
Teradata Database 15.10 は、以下のオペレーティング システムでサポートされて
います。
• SUSE Linux Enterprise Server (SLES) 10 SP3
• SUSE Linux Enterprise Server (SLES) 11 SP1
Teradata Database クライアント アプリケーションは他のオペレーティング システ
ムに対応しています。
前提条件
基本的なリレーショナル データベース管理の理論と技術について精通している必要
があります。
Teradata Database 固有の概念については、<Teradata 概要、B035-1091>および
<SQL 基礎、B035-1141>をお読みください。
組み込み SQL を使用するアプリケーションの開発の詳細については、<Teradata
PreProcessor2 埋め込み SQL プログラマ ガイド, B035-2446>を参照してください。
SQL 関数、演算子、式および述部
3
序文
このマニュアルの改訂内容
このマニュアルの改訂内容
リリース
説明
Teradata Database 15.10
「集約関数」の章の「結果のタイプと属性」
セクションを更新し、COUNT 集約関数を含
めました。
2015 年 6 月
TRYCAST 関数について解説しました。
Right、Left、および Reverse システム関数を
追加しました。
CreateFsysInfoTable セクションと
PopulateFsysInfoTable セクションを更新し
て、Ferret SHOWWHERE コマンドへの SQL
インターフェースを含めました。構文図を更
新して、SHOWWHERE を含めました。また、
SHOWWHERE 出力の新しい例を
CreateFsysInfoTable セクションと
PopulateFsysInfoTable セクションに追加しま
した。
「テーブル演算子」の章の「SCRIPT」セク
ションに「メモリ制限の設定」を追加しまし
た。
R テーブル演算子について説明しました。
追加情報
URL
説明
www.info.teradata.com 「Teradata Information Products Publishing Library」サイトでは、
英語版について以下が可能です。
• マニュアルを表示またはダウンロードします。
• Downloadable Publications で General Search を選択しま
す。
• 検索基準を入力して Search をクリックします。
• マニュアル CD-ROM をダウンロードします。
• Downloadable Publications で General Search を選択しま
す。
• Title or Keyword フィールドで、「CD-ROM」と入力し、
Search をクリックします。
www.teradata.com
4
Teradata ホームページには、Teradata に関する情報を得るため
の次のようなリンクが多数用意されています。
• エグゼクティブ レポート、ホワイト ペーパー、Teradata 導入
企業の事例研究、およびソート リーダーシップ
• 技術情報、ソリューション、および専門的アドバイス
SQL 関数、演算子、式および述部
序文
製品の安全情報
URL
説明
• プレス リリース、関連記事、およびメディア リソース
www.teradata.com/TEN Teradata Customer Education では、ユーザーによる Teradata へ
/
の投資を最大限まで活かすことができるようにするため、ユー
ザーの技術と能力を確立するためのトレーニングを行なっていま
す。
https://
tays.teradata.com
Teradata @ Your Service を利用すれば、オレンジ ブック、テク
ニカル アラート、ナレッジ リポジトリの参照、フォーラムの閲
覧と参加、ソフトウェア パッチのダウンロードを行なうことがで
きます。
Teradata Developer
Exchange
Teradata Developer Exchange では、Teradata 製品の使い方、技
術検討フォーラム、コードのダウンロードなどのコーナーを提供
しています。
製品およびサービスの品質を維持するため、本書の正確性、明瞭性、構成、有用性
についてコメントを頂けると幸いです。次のアドレスに E メールで連絡ください。
teradata-books@lists.teradata.com
製品の安全情報
このドキュメントには、データまたは所有物の損害に関連する製品の安全ポリシー
を扱った情報が含まれている場合があり、これらは注記という言葉で識別できます。
この注記書きは、その状況が避けられない場合、機器またはデータなどの所有物が、
人身傷害を除く損害を受ける可能性があることを示します。
例
注記: 再構成ユーティリティを不適切に使用すると、データが失われる可能性があります。
Teradata Database のオプション機能
このマニュアルには、Teradata Database の以下のオプション機能と製品に関する説
明が含まれている場合があります。
• メモリ内最適化
• セキュア ゾーン
• Teradata Columnar
• Teradata QueryGrid:Teradata Database-to-Hadoop
• Teradata QueryGrid:Teradata Database-to-Oracle Database
• Teradata QueryGrid: Teradata Database-to-Teradata Database
• Teradata 行レベル セキュリティ
• Teradata Temporal
• Teradata Virtual Storage (VS)
SQL 関数、演算子、式および述部
5
序文
Teradata Database のオプション機能
これらの機能は適切なライセンスがないと使用できません。これらの機能が製品メ
ディアやダウンロードに含まれていたり、または入手した資料で説明されていたと
しても、適切なライセンスがないとそれらの機能を使用することはできません。
オプション機能の購入および有効化については、Teradata 営業担当者までご連絡く
ださい。
6
SQL 関数、演算子、式および述部
第1章
序
概要
この章では、SQL 関数、演算子、式、および述部について説明します。
地理空間データを対象とする特殊な関数、演算子、述部、およびメソッドの詳細は、
<SQL 地理空間タイプ、B035-1181>を参照してください。
XML データ型および XML 操作、関数、およびメソッドの詳細は、<Teradata XML、
B035-1140>を参照してください。
JSON についての詳細は、<Teradata JSON、B035-1150>を参照してください。
SQL 関数
SQL 関数は、関数が呼び出されたときに指定される引数に応じてデータベースの局
面についての情報を戻します。
関数は入力引数を受け入れて出力値を戻すことにより、1 つの結果を生じます。一
部の SQL 関数には引数がありませんが、値を戻します。たとえば、そのような SQL
関数として CURRENT_DATE があります。
SQL 関数のタイプ
関数のタイプ
定義
スカラー
引数は、同一タイプまたは混合タイプの個々のスカラー値で、それぞれ異
なる意味を持つことができます。
結果は単一の値または null です。
スカラー関数は、式を使用できるどの SQL 文にも使用できます。
集約
引数は行のグループです。
結果は単一の値または null です。
集約関数は通常、SELECT 文の式リスト内と、WITH 句の要約リスト内で
使用されます。
SQL 関数、演算子、式および述部
7
第1章序
SQL 関数
関数のタイプ
定義
テーブル
引数は、同一タイプまたは混合タイプの個々のスカラー値で、それぞれ異
なる意味を持つことができます。
結果はテーブルです。
テーブル関数は、SELECT 文の FROM 句内でのみ使用できます。
テーブル関数はユーザー定義関数の形式です。これについては、<SQL 外
部ルーチン プログラミング、B035-1147>で説明されています。
順序付き分析
引数は、任意の標準 SQL 式です。
結果は、その他の SQL 式と同じように処理されます。結果列として示すこ
ともできれば、さらに複雑な計算式の一部として組み込むこともできます。
順序付き分析関数は、並べ替え済みの結果行セットを必要とする操作や、
直前の行の値に基づく操作で使用されます。
関数の例
関数
説明
SELECT CHARACTER_LENGTH(Details)
スカラー関数は Details 列の文字または CLOB の
値を取り、Orders テーブルの各行に対して数値
を返します。
FROM Orders;
SELECT AVG(Salary)
FROM Employee;
集約関数は、Employee テーブルの Salary 列に
よって指定される数値のグループに対して、単
一の値を返します。
埋め込みサービス システム関数
Teradata Database には、文字列処理、DateTime 演算、バイト/ビット操作など、さ
まざまな機能をサポートする一連のシステム関数が用意されています 。
埋め込みサービス システム関数の有効化
埋め込みサービス関数を使用する前に、データベース初期化プログラム(DIP)ユーティ
リティを実行し、DIPALL または DIPSYSFNC スクリプトを実行する必要があります。
DIPALL はシステム インストールの一部として実行されます。
DIP スクリプトは TD_SYSFNLIB データベースを作成します。このデータベースは、
埋め込みサービス関数をサポートするために、システムだけが使用します。このデー
タベースには、どんなデータベース オブジェクトも格納してはいけません 。格納す
ると、埋め込みサービス関数を正しく操作できなくなる場合があります。
TD_SYSFNLIB データベースまたは DBC ディクショナリ テーブルが関与する BAR 操
作を実行する場合は、DIPALL または DIPSYSFNC スクリプトを再実行して、埋め込
みサービス関数を再始動させる必要があります。
8
SQL 関数、演算子、式および述部
第1章序
SQL 演算子
埋め込みサービス システム関数の呼び出し
埋め込みサービス関数は、関数名だけを使用して呼び出すことができます。例えば、
CEILING (arg)のようにします。
TD_SYSFNLIB データベース名を追加することにより、関数の名前を修飾することも
できます。例えば、完全修飾した構文、TD_SYSFNLIB.CEILING(arg)を使用して、
CEILING 関数を呼び出すことができます。
注: 埋め込みサービス関数を、関数名だけを使用して呼び出そうとしたときに、同名
のユーザーが開発した UDF が現在のデータベースまたは SYSLIB データベースに存
在すると、Teradata Database は埋め込みサービス関数の代わりに、ユーザーが開発
した UDF を実行します。
そのため、確実に埋め込みサービス関数を呼び出すためには、次のいずれかの操作
を行ないます。
• ユーザーが開発した同名の UDF を通常の UDF 検索パス、つまり現在のデータ
ベースおよび SYSLIB データベースから削除します。詳細については、<SQL 外部
ルーチン プログラミング、B035-1147>の「UDF の位置」を参照してください。
• 完全修飾した構文を使用して、埋め込みサービス関数を呼び出します。
暗黙のデータ タイプ変換規則
埋め込みサービス関数は、UDF に適用される暗黙のデータ タイプ変換規則に従いま
す。UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変
換規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タ
イプに変換できない関数の引数は、明示的にキャストする必要があります。詳細に
ついては、<SQL 外部ルーチン プログラミング、B035-1147>の「互換データ型」
を参照してください。
関連トピック
詳細は、以下を参照してください。
• テーブル関数の例については、<SQL 外部ルーチン プログラミング、B035-1147>
を参照してください。
• たとえば、TD_SYSFNLIB.embedded_services_function のようにします。
SQL 演算子
SQL 演算子は、その引数に基づいて演算を実行するシンボルおよびキーワードです。
SQL では次の種類の演算子を使用することができます。
• 数値に対して実行される+、-などの算術演算子、日時、および間隔データ タイプ
です。
• 連結演算子||は、文字およびバイト タイプに対して実行されます。
SQL 関数、演算子、式および述部
9
第1章序
SQL 式
• =、>などの比較演算子は、引数の関係の真偽をテストします。比較演算子の詳細
については、「比較演算子と関数の概要」を参照してください。
比較演算子は、結果が TRUE、FALSE、不明(NULL)のいずれかの値になるため、
条件式とも呼ばれます。
• INTERSECT および UNION などの集合演算子または関係演算子は、複数のソース
からの結果の集合を単一の結果の集合に結合します。
SQL 式
SQL 式に値を指定すると、算術演算と論理演算を実行したり、リテラルと格納され
た値から新しい値や論理結果を生成したりできます。式は、次のものから構成する
ことができます。
•
•
•
•
•
•
•
列名
リテラル(定数とも呼ばれます)
関数
USING 変数
パラメータ
パラメータ マーカー(疑問符(?)プレースホルダー)
演算子で結合された列名、リテラル、および関数の組み合わせ
式の種類
SQL 式は通常、次のカテゴリに分類されます。
タイプ
説明
数値式
式は、通常、算出する結果の種類によって分類されます。
文字列式
たとえば、数値式は、列名、リテラル、関数で構成されているか、結
果が数値タイプの場合に算術演算子で結合された列名、リテラル定
数、および関数の組み合わせで構成されています。
日時式
間隔式
派生 PERIOD などの
期間式
CASE 式
CASE 式は、一連の WHEN/THEN 句とオプションの ELSE 句で構成さ
れています。
値形式の CASE 式は、テスト式と同等の最初の WHEN 式のテストを
行ない、一致する THEN 式の値を戻します。どの WHEN 式もテスト
式と同等でない場合、CASE は ELSE 式を返します。省略されている
場合には NULL を返します。
10
SQL 関数、演算子、式および述部
第1章序
SQL 述部
タイプ
説明
検索形式の CASE 式は、TRUE と評価される最初の WHEN 式のテスト
を行ない、一致する THEN 式の値を返します。どの WHEN 式も TRUE
と評価されない場合、CASE は ELSE 式を返します。省略されている
場合には NULL を返します。
式の例
式
説明
'Test Tech'
文字列リテラル
1024
数値リテラル
Employee.FirstName
列名
Salary * 12 + 100
数値を算出する算術式
INTERVAL '10' MONTH * 4
間隔値を算出する間隔式
CURRENT_DATE + INTERVAL '2' DAY
DATE 値を算出する日時式
CURRENT_TIME - INTERVAL '1' HOUR
TIME 値を算出する日時式
'Last' || ' Order'
文字列値を算出する文字列式
CASE x
数値を算出する値形式の CASE 条件式
WHEN 1
THEN 1001
ELSE 1002
END
SQL 述部
SQL 述部は論理述部とも呼ばれ、条件式の一種です。行またはグループの条件とし
て、次の 3 つのいずれかの状態を指定します。
• TRUE
• FALSE
• NULL(または不明)
述部は次のように表わされます。
• SELECT 文中の行を修飾または修飾解除するための WHERE、ON、または HAVING
句。
• 検索形式 CASE 式の WHEN 句検索条件。
SQL 関数、演算子、式および述部
11
第1章序
SQL 述部
• CASE_N 関数。
• ストアド プロシージャ内の IF、WHILE、REPEAT、および CASE 文。
論理述部の種類
SQL には次の論理述部があります。
•
•
•
•
•
•
•
比較演算子
[NOT] BETWEEN
LIKE
[NOT] IN
[NOT] EXISTS
OVERLAPS
IS [NOT] NULL
述部に対して操作を行なう論理演算子
• NOT
• AND
• OR
述部数量詞
• SOME
• ANY
• ALL
述部の例
述部
説明
SELECT *
Employee テーブルから行を選択するための条件
を指定する WHERE 句の述部。
FROM Employee
WHERE Salary < 40000;
SELECT SUM(CASE
WHEN part BETWEEN 100 AND 199
THEN 0
Orders テーブルの特定の行について、SUM 関数
に渡される値を決定する条件を指定する CASE 式
の述部。
ELSE cost
END)
FROM Orders;
12
SQL 関数、演算子、式および述部
第2章
集約関数
概要
この章では、SQL 集約関数について説明します。
詳細情報
• ウィンドウ集約関数とそれに相当する Teradata 固有の関数については、ウィン
ドウ集約関数を参照してください。
• 集約ユーザー定義関数(UDF)、集約 UDF を参照してください。
• ウィンドウ集約 UDF、ウィンドウ集約 UDF を参照してください。
集約関数について
集約関数は通常、算術式の中で使用されます。集約関数は、行のグループに対して
動作し、グループごとの結果テーブルに単一の値を返します。
次の文では、SUM 集約関数は Sales_Table テーブルによって定義された行のグルー
プに対して動作します。
SELECT SUM(Total_Sales)
FROM Sales_Table;
Sum(Total_Sales)
---------------5192.40
複数の結果値としてより複雑で精巧な結果を出すために、GROUP BY 句を使用する
ことができます。次の文では、SUM 集約関数は Sales_Table テーブルの Product_ID
列によって定義された行のグループに対して動作します。
SELECT Product_ID, SUM(Total_Sales)
FROM Sales_Table
GROUP BY Product_ID;
Product_ID Sum(Total_Sales)
---------- ---------------101
2100.00
107
1000.40
102
2092.00
集約と選択リスト
集約関数は通常、SELECT 文の式リスト内と、WITH 句の要約リスト内で使用され
ます。
SQL 関数、演算子、式および述部
13
第 2 章 集約関数
概要
集約と GROUP BY
SQL 文の選択リストで集約関数を使用する場合には、選択リストに含まれる他のす
べての列も、集約関数によって参照されなければなりません。または、その列名が
GROUP BY 句に入っていなければなりません。たとえば、以下の文では集約関数と
選択リストに含まれる列を使用しており、列名を GROUP BY 句で参照しています。
SELECT COUNT(*), Product_ID
FROM Sales_Table
GROUP BY Product_ID;
それは、非 GROUP BY の列参照は複数の値を戻すことができますが、集約は値を 1
つしか戻さないためです。
集約と日付
日付に AVG、MIN、MAX、COUNT を適用する操作は有効ですが、SUM(date)の指定
は無効です。
集約と選択リスト内のリテラル式
オプションで、選択リスト内のリテラル式を GROUP BY 句に入れることもできま
す。たとえば、以下の文では集約関数と選択リストに含まれるリテラル式を使用し
ていますが、GROUP BY 句を使用していません。
SELECT COUNT(*),
SUBSTRING( CAST( CURRENT_TIME(0) AS CHAR(14) ) FROM 1 FOR 8 )
FROM Sales_Table;
テーブルに行がない場合、このような文の結果は、リテラル式のタイプに応じて異
なります。
リテラル式
問合わせ結果内のリテラル式の結果
列参照が含まれていな リテラル式の値。
い場合
RANDOM などの関数は、集約ステップではなく、要求の即時検索
確定的な関数ではない ステップで計算されます。
場合(RANDOM など)
例を挙げます。
SELECT COUNT(*),
SUBSTRING(CAST(CURRENT_TIME(0) AS CHAR(14))
FROM 1 FOR 8)
FROM Sales_Table;
Count(*) Substring(Current Time(0) From 1 For 8)
-------- --------------------------------------0 09:01:43
14
SQL 関数、演算子、式および述部
第 2 章 集約関数
概要
リテラル式
問合わせ結果内のリテラル式の結果
列参照が含まれている NULL
場合
例を挙げます。
UDF の場合
SELECT COUNT(*), UDF_CALC(1,2)
FROM Sales_Table;
Count(*) UDF_CALC(1,2)
----------- ------------0
?
集約の入れ子
集約演算を入れ子にすることはできません。以下の集約は無効であり、エラーが返
されます。
AVG(MAXIMUM (Salary))
しかし、集約関数を集約ウィンドウ関数の入れ子にすることは可能です。次の文で
は SUM 集約関数が RANK ウィンドウ関数の入れ子になっており、有効です。
SELECT region
,product
,SUM(amount)
,RANK() OVER (PARTITION BY region ORDER by SUM (amount))
FROM table;
ゼロ行に対する集約の結果
ゼロ行に対して集約を実行すると、動作は次の表のようになります。
集約関数の形式
ゼロ行しかない場合に戻される
結果
COUNT(expression) WHERE …
0
他のすべての形式の aggregate_operator (expression)
WHERE …
Null
aggregate_operator (expression) … GROUP BY …
レコードが見つからない
aggregate_operator (expression) … HAVING …
集約と NULL
COUNT(*)以外の集約は、すべての計算で null を無視します。
SQL 関数、演算子、式および述部
15
第 2 章 集約関数
概要
注: UDT 列の値が NULL になるのは、NULL に設定された属性を UDT インスタンス
が持っている場合ではなく、列に明示的に NULL を入れた場合だけです。
null を無視すると、明らかに過渡的ではない異常な結果になることがあります。た
とえば、列 A または列 B (あるいはその両方)に NULL があると、実際に、次の式は、
必ず真になります。
SUM(A) + SUM(B) <> SUM(A+B)
ただし、列 A と B の両方の値が同じ行にあって NULL である場合は、例外です。そ
の場合には、行の全体が集約において無視されるからです。これは、一般規則に違
反しないようなささいな例です。
より正式にいえば、フィールド A とフィールド B の両方が null である場合にだけ、
いずれかのフィールドに null が現われるたびに上記の不等条件が false になります。
この動作を示す例については、結果のタイプと属性の「例: Null として返される社
員」および「例: 部署に割り当てられていない社員のカウント」を参照してくださ
い。集約は確実に所定どおりに動作していて、結果は算術的に異常にならないこと
に注意する必要があります。
この明らかに過渡的ではない問題が現われた場合には、解決する手段がいくつかあ
ります。次のいずれかの解決方法では、一定の同じ結果が得られます。
• 必ず、数値列を NOT NULL DEFAULT 0 として定義します。
• 集約関数の中で ZEROIFNULL 関数を使用して、計算のために NULL をゼロに変換
します。たとえば、SUM(ZEROIFNULL(x) + ZEROIFNULL(y))は、
SUM(ZEROIFNULL(x) + ZEROIFNULL(y))と同じ結果を出します。
浮動小数点データに対する集約演算
次のように、浮動小数点数を使った演算は、概算および四捨五入のエラーのせいで
常にそれぞれが相互に関連しあっているとは限りません。((A+B)+C)は必ずしも(A+(B
+C))に等しいわけではありません。
また、まだ明白ではありませんが、浮動小数点値の算術の非結合性が集計操作に影
響を与える可能性もあります。 所定の浮動小数データで集計関数を使うたびに、異
なる結果になることがあります。Teradata Database が集約を実行する場合、最終的
な結果を生成するために、計算に含まれた各 AMP から個々の条件を累積して条件を
評価します。 評価の順序によって、結果が多少異なる場合があり、また個々の AMP
がそれらの作業を終了する順序が予想できないため、同じシステム上の同じデータ
の集計関数の結果が異なることがあります。
集約と LOB
集約は CLOB または BLOB データ タイプをサポートしていません。
16
SQL 関数、演算子、式および述部
第 2 章 集約関数
概要
集約および Period データ タイプ
集約(COUNT を除く)は、Period データ タイプをサポートしていません。
集約と SELECT AND CONSUME 文
集約は、SELECT AND CONSUME 文では使用できません。
集約と再帰的問合わせ
集約関数は、再帰的問合わせの再帰文では使用できません。ただし、再帰的問合わ
せの中の非再帰シード文で集約関数を指定することができます。
WHERE および HAVING 句で使用される集約
集約は、以下のタイプの句で使用することができます。
• アボート条件を指定するための ABORT 文の WHERE 句。
ただし、集約関数を SELECT 文の WHERE 句で使用することはできません。
• グループ条件を指定するための HAVING 句。
DISTINCT オプション
DISTINCT オプションは、式が処理される時に重複した値が使用されないように指
定します。
次の SELECT はテーブルの中の固有のジョブ タイトルの数を戻します。
SELECT COUNT(DISTINCT JobTitle) FROM Employee;
以下の例に示すとおり、1 つの問合わせで、同一式をもった DISTINCT を使用する
複数の集約関数をもつことができます。
SELECT SUM(DISTINCT x), AVG(DISTINCT x) FROM XTable;
また、次の例のように、1 つの問合わせで、さまざまな式をもつ DISTINCT を使用
する複数の集約関数をもつこともできます。
SELECT SUM(DISTINCT x), SUM(DISTINCT y) FROM XYTable;
集約および行レベル セキュリティ テーブル
行レベル セキュリティで保護されたテーブルを参照する集約関数(SUM、COUNT、
MAX、MIN または AVG など)が要求に含まれている場合、その集約は要求を発行し
たユーザーがアクセスできる行にのみ基づいたものになります。この集約をテーブ
ルに含まれるすべての行に適用するには、ユーザーには次のいずれかが必要になり
ます。
SQL 関数、演算子、式および述部
17
第 2 章 集約関数
AVG
• テーブルのすべての行にアクセスするために必要なセキュリティ クレデンシャル。
• テーブルのセキュリティ制約に対して必要な OVERRIDE 権限。
関連トピック
計算での浮動小数点値に関連する潜在的な問題の詳細は、< SQL データ型とリテラ
ル、B035-1143>を参照してください。
詳細:
• ウィンドウ集約関数とそれに相当する Teradata 固有の関数については、ウィンド
ウ集約関数を参照してください。
• 集約ユーザー定義関数(UDF)、集約 UDF を参照してください。
• ウィンドウ集約 UDF、ウィンドウ集約 UDF を参照してください。
• 行レベル セキュリティについては、<セキュリティ管理ガイド 、B035-1100>を
参照してください。
AVG
目的
value_expression のすべての値の算術平均値を返します。
構文
AVERAGE
(
value_expression )
AVG
DISTINCT
AVE
ALL
構文要素
ALL
value_expression の null でないすべての値が、重複を含めて、計算に含まれます。
DISTINCT
value_expression によって指定された重複を計算から除外します。
value_expression
平均値が計算されるリテラルまたは列式。
この式に順序付き分析関数や集約関数を含めることはできません。
18
SQL 関数、演算子、式および述部
第 2 章 集約関数
AVG
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
AVERAGE と AVE は、ANSI 標準の Teradata 拡張機能です。
結果のタイプと属性
次の表に、AVG の結果のデフォルト属性をリストしています。
属性
値
データ タ REAL
イプ
タイトル
Average(x)
書式
オペランドが数値、日付、または間隔である場合、書式は x と同じ書式です。
オペランドが文字である場合、書式は FLOAT のデフォルトの書式です。
オペランドが UDT である場合、書式は UDT の暗黙キャスト先のデータ タイプ
の書式です。
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの
間でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行
ないます。
• 数値
• 文字
• DATE
• 間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。
AVG を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、ANSI SQL
規格の Teradata 拡張機能です。
INTEGER 値または DECIMAL 値の計算
DECIMAL または INTEGER 値の AVG は、個々の値が非常に大きい場合、または値の
数が多い場合には、オーバーフローになる可能性があります。
オーバーフローが発生した場合には、次のように、DECIMAL または INTEGER 値を
REAL に変換する CAST 関数を入れて AVG の呼出しを変更します。
AVG(CAST(value AS REAL) )
平均をとる前に値を REAL としてキャストすると、多少精度を欠くことになります。
結果のタイプは、どちらの場合も REAL になるため、CAST を行なっても多少精度
が悪くなるだけでその他の点においては結果は変わりません。
SQL 関数、演算子、式および述部
19
第 2 章 集約関数
AVG
x が整数である場合には、AVG は小数値を表示しません。小数値は、値を DECIMAL
としてキャストすることによって得られます。たとえば、次の DECIMAL への CAST
を使用します。
CAST(AVG(value) AS DECIMAL(9,2))
制約事項
value_expression は、関数によって得られたビュー列に対する列参照であってはな
りません。
AVG は数値データに対してのみ有効です。
結果の計算には NULL は含められません。
例: 地域ごとの平均売上の売上テーブルの問合わせ
この例では、地域ごとの平均の売上を問合わせ、次の結果を戻します。
SELECT Region, AVG(sales)
FROM sales_tbl
GROUP BY Region
ORDER BY Region;
Region Average (sales)
------ --------------North
21840.17
East
55061.32
Midwest
15535.73
AVG ウィンドウ関数
グループ、累計、および移動平均を計算する AVG ウィンドウ関数については、ウィ
ンドウ集約関数を参照してください。
関連トピック
詳細は、以下を参照してください。
• 計算での浮動小数点値に関連する潜在的な問題の詳細は、< SQL データ型とリテ
ラル、B035-1143>を参照してください。
• 書式における書式設定文字についての説明は、 < SQL データ型とリテラル、
B035-1143>の「データ タイプの書式および書式句」を参照してください。
• セキュリティ管理ガイド 、B035-1100
• CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>
を参照してください。
• AVG 拡張を無効にするには、DBS 制御レコードの
DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳細は、
<ユーティリティ 、B035-1102>を参照してください。
20
SQL 関数、演算子、式および述部
第 2 章 集約関数
CORR
• UDT の暗黙タイプ変換の詳細は、概要を参照してください。
• null の詳細については、<SQL 基礎、B035-1141>および集約と NULL を参照し
てください。
• 集約ユーザー定義関数(UDF)、集約 UDF を参照してください。
• ウィンドウ集約 UDF、ウィンドウ集約 UDF を参照してください。
CORR
目的
すべての非 null データ点の対について、引数のサンプル ピアソン積モーメントの相
関係数を返します。
構文
CORR
( value_expression_1, value_expression_2 )
構文要素
value_expression_2/value_expression_1
第 2 の数値式との相関をとる数値式。
この式に順序付き分析関数や集約関数を含めることはできません。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
定義
サンプル ピアソン積モーメント相関係数は、変数間の線形関連の尺度です。算出さ
れる係数の範囲は -1.00 ~ +1.00 です。
相関が高いからといって、変数間に因果関係があることを暗示してはいないことに
注意する必要があります。
次の表は、2 つの変数間の相関係数の 4 つの極限値の意味を示しています。
相関係数の値
変数間の関連
-1.00
完全に線形で逆向き
y の値の変化につれて、x も逆方向に等量変化する。
0
関連はなく、いわゆる「相関なし」。
+1.00
完全に線形。
y の値の変化につれて、x も同方向に等量変化する。
SQL 関数、演算子、式および述部
21
第 2 章 集約関数
CORR
相関係数の値
変数間の関連
NULL
計算に使用される非 NULL データ点の対がデータに存在しない
ため、測定不能。
計算
CORR の計算の公式は次のように定義されます。
変数
内容
x
value_expression_2
y
value_expression_1
ゼロで割ると、エラーではなく NULL になります。
結果のタイプと属性
CORR(y, x)のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ
書式
タイトル
REAL
DECIMAL(7,6)のデフォルト書式
CORR(y,x)
書式における書式設定文字についての説明は、 < SQL データ型とリテラル、
B035-1143>の「データ タイプの書式および書式句」を参照してください。
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの間
でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行な
います。
•
•
•
•
数値
文字
DATE
間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
CORR を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、ANSI SQL
規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レコードの
DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。
他の関数との組み合わせ
CORR は、SELECT リスト、QUALIFY 句、または ORDER BY 句の中で、順序付き分
析関数と組み合わせることができます。 順序付き分析関数の詳細は、順序付き分析
関数を参照してください。
22
SQL 関数、演算子、式および述部
第 2 章 集約関数
COUNT
CORR は、同じ SELECT リスト、QUALIFY 句、または ORDER BY 句の中の集約関数
と組み合わせることはできません。
例: HomeSales テーブルのデータの問合わせ
この例では、次の HomeSales テーブルのデータを使用します。
SalesPrice
---------160000
180000
200000
220000
240000
260000
280000
NbrSold
------126
103
82
75
82
40
20
Area
--------358711030
358711030
358711030
358711030
358711030
358711030
358711030
次の問合わせについて説明します。
SELECT CAST (CORR(NbrSold,SalesPrice) AS DECIMAL (6,4))
FROM HomeSales
WHERE area = 358711030
AND SalesPrice Between 160000 AND 280000;
CORR(NbrSold,SalesPrice)
------------------------.9543
結果の-.9543 は、変数間に逆向きの関係があることを示唆しています。つまり、問
合わせで指定された Area と SalesPrice の範囲において、NbrSold の値は、SalesPrice
が減少すると増加し、SalesPrice が増加すると減少します。
CORR ウィンドウ関数
グループ、累計、または移動を計算する CORR ウィンドウ関数については、ウィン
ドウ集約関数を参照してください。
関連トピック
詳細は、以下を参照してください。
• UDT の暗黙タイプ変換の詳細は、概要を参照してください。
• 詳細は、<ユーティリティ 、B035-1102>を参照してください。
COUNT
目的
value_expression 内で限定された行の合計数として列の値を返します。
SQL 関数、演算子、式および述部
23
第 2 章 集約関数
COUNT
構文
COUNT
(
value_expression
)
DISTINCT
ALL
*
構文要素
ALL
null でない value_expression のすべての値が、重複も含めて、この計算に含まれます。
DISTINCT
value_expression によって指定された重複を計算から除外します。
この式に順序付き分析関数や集約関数を含めることはできません。
value_expression
値の数が計算されるリテラルまたは列式。
この式に順序付き分析関数や集約関数を含めることはできません。
*
COUNT によって操作が実行される行のグループ内のすべての行をカウントします。
使用上の注意
構文
カウントする行の総数
COUNT(value_expression)
value_expression が null ではないグループ。
COUNT (DISTINCT value_expression) value_expression が一意で null ではないグループ。
COUNT(*)
COUNT が動作する行のグループ。
COUNT はすべてのデータ タイプに有効です。
結果のタイプと属性
次の表に、COUNT の結果のデータ タイプと書式をリストしています。
モード
データ タイプと書式
ANSI
MaxDecimal は、DBS 制御ユーティリティの一般フィールド 13 です。
DBSControl 内の MaxDecimal の値
• 0 または 15。結果タイプは DECIMAL(15,0)、書式は-(15)9。
• 18。結果タイプは DECIMAL(18,0)、書式は-(18)9。
• 38。結果タイプは DECIMAL(38,0)、書式は-(38)9。
24
SQL 関数、演算子、式および述部
第 2 章 集約関数
COUNT
モード
データ タイプと書式
TERADA
TA
INTEGER および書式は INTEGER のデフォルト書式です。
COUNT
DBSControl 一般フィールド(80)、COUNT_mode のデフォルト値は 0 です。デ
フォルトは互換性モードで、外部アプリケーションに影響するすべての拡張機能
を無効にします。
BIGINT モードと NUMBER モードは COUNT のパフォーマンスに影響を及ぼします。
• 型の上位変換には、モードが変更された場合、別の型を使用した計算式が必要に
なることがあります。これは、COUNT (*)ベースの式の結果が BIGINT/NUMBER
タイプとして実体化され、後で副式として別の式の計算に使用される場合に発生
します。パフォーマンス オーバーヘッドは、COUNT (*)を BIGINT/NUMBER と
してキャストしたときに発生するものと同じです。
• モードが変更されると COUNT (*)のデータ型が変わるため、書式、タイトル、
データ型を仮定した問合わせではこの変更に注意する必要があります。
COUNT の結果がオーバーフローを起こし、エラーが報告された場合には、次の例
のように結果を別のデータ型にキャストできます。
SELECT CAST(COUNT(*) AS BIGINT)
FROM BIGTABLE;
COUNT 関数と RANK ウィンドウ関数について同様の例を示します。
SELECT CAST(COUNT(*) over([PARTITION/ORDER BY]) AS BIGINT)
FROM BIGTABLE;
SELECT CAST(rank over([PARTITION/ORDER BY]) AS BIGINT)
FROM BIGTABLE;
注: CAST は、デフォルトまたは互換性モードに対してのみ必要です。COUNT 計算
の NUMBER または BIGINT モードに対し値 1 または 2 が指定されている場合、CAST
は不要です。
次の表に、COUNT の結果の初期設定タイトルをリストしています。
演算
タイトル
COUNT(x)
Count(x)
COUNT(*)
Count(*)
集約結合索引内の COUNT 指定
結合索引の COUNT 集約関数に対し、COUNT、FLOAT OR DECIMAL(38,0)への
COUNT キャスト、BIGINT、または NUMBER を指定できます。以下に、BIGINT へ
のデータ型キャストを格納する SHOW JOIN INDEX を示します。
CREATE JOIN INDEX TEST.j1 ,NO FALLBACK ,CHECKSUM = DEFAULT AS
SELECT COUNT (*)(BIGINT, NAMED a ),TEST.t1.a1
FROM TEST.t1
GROUP BY TEST.t1.a1
PRIMARY INDEX ( a1 );
SQL 関数、演算子、式および述部
25
第 2 章 集約関数
COUNT
例: 各部門の従業員数の報告
COUNT (*)は、GROUP BY 句が部門番号ごとに結果をグループ化するため、各部門の
従業員数を報告します。
SELECT DeptNo, COUNT(*) FROM Employee
GROUP BY DeptNo
ORDER BY DeptNo;
GROUP BY 句を指定しなければ、Employee テーブルに入っている従業員の総数だけ
が報告されます。
SELECT COUNT(*) FROM Employee;
GROUP BY 句を指定しなければ選択リストに DeptNo 列を含めることができないこ
とに注意してください。それは、その場合に任意の数の値が戻されるのに対して、
COUNT(*)が 1 つの値しか戻さないためです。
例: Null として返された従業員
挿入されているが、まだ部門が割り当てられていない従業員がいる場合、その従業
員の DeptNo 列に NULL が入ります。
SELECT DeptNo, COUNT(*) FROM Employee
GROUP BY DeptNo
ORDER BY DeptNo;
2 人の新しい従業員に部門が割り当てられていないと想定すると、その結果のテー
ブルは次のようになります。
DeptNo
-----?
100
300
500
600
700
Count(*)
-------2
4
3
7
4
3
例: 部門にまだ割り当てられていない従業員数の計算
例: 各部門の従業員数のレポートの実行において、SELECT... COUNT … を使用し、部
門番号による結果のグループ化を行なわなかったとしたら、結果テーブルには DeptNo
の登録済みの非 NULL のオカレンスだけが含まれることになり、部門に未割り当て
(NULL)の 2 人の従業員は含まれないことになります。カウントが異なります(例: 各
部門の従業員数のレポートでは 23 になり、この例で説明する文を使用すると 21 に
なります)。
Employee テーブルの中で部門に割り当てられている 21 人の従業員のほかに、部門
に割り当てられていない新しい従業員が 2 人いることを思い出してください(それぞ
れの新しい従業員の行には、null の部門番号が入っています)。
SELECT COUNT(deptno) FROM employee ;
この SELECT によって、COUNT は、非 null 部門番号のオカレンスの総数を戻します。
集約関数は null を無視するため、2 人の新しい従業員は数えられません。
26
SQL 関数、演算子、式および述部
第 2 章 集約関数
COUNT
Count(DeptNo)
-------------21
例: 性別による従業員数を出すための COUNT の使用
この例では、COUNT を使用して、データベースの Employee テーブル内の男性従業
員の数を数えます。
SELECT COUNT(sex)
FROM Employee
WHERE sex = 'M' ;
結果は、以下のようになります。
Count(Sex)
---------12
例: 非 Null 部門番号の行の総数の計算
この例では、COUNT が、null でない部門番号の行の総数を部門ごとに数えます。
SELECT deptno, COUNT(deptno)
FROM employee
GROUP BY deptno
ORDER BY deptno ;
ここでも、2 人の新しい従業員が数えられていないことに注意する必要があります。
DeptNo
-----100
300
500
600
700
Count(DeptNo)
------------4
3
7
4
3
例: 部門ごとの従業員数を返す
部門番号ごとの従業員数を入手するには、GROUP BY 句および ORDER BY 句を指定
した COUNT (*)を使用します。
SELECT deptno, COUNT(*)
FROM employee
GROUP BY deptno
ORDER BY deptno ;
この場合には、?で示された null も含まれます。
DeptNo
-----?
100
300
500
SQL 関数、演算子、式および述部
Count(*)
-------2
4
3
7
27
第 2 章 集約関数
COVAR_POP
600
700
4
3
例: Employee テーブルにある部門数の判別
Employee テーブルにある部門の数を調べるには、次の SELECT COUNT に示すよう
に COUNT (DISTINCT)を使用します。
SELECT COUNT (DISTINCT DeptNo)
FROM Employee ;
次のレポートが生成されます。
Count(Distinct(DeptNo))
----------------------5
関連トピック
詳細は、以下を参照してください。
• グループ、累計、および移動カウントを戻す COUNT 関数については、ウィンド
ウ集約関数を参照してください。
• COUNT(*)を例外として、計算には NULL は組み込まれません。詳細については、
<SQL 基礎、B035-1141>および集約と NULL を参照してください。
• データ タイプのデフォルトの書式の詳細については、< SQL データ型とリテラ
ル、B035-1143>の「データ タイプの書式および書式句」を参照してください。
• COUNT_mode フィールドについては、<ユーティリティ 、B035-1102>を参照し
てください。
COVAR_POP
目的
すべての非 NULL のデータ点の対に対して、引数の母集団共分散を戻します。
構文
COVAR_POP
( value_expression_1, value_expression_2 )
構文要素
value_expression_1/value_expression_2
第 2 の数値式と対になって共分散を判別する数値式。
この式に順序付き分析関数や集約関数を含めることはできません。
28
SQL 関数、演算子、式および述部
第 2 章 集約関数
COVAR_POP
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
定義
共分散は、2 つのランダム変数が同じように分散しているかどうかを示す尺度です。
これは、各々の非 null データ点の対についての偏差積の平均です。
共分散が高いからといって、変数間に因果関係があることを暗示してはいないこと
に注意する必要があります。
他の関数との組み合わせ
COVAR_POP は、SELECT リスト、QUALIFY 句、または ORDER BY 句の中で、順序
付き分析関数と組み合わせることができます。
COVAR_POP は、同じ SELECT リスト、QUALIFY 句、または ORDER BY 句の中の集
約関数と組み合わせることはできません。
計算
計算に使用される非 NULL のデータ点の対がデータにない場合は、COVAR_POP は
NULL を戻します。
ゼロで割ると、エラーではなく NULL になります。
結果のタイプと属性
COVAR_POP のデータ タイプ、書式、およびタイトルは、次のとおりです。
データ タイプ: REAL
• オペランドが文字である場合、書式は FLOAT のデフォルトの書式です。
• オペランドが数値、日付、または間隔である場合、書式は x と同じ書式です。
• オペランドが UDT である場合、書式は UDT の暗黙キャスト先のデータ タイプの
書式です。
データ タイプのデフォルトの書式、および書式における書式設定文字についての説
明は、< SQL データ型とリテラル、B035-1143>の「データ タイプの書式および書
式句」を参照してください。
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの
間でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行
ないます。
• 数値
• 文字
• DATE
SQL 関数、演算子、式および述部
29
第 2 章 集約関数
COVAR_SAMP
• 間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
COVAR_POP を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、
ANSI SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レ
コードの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳
細は、<ユーティリティ 、B035-1102>を参照してください。
UDT の暗黙タイプ変換の詳細は、概要を参照してください。
COVAR_POP ウィンドウ関数
グループ、累計、または移動を計算する COVAR_POP ウィンドウ関数については、
ウィンドウ集約関数を参照してください。
COVAR_SAMP
目的
すべての非 NULL のデータ点の対に対して、引数の標本共分散を戻します。
構文
COVAR_SAMP
( value_expression_1, value_expression_2 )
構文要素
value_expression_2/value_expression_1
第 2 の数値式と対になって共分散を判別する数値式。
この式に順序付き分析関数や集約関数を含めることはできません。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
定義
共分散は、2 つのランダム変数が同じように分散しているかどうかを示す尺度です。
これは、各々の非 null データ点の対についての偏差積の合計です。
共分散が高いからといって、変数間に因果関係があることを暗示してはいないこと
に注意する必要があります。
30
SQL 関数、演算子、式および述部
第 2 章 集約関数
COVAR_SAMP
他の関数との組み合わせ
COVAR_SAMP は、SELECT リスト、QUALIFY 句、または ORDER BY 句の中で、順
序付き分析関数と組み合わせることができます。 順序付き分析関数の詳細は、ウィ
ンドウ集約関数を参照してください。
COVAR_SAMP は、同じ SELECT リスト、QUALIFY 句、または ORDER BY 句の中の
集約関数と組み合わせることはできません。
計算
計算に使用される非 NULL のデータ点の対がデータにない場合は、COVAR_SAMP
は NULL を戻します。
ゼロで割ると、エラーではなく NULL になります。
結果のタイプと属性
COVAR_SAMP(y, x)のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ: REAL
• オペランドが文字である場合、書式は FLOAT のデフォルトの書式です。
• オペランドが数値、日付、または間隔である場合、書式は x と同じ書式です。
• オペランドが UDT である場合、書式は UDT の暗黙キャスト先のデータ タイプの
書式です。
データ タイプのデフォルトの書式、および書式における書式設定文字についての説
明は、< SQL データ型とリテラル、B035-1143>の「データ タイプの書式および書
式句」を参照してください。
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの
間でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行
ないます。
• 数値
• 文字
• DATE
• 間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
COVAR_SAMP を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、
ANSI SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レ
コードの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳
細は、<ユーティリティ 、B035-1102>を参照してください。
UDT の暗黙タイプ変換の詳細は、データ型の変換を参照してください。
SQL 関数、演算子、式および述部
31
第 2 章 集約関数
GROUPING
COVAR_SAMP ウィンドウ関数
グループ、累計、または移動を計算する COVAR_SAMP ウィンドウ関数については、
ウィンドウ集約関数を参照してください。
例: SELECT 文を使用して、weight と height の標本共分散を返す
この例は、次の regrtbl データに基づいています。Null は?によって示されています。
c1
height
weight
1
60
84
2
62
95
3
64
140
4
66
155
5
68
119
6
70
175
7
72
145
8
74
197
9
76
150
10
76
?
11
?
150
12
?
?
次の SELECT 文は、weight と height がどちらも null でない部分における、weight
と height の標本共分散を戻します。
SELECT COVAR_SAMP(weight,height)
FROM regrtbl;
Covar_Samp(weight,height)
------------------------150
GROUPING
目的
結果行の指定された列が GROUP BY 句のグループ化セットから除外されたかどうか
を示す値を戻します。
32
SQL 関数、演算子、式および述部
第 2 章 集約関数
GROUPING
構文
GROUPING
( expression (
構文要素
expression
CUBE、ROLLUP、または GROUPING SET が含まれている、グループ化された問合
わせから除外された可能性のある、結果行内の列。
引数は GROUP BY 句の項目でなければなりません。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
使用上の注意
CUBE、ROLLUP、または GROUPING SET が含まれている、グループ化された問合
わせの結果行に NULL があるということは、次のいずれかを意味する場合がありま
す。
• 列の実際のデータが NULL である。
• 拡張されたグループ化指定がその列で集約を実行し、特定のグループ化からその
列を除外した。この場合の null は、この列のすべての値を表わします。
実データが NULL の行と、グループ化セットで NULL が生成された行を区別するに
は、GROUPING を使用します。
結果のタイプと属性
GROUPING(x)のデータ タイプ、書式、およびタイトルは、次のとおりです。
データ タイプ
書式
タイトル
INTEGER
INTEGER データ タイプのデフォルト書式
Grouping(x)
結果値
結果行の指定された列の値
GROUPING から戻される
もの
拡張されたグループ化指定がその列で集約を実行し、特定のグ 1
ループ化からその列を除外した場合に生成される NULL
その他
SQL 関数、演算子、式および述部
0
33
第 2 章 集約関数
GROUPING
例: 国と市ごとの売上げの要約の表示
次のような sales_view テーブルのデータがあるとします。
PID
コスト
Sale
Margin
状態
County
City
1
38350
50150
11800
CA
Los Angeles
Long Beach
1
63375
82875
19500
CA
San Diego
San Diego
1
46800
61200
14400
CA
Los Angeles
Avalon
2
40625
53125
12500
CA
Los Angeles
Long Beach
County ごと、および City ごとの売上げの要約を調べるには、次の SELECT 文を使用
します。
SELECT county, city, sum(margin)
FROM sale_view
GROUP BY GROUPING SETS ((county),(city));
問合わせにより、次のデータがレポートされます。
County
----------Los Angeles
San Diego
?
?
?
City
---------?
?
Long Beach
San Diego
Avalon
Sum(margin)
----------38700
19500
24300
19500
14400
この例の場合、null は列のすべての値を表わしていることに注意してください。そ
れは、示されているグループ化セットからこの列が除外されているためです。
実データが null の行と、グループ化セットで null が生成された行を区別するには、
GROUPING 関数を使用します。
SELECT county, city, sum(margin),
GROUPING(county) AS County_Grouping,
GROUPING(city) AS City_Grouping
FROM sale_view
GROUP BY GROUPING SETS ((county),(city));
結果は次のようになります。
County
----------Los Angeles
San Diego
?
?
?
City
Sum(margin) County_Grouping City_Grouping
---------- ----------- --------------- ------------?
38700
0
1
?
19500
0
1
Long Beach
24300
1
0
San Diego
19500
1
0
Avalon
14400
1
0
拡張グループ化指定が列に対して集約を実行し、その列を特定のグループ化から除
外したために結果行に現われた null を置換するために、GROUPING を使用すること
もできます。たとえば、
34
SQL 関数、演算子、式および述部
第 2 章 集約関数
KURTOSIS
SELECT CASE
WHEN GROUPING(county) = 1
THEN '-All Counties-'
ELSE county
END AS County,
CASE
WHEN GROUPING(city) = 1
THEN '-All Cities-'
ELSE city
END AS City,
SUM(margin)
FROM sale_view
GROUP BY GROUPING SETS (county,city);
問合わせにより、次のデータがレポートされます。
County
-------------Los Angeles
San Diego
-All Counties-All Counties-All Counties-
City
------------All Cities-All CitiesLong Beach
San Diego
Avalon
Sum(margin)
----------38700
19500
24300
19500
14400
関連トピック
GROUP BY、GROUPING SETS、ROLLUP、および CUBE の詳細は、< SQL データ操
作言語、B035-1146>を参照してください。
データ タイプのデフォルトの書式の詳細については、< SQL データ型とリテラル、
B035-1143>の「データ タイプの書式および書式句」を参照してください。
KURTOSIS
目的
value_expression の分布のとがり(kurtosis)を戻します。
構文
KURTOSIS
value_expression )
(
DISTINCT
ALL
SQL 関数、演算子、式および述部
35
第 2 章 集約関数
KURTOSIS
構文要素
ALL
null でない value_expression のすべての値が、重複も含めて、この計算に含まれます。
DISTINCT
value_expression によって指定された重複を計算から除外します。
value_expression
値の分布のとがりを計算するリテラルまたは列式。
この式に順序付き分析関数や集約関数を含めることはできません。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
定義
とがり(kurtosis)は分布の第 4 モーメントです。これは、正規(ガウス)分布と比較し
た場合の、相対的なピークの大きさ、あるいは平坦さの尺度です。
正規分布のとがりはゼロです。
とがりが正の値であれば分布のピークが高く、とがりが負の値であれば相対的に平
坦であることを示します。
結果のタイプと属性
KURTOSIS(x)のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ
書式
タイトル
REAL
REAL データ タイプのデフォルト書式
Kurtosis(x)
データ タイプのデフォルトの書式の詳細については、< SQL データ型とリテラル、
B035-1143>の「データ タイプの書式および書式句」を参照してください。
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの間
でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行な
います。
• 数値
• 文字
• DATE
• 間隔
36
SQL 関数、演算子、式および述部
第 2 章 集約関数
MAX
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
KURTOSIS を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、ANSI
SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レコー
ドの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳細
は、<ユーティリティ 、B035-1102>を参照してください。
UDT の暗黙タイプ変換の詳細は、「データ型の変換」を参照してください。
計算
KURTOSIS の計算の公式は次のように定義されます。
説明:
変数
内容
x
value_expression
NULL 戻り値になる条件
次の条件は、NULL 戻り値になります。
• 計算に使用されるデータに、非 NULL のデータ点が 4 個未満しかない。
• STDDEV_SAMP(x) = 0
• 0 による除算
MAX
目的
value_expression の最大値である列の値を返します。
構文
MAXIMUM
MAX
(
value_expression )
DISTINCT
ALL
構文要素
ALL
value_expression によって指定された null でないすべての値が、重複も含めて、グ
ループの最大値計算に含まれます。これは、デフォルトです。
SQL 関数、演算子、式および述部
37
第 2 章 集約関数
MAX
DISTINCT
value_expression によって指定された重複を計算から除外します。
value_expression によって指定された重複値と null でない値がグループの最大値計
算から除外されます。
value_expression
最大値が計算されるリテラルまたは列式。
この式に順序付き分析関数や集約関数を含めることはできません。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
MAXIMUM は、ANSI SQL:2011 規格の Teradata 拡張機能です。
結果のタイプと属性
次の表に、MAX(x)の結果のデフォルト属性をリストしています。
属性
値
データ タ
イプ
オペランド x が UDT でない場合、結果のデータ タイプはオペランド x のデー
タ タイプです。
オペランド x が UDT である場合、結果のデータ タイプは UDT の暗黙キャス
ト先のデータ タイプです。
書式
オペランド x が UDT でない場合、結果のデータ タイプはオペランド x のデー
タ タイプです。
オペランド x が UDT である場合、結果のデータ タイプは UDT の暗黙キャス
ト先のデータ タイプです。
タイトル
Maximum(x)
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの間
でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行な
います。
• 数値
• 文字
• バイト
• DATE
• TIME または TIMESTAMP
• 間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
38
SQL 関数、演算子、式および述部
第 2 章 集約関数
MAX
MAX を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、ANSI SQL
規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レコードの
DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳細は、<
ユーティリティ 、B035-1102>を参照してください。
UDT の暗黙タイプ変換の詳細は、「データ型の変換」を参照してください。
使用上の注意
MAX は、数値型データと文字型データに対して有効です。文字式に使用された場
合、MAX は最高位の整列順を戻します。
結果の計算には NULL は含められません。詳細は、<SQL 基礎、B035-1141>ど集約
と NULL を参照してください。
value_expression が列式の場合、この列はデータが選択されるテーブル内の列を少
なくとも 1 つ参照する必要があります。
value_expression は、関数によって得られたビュー列に対する列参照を指定しては
なりません。
MAX ウィンドウ関数
グループ、累計、および移動最大値を計算する MAX ウィンドウ関数については、
ウィンドウ集約関数を参照してください。
例: CHARACTER データ
次の SELECT は、直ちに次の結果を戻します。
SELECT MAX(Name)
FROM Employee;
Maximum(Name)
------------Zorn J
例: 列の式
倉庫の在庫のうち、売上げ原価が最大の商品はどれかを知りたいとします。
SELECT MAX(CostOfSales) AS m, ProdID
FROM Inventory
GROUP BY ProdID
ORDER BY m DESC;
Maximum(CostOfSales)
-------------------1295
975
950
SQL 関数、演算子、式および述部
ProdID
-----3815
4400
4120
39
第 2 章 集約関数
MIN
MIN
目的
value_expression の最小値である列の値を返します。
構文
MINIMUM
(
MIN
value_expression )
DISTINCT
ALL
構文要素
ALL
value_expression によって指定された null でないすべての値が、重複も含めて、グ
ループの最小値計算に含まれます。これは、デフォルトです。
DISTINCT
value_expression によって指定された重複を計算から除外します。
value_expression によって指定された重複値と null でない値がグループの最小値計
算から除外されます。
value_expression
最小値が計算されるリテラルまたは列式。
この式に順序付き分析関数や集約関数を含めることはできません。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
MINIMUM は、ANSI SQL:2011 規格の Teradata 拡張機能です。
結果のタイプと属性
次の表に、MIN(x)の結果のデフォルト属性をリストしています。
属性
値
データ タ
イプ
オペランド x が UDT でない場合、結果のデータ タイプはオペランド x のデー
タ タイプです。
オペランド x が UDT である場合、結果のデータ タイプは UDT の暗黙キャス
ト先のデータ タイプです。
40
タイトル
Minimum(x)
書式
オペランド x が UDT でない場合、結果の書式はオペランド x の書式です。
SQL 関数、演算子、式および述部
第 2 章 集約関数
MIN
属性
値
オペランド x が UDT である場合、結果の書式は UDT の暗黙キャスト先のデー
タ タイプの書式です。
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの
間でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行
ないます。
• 数値
• 文字
• バイト
• DATE
• TIME または TIMESTAMP
• 間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
MIN を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、ANSI SQL
規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レコードの
DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳細は、<
ユーティリティ 、B035-1102>を参照してください。
UDT の暗黙タイプ変換の詳細は、「データ型の変換」を参照してください。
使用上の注意
MINIMUM は、数値データだけでなく文字データにも有効です。MINIMUM は、文
字式の最下位の整列順を戻します。
計算には NULL を組み込むことはできません。詳細については、<SQL 基礎、
B035-1141>の「Null の操作」、および「集約と Null」を参照してください。
value_expression が列式を指定する場合、この式はデータが選択されるテーブル内
の列を少なくとも 1 つ参照する必要があります。
value_expression が列参照を指定する場合、その列は関数によって得られたビュー
列であってはなりません。
MIN ウィンドウ関数
グループ、累計、および移動最大値を計算する MIN ウィンドウ関数については、
ウィンドウ集約関数を参照してください。
例: CHARACTER データで使用される MINIMUM
次の SELECT は、直ちに次の結果を戻します。
SQL 関数、演算子、式および述部
41
第 2 章 集約関数
REGR_AVGX
SELECT MINIMUM(Name)
FROM Employee;
Minimum(Name)
------------Aarons A
例: JIT インベントリ
ユーザーの製造販売店が最近ベンダーを変更し、そのベンダーからの部品で ProdID
当たり 20 個を超えるものが少ないことがわかっています。他の在庫商品で、新しい
出荷をスケジュールする必要があるほど量が少ないものがいくつあるかを知る必要
があります。ここで、「量が少ない」とは、その部品の QUANTITY 列が 30 未満の
ものと定義されます。
SELECT ProdID, MINIMUM(QUANTITY)
FROM Inventory
WHERE QUANTITY BETWEEN 20 AND 30
GROUP BY ProdID
ORDER BY ProdID;
レポートは次のようになります。
ProdID
----------1124
1355
3215
4391
Minimum(Quantity)
----------------24
21
25
22
REGR_AVGX
目的
従属および独立変数引数のすべての非 NULL データ ペアの
independent_variable_expression の平均を戻します。
構文
REGR_AVGX
( dependent_variable_expression, independent_variable_expression )
構文要素
dependent_variable_expression
回帰に対する従属変数。従属変数は、処理に対する応答として測定されるものです。
この式に順序付き分析関数や集約関数を含めることはできません。
42
SQL 関数、演算子、式および述部
第 2 章 集約関数
REGR_AVGX
independent_variable_expression
回帰に対する独立変数。独立変数とは、他の変数の動作をテストするためにユーザー
制御により変化する、何らかの処理です。
この式に順序付き分析関数や集約関数を含めることはできません。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
プロット用の軸の設定
プロット用にデータをエクスポートする場合、従属変数として y 軸(縦座標)、独立
変数として x 軸(横座標)を定義します。
他の関数との組み合わせ
REGR_AVGX は、SELECT リスト、QUALIFY 句、または ORDER BY 句の中で、順序
付き分析関数と組み合わせることができます。 順序付き分析関数の詳細は、ウィン
ドウ集約関数を参照してください。
REGR_AVGX は、同じ SELECT リスト、QUALIFY 句、または ORDER BY 句の中の集
約関数と組み合わせることはできません。
計算
計算に使用される非 NULL のデータ点の対がデータに 2 つ未満しかない場合は、
REGR_AVGX は NULL を戻します。
ゼロで割ると、エラーではなく NULL になります。
結果のタイプと属性
REGR_AVGX(y, x)のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ: REAL
• オペランドが文字である場合、書式は FLOAT のデフォルトの書式です。
• オペランドが数値、日付、または間隔である場合、書式は y と同じ書式です。
• オペランドが UDT である場合、書式は UDT の暗黙キャスト先のデータ タイプの
書式です。
データ タイプのデフォルトの書式、および書式における書式設定文字についての説
明は、< SQL データ型とリテラル、B035-1143>の「データ タイプの書式および書
式句」を参照してください。
SQL 関数、演算子、式および述部
43
第 2 章 集約関数
REGR_AVGX
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの間
でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行な
います。
• 数値
• 文字
• DATE
• 間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
REGR_AVGX を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、
ANSI SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レ
コードの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳
細は、<ユーティリティ 、B035-1102>を参照してください。
UDT の暗黙タイプ変換の詳細は、「データ型の変換」を参照してください。
REGR_AVGX ウィンドウ関数
グループ、累計、または移動を計算する REGR_AVGX ウィンドウ関数については、
ウィンドウ集約関数を参照してください。
例: regrtbl の height の平均を返す
この例は、次の regrtbl データに基づいています。Null は?によって示されています。
c1
-1
2
3
4
5
6
7
8
9
10
11
12
height
-----60
62
64
66
68
70
72
74
76
76
?
?
weight
-----84
95
140
155
119
175
145
197
150
?
150
?
次の SELECT 文は、weight と height がどちらも null でない部分における、regrtbl
の height の平均を戻します。
SELECT REGR_AVGX(weight,height)
FROM regrtbl;
Regr_Avgx(weight,height)
44
SQL 関数、演算子、式および述部
第 2 章 集約関数
REGR_AVGY
-----------------------68
REGR_AVGY
目的
従属および独立変数引数のすべての非 NULL データ ペアの
dependent_variable_expression の平均を戻します。
構文
REGR_AVGY
( dependent_variable_expression, independent_variable_expression )
構文要素
dependent_variable_expression
回帰に対する従属変数。従属変数は、処理に対する応答として測定されるものです。
この式に順序付き分析関数や集約関数を含めることはできません。
independent_variable_expression
回帰に対する独立変数。独立変数とは、他の変数の動作をテストするためにユーザー
制御により変化する、何らかの処理です。
この式に順序付き分析関数や集約関数を含めることはできません。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
プロット用の軸の設定
プロット用にデータをエクスポートする場合、従属変数として y 軸(縦座標)、独立
変数として x 軸(横座標)を定義します。
他の関数との組み合わせ
REGR_AVGY は、SELECT リスト、QUALIFY 句、または ORDER BY 句の中で、順序
付き分析関数と組み合わせることができます。 順序付き分析関数の詳細は、ウィン
ドウ集約関数を参照してください。
REGR_AVGY は、同じ SELECT リスト、QUALIFY 句、または ORDER BY 句の中の集
約関数と組み合わせることはできません。
SQL 関数、演算子、式および述部
45
第 2 章 集約関数
REGR_AVGY
計算
計算に使用される非 NULL のデータ点の対がデータに 2 つ未満しかない場合は、
REGR_AVGY は NULL を戻します。
ゼロで割ると、エラーではなく NULL になります。
結果のタイプと属性
REGR_AVGY(y, x)のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ: REAL
• オペランドが文字である場合、書式は FLOAT のデフォルトの書式です。
• オペランドが数値、日付、または間隔である場合、書式は y と同じ書式です。
• オペランドが UDT である場合、書式は UDT の暗黙キャスト先のデータ タイプの
書式です。
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの間
でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行な
います。
•
•
•
•
数値
文字
DATE
間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
REGR_AVGY を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、
ANSI SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レ
コードの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳
細は、<ユーティリティ 、B035-1102>を参照してください。
REGR_AVGY ウィンドウ関数
グループ、累計、または移動を計算する REGR_AVGY ウィンドウ関数については、
ウィンドウ集約関数を参照してください。
例: regrtbl から weight の平均を返す
この例は、次の regrtbl データに基づいています。Null は?によって示されています。
c1
-1
2
3
4
46
height
-----60
62
64
66
weight
-----84
95
140
155
SQL 関数、演算子、式および述部
第 2 章 集約関数
REGR_COUNT
5
6
7
8
9
10
11
12
68
70
72
74
76
76
?
?
119
175
145
197
150
?
150
?
次の SELECT 文は、height と weight がどちらも null でない部分における、regrtbl
の weight の平均を戻します。
SELECT REGR_AVGY(weight,height)
FROM regrtbl;
Regr_Avgy(weight,height)
-----------------------140
関連トピック
詳細は、以下を参照してください。
• データ タイプのデフォルトの書式、および書式における書式設定文字について
の説明は、< SQL データ型とリテラル、B035-1143>の「データ タイプの書式お
よび書式句」を参照してください。
• UDT の暗黙タイプ変換の詳細は、概要を参照してください。
REGR_COUNT
目的
従属および独立変数引数のすべての非 NULL データ ペアの数を戻します。
構文
REGR_COUNT
( dependent_variable_expression, independent_variable_expression )
構文要素
dependent_variable_expression
回帰に対する従属変数。従属変数は、処理に対する応答として測定されるものです。
この式に順序付き分析関数や集約関数を含めることはできません。
SQL 関数、演算子、式および述部
47
第 2 章 集約関数
REGR_COUNT
independent_variable_expression
回帰に対する独立変数。独立変数とは、他の変数の動作をテストするためにユーザー
制御により変化する、何らかの処理です。
この式に順序付き分析関数や集約関数を含めることはできません。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
プロット用の軸の設定
プロット用にデータをエクスポートする場合、従属変数として y 軸(縦座標)、独立変
数として x 軸(横座標)を定義します。
他の関数との組み合わせ
REGR_COUNT は、SELECT リスト、QUALIFY 句、または ORDER BY 句の中で、順
序付き分析関数と組み合わせることができます。 順序付き分析関数の詳細は、ウィ
ンドウ集約関数を参照してください。
REGR_COUNT は、同じ SELECT リスト、QUALIFY 句、または ORDER BY 句の中の
集約関数と組み合わせることはできません。
結果のタイプと属性
次の表に、REGR_COUNT(y,x)の結果のデータ タイプをリストしています。
モード
データ タイプ
ANSI
DBSControl 内の MaxDecimal の値
• 0 または 15。結果のタイプは DECIMAL(15,0)。
• 18。結果のタイプは DECIMAL(15,0)。
• 38。結果のタイプは DECIMAL(38,0)。
TERADATA
INTEGER
REGR_COUNT の結果のタイプは、ANSI トランザクション モードおよび Teradata ト
ランザクション モードの COUNT の結果のタイプと一致します。
Teradata モードのときに、 REGR_COUNT の結果がオーバーフローを起こし、エラー
が報告された場合には、次の例のように結果を別のデータ タイプにキャストできます。
SELECT CAST(REGR_COUNT(weight,height) AS BIGINT)
FROM regrtbl;
次に、REGR_COUNT の結果のデフォルトの書式とタイトルを示します。
• オペランド y が数値または文字である場合、書式は次のようになります。
• ANSI モードの場合の、DBSControl 内の MaxDecimal の値
0 または 15。書式は-(15)9。
48
SQL 関数、演算子、式および述部
第 2 章 集約関数
REGR_COUNT
18。書式は-(18)9。
38。書式は-(38)9。
• Teradata モードの場合、書式は INTEGER のデフォルトの書式。
• オペランド y が UDT である場合、書式は UDT の暗黙キャスト先のデータ タイ
プの書式です。
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの
間でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行
ないます。
•
•
•
•
数値
文字
DATE
間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
REGR_COUNT を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、
ANSI SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レ
コードの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳
細は、<ユーティリティ 、B035-1102>を参照してください。
REGR_COUNT ウィンドウ関数
グループ、累計、または移動を計算する REGR_COUNT ウィンドウ関数については、
ウィンドウ集約関数を参照してください。
例: regrtbl の行数を返す
この例は、次の regrtbl データに基づいています。Null は?によって示されています。
c1
height
weight
1
60
84
2
62
95
3
64
140
4
66
155
5
68
119
6
70
175
7
72
145
8
74
197
9
76
150
10
76
?
SQL 関数、演算子、式および述部
49
第 2 章 集約関数
REGR_INTERCEPT
c1
height
weight
11
?
150
12
?
?
次の SELECT 文は、regrtbl における、height と weight がどちらも null でない部分
の行数を戻します。
SELECT REG_COUNT(weight,height)
FROM regrtbl;
結果は以下のようになります。
Regr_Count(weight,height)
------------------------9
関連トピック
詳細は、以下を参照してください。
• データ タイプのデフォルトの書式の詳細については、< SQL データ型とリテラ
ル、B035-1143>の「データ タイプの書式および書式句」を参照してください。
• UDT の暗黙タイプ変換の詳細は、概要を参照してください。
• グループ、累計、または移動を計算する REGR_COUNT ウィンドウ関数について
は、ウィンドウ集約関数を参照してください。
REGR_INTERCEPT
目的
従属および独立変数引数のすべての非 NULL データ ペアを通して、一変量の線形回
帰直線の傾きを戻します。
構文
REGR_INTERCEPT
( dependent_variable_expression, independent_variable_expression )
構文要素
dependent_variable_expression
回帰に対する従属変数。従属変数は、処理に対する応答として測定されるものです。
この式に順序付き分析関数や集約関数を含めることはできません。
50
SQL 関数、演算子、式および述部
第 2 章 集約関数
REGR_INTERCEPT
independent_variable_expression
回帰に対する独立変数。独立変数とは、他の変数の動作をテストするためにユーザー
制御により変化する、何らかの処理です。
この式に順序付き分析関数や集約関数を含めることはできません。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
定義
切片とは、サンプルの非 NULL データ対を通して得られる回帰直線が、グラフの y
軸と交差する点のことです。
変数上の線形回帰のプロットは、独立変数の変更時の従属変数の動作を予測するた
めに使用されます。
この計算は、変数間の線形的な関連を前提とすることに注意する必要があります。
独立変数と従属変数の間に、強い非線形の関連がある場合は、そのような変数の対
の間で単純な線形回帰を計算すると、その関連は反映されません。
独立変数と従属変数
独立変数とは、他の変数の動作をテストするためにユーザー制御により変化する、
何らかの処理です。
従属変数は、処理に対する応答として測定されるものです。
たとえば、ある品目の販売を拡大するために、さまざまなプロモーションの効果を
テストしたい場合があります。
この場合、プロモーションが独立変数で、品目の販売数が個別のプロモーションの
結果として従属変数になります。
線形回帰の切片の値は、分析用に選択された品目のプロモーションを何も行なわな
い場合の販売数の予想値になります。
プロット用の軸の設定
プロット用にデータをエクスポートする場合、従属変数として y 軸(縦座標)、独立
変数として x 軸(横座標)を定義します。
他の関数との組み合わせ
REGR_INTERCEPT は、SELECT リスト、QUALIFY 句、または ORDER BY 句の中で、
順序付けられた任意の分析関数と組み合わせることができます。順序付き分析関数
の詳細は、ウィンドウ集約関数を参照してください。
SQL 関数、演算子、式および述部
51
第 2 章 集約関数
REGR_INTERCEPT
REGR_INTERCEPT は、同じ SELECT リスト、QUALIFY 句、または ORDER BY 句の
中の集約関数と組み合わせることはできません。
計算
計算に使用される非 NULL のデータ点の対がデータに 2 つ未満しかない場合は、
REGR_INTERCEPT は NULL を戻します。
ゼロで割ると、エラーではなく NULL になります。
結果のタイプと属性
REGR_INTERCEPT(y, x)のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ
書式
タイトル
REAL
REAL データ タイプのデフォルト書式
REGR_INTERCEPT(y,x)
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの間
でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行な
います。
•
•
•
•
数値
文字
DATE
間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
REGR_INTERCEPT を含め、システム演算子および関数用の UDT の暗黙タイプ変換
は、ANSI SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制
御レコードの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。
詳細は、<ユーティリティ 、B035-1102>を参照してください。
REGR_INTERCEPT ウィンドウ関数
グループ、累計、または移動を計算する REGR_INTERCEPT ウィンドウ関数について
は、ウィンドウ集約関数を参照してください。
例: NbrSold および SalesPrice の回帰直線の切片を返す
この例では、次の HomeSales テーブルのデータを使用します。
52
SalesPrice
NbrSold
Area
160000
126
358711030
180000
103
358711030
SQL 関数、演算子、式および述部
第 2 章 集約関数
REGR_R2
SalesPrice
NbrSold
Area
200000
82
358711030
220000
75
358711030
240000
82
358711030
260000
40
358711030
280000
20
358711030
次の問合わせは、358711030 の Area で SalesPrice が 160000~280000 の部分に
おける、NbrSold と SalesPrice の回帰直線の切片を戻します。
SELECT CAST (REGR_INTERCEPT(NbrSold,SalesPrice) AS DECIMAL (5,1))
FROM HomeSales
WHERE area = 358711030
AND SalesPrice BETWEEN 160000 AND 280000;
結果は以下のようになります。
REGR_INTERCEPT(NbrSold,SalesPrice)
---------------------------------249.9
関連トピック
詳細は、以下を参照してください。
• データ タイプのデフォルトの書式、および書式における書式設定文字について
の説明は、< SQL データ型とリテラル、B035-1143>の「データ タイプの書式お
よび書式句」を参照してください。
• UDT の暗黙型変換の詳細は、概要を参照してください。
• グループ、累計、または移動を計算する REGR_INTERCEPT ウィンドウ関数につ
いては、ウィンドウ集約関数を参照してください。
REGR_R2
目的
従属および独立変数引数のすべての非 NULL データ ペアの決定係数を戻します。
構文
REGR_R2
SQL 関数、演算子、式および述部
( dependent_variable_expression, independent_variable_expression )
53
第 2 章 集約関数
REGR_R2
構文要素
dependent_variable_expression
回帰に対する従属変数。従属変数は、処理に対する応答として測定されるものです。
この式に順序付き分析関数や集約関数を含めることはできません。
independent_variable_expression
回帰に対する独立変数。独立変数とは、他の変数の動作をテストするためにユーザー
制御により変化する、何らかの処理です。
この式に順序付き分析関数や集約関数を含めることはできません。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
プロット用の軸の設定
プロット用にデータをエクスポートする場合、従属変数として y 軸(縦座標)、独立変
数として x 軸(横座標)を定義します。
他の関数との組み合わせ
REGR_R2 は、SELECT リスト、QUALIFY 句、または ORDER BY 句の中で、順序付け
られた任意の分析関数と組み合わせることができます。順序付き分析関数の詳細は、
ウィンドウ集約関数を参照してください。
REGR_R2 は、同じ SELECT リスト、QUALIFY 句、または ORDER BY 句の中の集約
関数と組み合わせることはできません。
計算
計算に使用される非 NULL データ点の対がデータに 2 つ未満しかない場合は、
REGR_SXY は NULL を戻します。
ゼロで割ると、エラーではなく NULL になります。
結果のタイプと属性
REGR_R2(y, x)のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ: REAL
• オペランドが文字である場合、書式は FLOAT のデフォルトの書式です。
• オペランドが数値、日付、または間隔である場合、書式は y と同じ書式です。
• オペランドが UDT である場合、書式は UDT の暗黙キャスト先のデータ タイプの
書式です。
54
SQL 関数、演算子、式および述部
第 2 章 集約関数
REGR_R2
データ タイプのデフォルトの書式、および書式における書式設定文字についての説
明は、< SQL データ型とリテラル、B035-1143>の「データ タイプの書式および書
式句」を参照してください。
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの
間でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行
ないます。
• 数値
• 文字
• DATE
• 間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
REGR_R2 を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、ANSI
SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レコー
ドの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳細
は、<ユーティリティ 、B035-1102>を参照してください。
REGR_R2 ウィンドウ関数
グループ、累計、または移動を計算する REGR_R2 ウィンドウ関数については、ウィ
ンドウ集約関数を参照してください。
例: height と weight の決定係数を返す
この例は、次の regrtbl データに基づいています。NULL は QUESTION MARK によっ
て示されています。
c1
-1
2
3
4
5
6
7
8
9
10
11
12
height
-----60
62
64
66
68
70
72
74
76
76
?
?
weight
-----84
95
140
155
119
175
145
197
150
?
150
?
次の SELECT 文は、weight と height がどちらも null でない部分における、weight
と height の決定係数を戻します。
SELECT CAST(REGR_R2(weight,height) AS DECIMAL(4,2))
FROM regrtbl;
SQL 関数、演算子、式および述部
55
第 2 章 集約関数
REGR_SLOPE
REGR_R2(weight,height)
---------------------.58
関連トピック
詳細は、以下を参照してください。
• データ タイプのデフォルトの書式、および書式における書式設定文字についての
説明は、< SQL データ型とリテラル、B035-1143>の「データ タイプの書式およ
び書式句」を参照してください。
• UDT の暗黙タイプ変換の詳細は、概要を参照してください。
• グループ、累計、または移動を計算する REGR_R2 ウィンドウ関数については、
ウィンドウ集約関数を参照してください。
REGR_SLOPE
目的
すべての非 NULL データ対を通して、従属および独立変数引数の一変量の線形回帰
直線の傾きを戻します。
構文
REGR_SLOPE
( dependent_variable_expression, independent_variable_expression )
構文要素
dependent_variable_expression
回帰に対する従属変数。従属変数は、処理に対する応答として測定されるものです。
この式に順序付き分析関数や集約関数を含めることはできません。
independent_variable_expression
回帰に対する独立変数。独立変数とは、他の変数の動作をテストするためにユーザー
制御により変化する、何らかの処理です。
この式に順序付き分析関数や集約関数を含めることはできません。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
56
SQL 関数、演算子、式および述部
第 2 章 集約関数
REGR_SLOPE
定義
最適線形回帰の傾きは、1 つの独立変数対従属変数の回帰の変化率の尺度です。
変数上の線形回帰のプロットは、独立変数の変更時の従属変数の動作を予測するた
めに使用されます。
この計算は、変数間の線形的な関連を前提とすることに注意する必要があります。
独立変数と従属変数の間に、強い非線形の関連がある場合は、そのような変数の対
の間で単純な線形回帰を計算すると、その関連は反映されません。
独立変数と従属変数
独立変数とは、他の変数の動作をテストするためにユーザー制御により変化する、
何らかの処理です。
従属変数は、処理に対する応答として測定されるものです。
たとえば、ある品目の販売を拡大するために、さまざまなプロモーションの効果を
テストしたい場合があります。
この場合、プロモーションが独立変数で、品目の販売数が個別のプロモーションの
結果として従属変数になります。
プロット用の軸の設定
プロット用にデータをエクスポートする場合、従属変数として y 軸(縦座標)、独立
変数として x 軸(横座標)を定義します。
他の関数との組み合わせ
REGR_SLOPE は、SELECT リスト、QUALIFY 句、または ORDER BY 句の中で、順序
付き分析関数と組み合わせることができます。 順序付き分析関数の詳細は、ウィン
ドウ集約関数を参照してください。
REGR_SLOPE は、同じ SELECT リスト、QUALIFY 句、または ORDER BY 句の中の
集約関数と組み合わせることはできません。
計算
計算に使用される非 NULL のデータ点の対がデータに 2 つ未満しかない場合は、
REGR_SLOPE は NULL を戻します。
ゼロで割ると、エラーではなく NULL になります。
結果のタイプと属性
REGR_SLOPE(y, x)のデータ タイプ、書式、およびタイトルは次のとおりです。
SQL 関数、演算子、式および述部
57
第 2 章 集約関数
REGR_SLOPE
データ タイプ
書式
タイトル
REAL
REAL データ タイプのデフォルト書式
REGR_SLOPE(y,x)
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの間
でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行な
います。
•
•
•
•
数値
文字
DATE
間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
REGR_SLOPE を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、
ANSI SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レ
コードの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳
細は、<ユーティリティ 、B035-1102>を参照してください。
REGR_SLOPE ウィンドウ関数
グループ、累計、または移動を計算する REGR_SLOPE ウィンドウ関数については、
ウィンドウ集約関数を参照してください。
例: NbrSold および SalesPrice の回帰直線の傾きを返す
この例では、次の HomeSales テーブルのデータを使用します。
SalesPrice
NbrSold
Area
160000
126
358711030
180000
103
358711030
200000
82
358711030
220000
75
358711030
240000
82
358711030
260000
40
358711030
280000
20
358711030
次の問合わせは、358711030 の Area で SalesPrice が 160000~280000 の部分に
おける、NbrSold と SalesPrice の回帰直線の傾きを戻します。
SELECT CAST (REGR_SLOPE(NbrSold,SalesPrice) AS FLOAT)
FROM HomeSales
WHERE area = 358711030
AND SalesPrice BETWEEN 160000 AND 280000;
58
SQL 関数、演算子、式および述部
第 2 章 集約関数
REGR_SXX
結果は以下のようになります。
REGR_SLOPE(NbrSold,SalesPrice)
------------------------------7.92857142857143E-004
関連トピック
詳細は、以下を参照してください。
• データ タイプのデフォルトの書式、および書式における書式設定文字について
は、< SQL データ型とリテラル、B035-1143>の「データ タイプの書式および書
式句」を参照してください。
• UDT の暗黙タイプ変換の詳細は、概要を参照してください。
• グループ、累計、または移動を計算する REGR_SLOPE ウィンドウ関数について
は、ウィンドウ集約関数を参照してください。
REGR_SXX
目的
従属および独立変数引数のすべての非 null データ ペアの
independent_variable_expression の 2 乗の合計を戻します。
構文
REGR_SXX
( dependent_variable_expression, independent_variable_expression )
構文要素
dependent_variable_expression
回帰に対する従属変数。従属変数は、処理に対する応答として測定されるものです。
この式に順序付き分析関数や集約関数を含めることはできません。
independent_variable_expression
回帰に対する独立変数。独立変数とは、他の変数の動作をテストするためにユーザー
制御により変化する、何らかの処理です。
この式に順序付き分析関数や集約関数を含めることはできません。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
SQL 関数、演算子、式および述部
59
第 2 章 集約関数
REGR_SXX
プロット用の軸の設定
プロット用にデータをエクスポートする場合、従属変数として y 軸(縦座標)、独立変
数として x 軸(横座標)を定義します。
他の関数との組み合わせ
REGR_SXX は、SELECT リスト、QUALIFY 句、または ORDER BY 句の中で、順序付
けられた任意の分析関数と組み合わせることができます。順序付き分析関数の詳細
は、ウィンドウ集約関数を参照してください。
REGR_SXX は、同じ SELECT リスト、QUALIFY 句、または ORDER BY 句の中の集約
関数と組み合わせることはできません。
計算
計算に使用される非 NULL のデータ点の対がデータに 2 つ未満しかない場合は、
REGR_SXX は NULL を戻します。
ゼロで割ると、エラーではなく NULL になります。
結果のタイプと属性
REGR_SXX(y, x)のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ: REAL
• オペランドが文字である場合、書式は FLOAT のデフォルトの書式です。
• オペランドが数値、日付、または間隔である場合、書式は y と同じ書式です。
• オペランドが UDT である場合、書式は UDT の暗黙キャスト先のデータ タイプの
書式です。
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの間
でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行な
います。
• 数値
• 文字
• DATE
• 間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
REGR_SXX を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、ANSI
SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レコード
の DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳細は、
<ユーティリティ 、B035-1102>を参照してください。
60
SQL 関数、演算子、式および述部
第 2 章 集約関数
REGR_SXX
REGR_SXX ウィンドウ関数
グループ、累計、または移動を計算する REGR_SXX ウィンドウ関数については、
ウィンドウ集約関数を参照してください。
例: height の 2 乗の合計を返す
この例は、次の regrtbl データに基づいています。Null は?によって示されています。
c1
-1
2
3
4
5
6
7
8
9
10
11
12
height
-----60
62
64
66
68
70
72
74
76
76
?
?
weight
-----84
95
140
155
119
175
145
197
150
?
150
?
次の SELECT 文は、weight と height がどちらも null でない部分における、height
の 2 乗の合計を戻します。
SELECT REGR_SXX(weight,height)
FROM regrtbl;
Regr_Sxx(weight,height)
----------------------240
関連トピック
詳細は、以下を参照してください。
• データ タイプのデフォルトの書式の詳細については、< SQL データ型とリテラ
ル、B035-1143>の「データ タイプの書式および書式句」を参照してください。
• UDT の暗黙タイプ変換の詳細は、概要を参照してください。
• グループ、累計、または移動を計算する REGR_SXX ウィンドウ関数については、
ウィンドウ集約関数を参照してください。
SQL 関数、演算子、式および述部
61
第 2 章 集約関数
REGR_SXY
REGR_SXY
目的
従属および独立変数引数のすべての非 null データ ペアの
independent_variable_expression と dependent_variable_expression の積の合計を
戻します。
構文
REGR_SXY
( dependent_variable_expression, independent_variable_expression )
構文要素
dependent_variable_expression
回帰に対する従属変数。従属変数は、処理に対する応答として測定されるものです。
この式に順序付き分析関数や集約関数を含めることはできません。
independent_variable_expression
回帰に対する独立変数。独立変数とは、他の変数の動作をテストするためにユーザー
制御により変化する、何らかの処理です。
この式に順序付き分析関数や集約関数を含めることはできません。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
プロット用の軸の設定
プロット用にデータをエクスポートする場合、従属変数として y 軸(縦座標)、独立変
数として x 軸(横座標)を定義します。
他の関数との組み合わせ
REGR_SXY は、SELECT リスト、QUALIFY 句、または ORDER BY 句の中で、順序付
けられた任意の分析関数と組み合わせることができます。順序付き分析関数の詳細
は、ウィンドウ集約関数を参照してください。
REGR_SXY は、同じ SELECT リスト、QUALIFY 句、または ORDER BY 句の中の集約
関数と組み合わせることはできません。
計算
計算に使用される非 NULL のデータ点の対がデータに 2 つ未満しかない場合は、
REGR_SXY は NULL を戻します。
62
SQL 関数、演算子、式および述部
第 2 章 集約関数
REGR_SXY
ゼロで割ると、エラーではなく NULL になります。
結果のタイプと属性
REGR_SXY(y, x)のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ: REAL
• オペランドが文字である場合、書式は FLOAT のデフォルトの書式です。
• オペランドが数値、日付、または間隔である場合、書式は y と同じ書式です。
• オペランドが UDT である場合、書式は UDT の暗黙キャスト先のデータ タイプの
書式です。
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの
間でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行
ないます。
• 数値
• 文字
• DATE
• 間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
REGR_SXY を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、ANSI
SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レコー
ドの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳細
は、<ユーティリティ 、B035-1102>を参照してください。
UDT の暗黙タイプ変換の詳細は、「データ型の変換」を参照してください。
REGR_SXY ウィンドウ関数
グループ、累計、または移動を計算する REGR_SXY ウィンドウ関数については、
ウィンドウ集約関数を参照してください。
例: height と weight の積の合計を返す
この例は、次の regrtbl データに基づいています。Null は?によって示されています。
c1
-1
2
3
4
5
6
7
8
height
-----60
62
64
66
68
70
72
74
SQL 関数、演算子、式および述部
weight
-----84
95
140
155
119
175
145
197
63
第 2 章 集約関数
REGR_SYY
9
10
11
12
76
76
?
?
150
?
150
?
次の SELECT 文は、weight と height がどちらも null でない部分における、weight
と height の積の合計を戻します。
SELECT REGR_SXY(weight,height)
FROM regrtbl;
Regr_Sxy(weight,height)
----------------------1200
関連トピック
詳細は、以下を参照してください。
• データ タイプのデフォルトの書式の詳細については、< SQL データ型とリテラ
ル、B035-1143>の「データ タイプの書式および書式句」を参照してください。
• UDT の暗黙タイプ変換の詳細は、概要を参照してください。
REGR_SYY
目的
従属および独立変数引数のすべての非 null データ ペアの
dependent_variable_expression の 2 乗の合計を戻します。
構文
REGR_SYY
( dependent_variable_expression, independent_variable_expression )
構文要素
dependent_variable_expression
回帰に対する従属変数。従属変数は、処理に対する応答として測定されるものです。
この式に順序付き分析関数や集約関数を含めることはできません。
independent_variable_expression
回帰に対する独立変数。独立変数とは、他の変数の動作をテストするためにユーザー
制御により変化する、何らかの処理です。
この式に順序付き分析関数や集約関数を含めることはできません。
64
SQL 関数、演算子、式および述部
第 2 章 集約関数
REGR_SYY
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
プロット用の軸の設定
プロット用にデータをエクスポートする場合、従属変数として y 軸(縦座標)、独立
変数として x 軸(横座標)を定義します。
他の関数との組み合わせ
REGR_SYY は、SELECT リスト、QUALIFY 句、または ORDER BY 句の中で、順序付
けられた任意の分析関数と組み合わせることができます。順序付き分析関数の詳細
は、ウィンドウ集約関数を参照してください。
REGR_SYY は、同じ SELECT リスト、QUALIFY 句、または ORDER BY 句の中の集約
関数と組み合わせることはできません。
計算
計算に使用される非 NULL のデータ点の対がデータに 2 つ未満しかない場合は、
REGR_INTERCEPT は NULL を戻します。
ゼロで割ると、エラーではなく NULL になります。
結果のタイプと属性
REGR_SYY(y, x)のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ: REAL
• オペランドが文字である場合、書式は FLOAT のデフォルトの書式です。
• オペランドが数値、日付、または間隔である場合、書式は y と同じ書式です。
• オペランドが UDT である場合、書式は UDT の暗黙キャスト先のデータ タイプの
書式です。
データ タイプのデフォルトの書式の詳細については、< SQL データ型とリテラル、
B035-1143>の「データ タイプの書式および書式句」を参照してください。
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの
間でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行
ないます。
• 数値
• 文字
• DATE
• 間隔
SQL 関数、演算子、式および述部
65
第 2 章 集約関数
SKEW
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
REGR_SYY を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、ANSI
SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レコード
の DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳細は、
<ユーティリティ 、B035-1102>を参照してください。
REGR_SYY ウィンドウ関数
グループ、累計、または移動を計算する REGR_SYY ウィンドウ関数については、ウィ
ンドウ集約関数を参照してください。
例: weight の 2 乗の合計を返す
この例は、次の regrtbl データに基づいています。Null は?によって示されています。
c1
-1
2
3
4
5
6
7
8
9
10
11
12
height
-----60
62
64
66
68
70
72
74
76
76
?
?
weight
-----84
95
140
155
119
175
145
197
150
?
150
?
次の SELECT 文は、height と weight がどちらも null でない部分における、weight
の 2 乗の合計を戻します。
SELECT REGR_SYY(weight,height)
FROM regrtbl;
Regr_Syy(weight,height)
----------------------10426
SKEW
目的
value_expression の分布のひずみ(skewness)を戻します。
66
SQL 関数、演算子、式および述部
第 2 章 集約関数
SKEW
構文
SKEW
value_expression )
(
DISTINCT
ALL
構文要素
ALL
null でない value_expression のすべての値が、重複も含めて、この計算に含まれま
す。
DISTINCT
value_expression によって指定された null と重複値がグループの計算から除外され
ます。
value_expression
値の分布のひずみを計算するリテラルまたは列式。
この式に順序付き分析関数や集約関数を含めることはできません。
定義
ひずみ(skewness)は分布の第 3 モーメントです。これは、正規(ガウス)分布と比較
した場合の、平均に関する分布の非対称性の尺度です。
正規分布のひずみはゼロです。
ひずみの値が正の数の場合は、分布が正方向に非対称に伸びており、負の数の場合
は分布が負方向に非対称に伸びていることを示します。
結果のタイプと属性
SKEW(x)のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ
書式
タイトル
REAL
REAL データ タイプのデフォルト書式
SKEW(x)
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの
間でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行
ないます。
• 数値
• 文字
• DATE
• 間隔
SQL 関数、演算子、式および述部
67
第 2 章 集約関数
STDDEV_POP
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
SKEW を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、ANSI SQL
規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レコードの
DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳細は、<
ユーティリティ 、B035-1102>を参照してください。
計算
SKEW の計算の公式は次のように定義されます。
説明:
変数
内容
x
value_expression
Null 結果になる条件
次の条件の結果は、null になります。
• 計算に使用されるデータに、非 NULL のデータ点が 3 個未満しかない。
• STDDEV_SAMP(x) = 0
• 0 による除算
関連トピック
詳細は、以下を参照してください。
• SQL データ型とリテラル、B035-1143
• 概要
STDDEV_POP
目的
value_expression の中の非 null のデータ点に対して、母集団の標準偏差を戻します。
構文
STDDEV_POP
value_expression )
(
DISTINCT
ALL
68
SQL 関数、演算子、式および述部
第 2 章 集約関数
STDDEV_POP
構文要素
ALL
value_expression によって指定された null でないすべての値が、重複も含めて、計
算に含まれます。これは、デフォルトです。
DISTINCT
value_expression の重複を計算から除外します。
value_expression
母集団の標準偏差を計算する数値リテラルまたは列式。
この式に順序付き分析関数や集約関数を含めることはできません。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
定義
標準偏差は分布の第 2 のモーメントです。母集団について、その母集団の平均から
のばらつきの尺度となります。
処理中のデータ点が完全な母集団でない場合は、STDDEV_POP を使用しないでくだ
さい。
他の関数との組み合わせ
STDDEV_POP は、SELECT リスト、QUALIFY 句、または ORDER BY 句の中で、順
序付き分析関数と組み合わせることができます。 順序付き分析関数の詳細は、ウィ
ンドウ集約関数を参照してください。
STDDEV_POP は、同じ SELECT リスト、QUALIFY 句、または ORDER BY 句の中の
集約関数と組み合わせることはできません。
GROUP BY がレポートの区切りに与える影響
STDDEV_POP は、SELECT 文に GROUP BY 句があるかどうかによって、動作が異な
ります。
問合わせ
STDDEV_POP の報告対象
GROUP BY 句を指定する場合
個々のグループ
GROUP BY 句を指定しない場合
サンプル内のすべての行
SQL 関数、演算子、式および述部
69
第 2 章 集約関数
STDDEV_POP
母集団の標準偏差の測定
データが、変数の母集団全体の標本を表わすにすぎない場合は、STDDEV_SAMP 関
数を使用してください。詳細については、「STDDEV_SAMP」を参照してください。
標本サイズが大きくなると、STDDEV_SAMP の値と STDDEV_POP は同じ数値に近づ
いていきます。しかし、変数に関してデータが母集団全体を成しているという絶対
的な確信がない限り、より控えめな STDDEV_SAMP 計算を常に使用するようにして
ください。
計算
母集団に非 NULL のデータ点がない場合は、STDDEV_POP は NULL を戻します。
ゼロで割ると、エラーではなく NULL になります。
結果のタイプと属性
STDDEV_POP(x)のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ: REAL
• オペランドが文字である場合、書式は FLOAT のデフォルトの書式です。
• オペランドが数値、日付、または間隔である場合、書式は x と同じ書式です。
• オペランドが UDT である場合、書式は UDT の暗黙キャスト先のデータ タイプの
書式です。
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの間
でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行な
います。
• 数値
• 文字
• DATE
• 間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
STDDEV_POP を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、
ANSI SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レ
コードの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳
細は、<ユーティリティ 、B035-1102>を参照してください。
STDDEV_POP ウィンドウ関数
グループ、累計、または移動を計算する STDDEV_POP ウィンドウ関数については、
ウィンドウ集約関数を参照してください。
70
SQL 関数、演算子、式および述部
第 2 章 集約関数
STDDEV_SAMP
関連トピック
詳細は、以下を参照してください。
• SQL データ型とリテラル、B035-1143
• 概要
• ウィンドウ集約関数
STDDEV_SAMP
目的
value_expression の中の非 null のデータ点に対して、標本の標準偏差を戻します。
構文
STDDEV_SAMP
value_expression )
(
DISTINCT
ALL
構文要素
ALL
null でない value_expression のすべての値が、重複も含めて、この計算に含まれま
す。
DISTINCT
value_expression の重複を計算から除外します。
value_expression
母集団の標本の標準偏差を計算する数値リテラルまたは列式。
この式に順序付き分析関数や集約関数を含めることはできません。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
定義
標準偏差は分布の第 2 のモーメントです。標本について、その標本の平均からのば
らつきの尺度となります。この計算は、算出値に与える他者の影響を最小限にする
ため、母集団の分散に対して控えめなものとなります。
SQL 関数、演算子、式および述部
71
第 2 章 集約関数
STDDEV_SAMP
計算
ゼロで割ると、エラーではなく NULL になります。
計算に使用される非 NULL のデータ点の対が標本に 2 つ未満しかない場合は、
STDDEV_SAMP は NULL を戻します。
結果のタイプと属性
STDDEV_SAMP(x)のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ:REAL
• オペランドが文字である場合、書式は FLOAT のデフォルトの書式です。
• オペランドが数値、日付、または間隔である場合、書式は x と同じ書式です。
• オペランドが UDT である場合、書式は UDT の暗黙キャスト先のデータ タイプの
書式です。
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの間
でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行な
います。
• 数値
• 文字
• DATE
• 間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
STDDEV_SAMP を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、
ANSI SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レ
コードの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳
細は、<ユーティリティ 、B035-1102>を参照してください。
他の関数との組み合わせ
STDDEV_SAMP は、SELECT リスト、QUALIFY 句、または ORDER BY 句の中で、順
序付き分析関数と組み合わせることができます。 順序付き分析関数の詳細は、ウィ
ンドウ集約関数を参照してください。
STDDEV_SAMP は、同じ SELECT リスト、QUALIFY 句、または ORDER BY 句の中の
集約関数と組み合わせることはできません。
GROUP BY がレポートの区切りに与える影響
GROUP BY 句は STDDEV_SAMP 操作に影響を与えます。
72
SQL 関数、演算子、式および述部
第 2 章 集約関数
SUM
問合わせ
STDDEV_SAMP の報告対象
GROUP BY 句を指定する場合
個々のグループ
GROUP BY 句を指定しない場合
サンプル内のすべての行
母集団の標準偏差の測定
データが、変数の母集団全体を表わしている場合は、STDDEV_POP 関数を使用して
ください。詳細は、「STDDEV_POP」を参照してください。
標本サイズが大きくなると、STDDEV_SAMP の値と STDDEV_POP は同じ数値に近
づいていきます。しかし、変数に関してデータが母集団全体を成しているという絶
対的な確信がない限り、より控えめな STDDEV_SAMP 計算を使用するようにしてく
ださい。
STDDEV_SAMP ウィンドウ関数
グループ、累計、または移動を計算する STDDEV_SAMP ウィンドウ関数について
は、ウィンドウ集約関数を参照してください。
関連トピック
詳細は、以下を参照してください。
• SQL データ型とリテラル、B035-1143
• 概要
• ウィンドウ集約関数
SUM
目的
value_expression の算術合計である列の値を返します。
構文
SUM
(
value_expression )
DISTINCT
ALL
構文要素
ALL
null でない value_expression のすべての値が、重複も含めて、この計算に含まれま
す。
SQL 関数、演算子、式および述部
73
第 2 章 集約関数
SUM
DISTINCT
value_expression によって指定された null でない値および重複を計算から除外します。
value_expression
合計が計算されるリテラルまたは列式。
この式に順序付き分析関数や集約関数を含めることはできません。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
結果のタイプと属性
次の表に、SUM(x)の結果のデフォルト属性をリストします。
データ タイプとオ 結果のデータ タイプ
ペランド
書式
BYTEINT または
SMALLINT
オペランドと同じ
INTEGER データ Sum(x)
タイプのデフォル
ト書式
文字
オペランドと同じ
FLOAT のデフォ
ルト書式
UDT
オペランドと同じ
UDT の暗黙キャ
スト先のデータ タ
イプの書式
DECIMAL(n,m)
DECIMAL(p,m)。このとき、p は次の規則
によって決定されます:
オペランドのデー Sum(x)
タ タイプのデフォ
ルトの書式
DBSControl 内の MaxDecimal が 0 または
15 である場合
• n ≤ 15 の場合、p = 15。
• 15 < n ≤ 18 の場合、 p = 18。
• n > 18 の場合、p = 38。
タイ
トル
DBSCControl 内の MaxDecimal が 18 であ
る場合
• n ≤ 18 の場合、p = 18。
• n > 18 の場合、p = 38。
DBSControl の MaxDecimal が 38 で n が
任意の値である場合、p = 38。
UDT、
SMALLINT、
BYTEINT、
74
オペランドと同じ
オペランドのデー
タ タイプのデフォ
ルトの書式
SQL 関数、演算子、式および述部
第 2 章 集約関数
SUM
データ タイプとオ 結果のデータ タイプ
ペランド
書式
タイ
トル
DECIMAL、または
文字のいずれでも
ない
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの
間でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行
ないます。
• 数値
• 文字
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
SUM を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、ANSI SQL
規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レコードの
DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳細は、<
ユーティリティ 、B035-1102>を参照してください。
UDT の暗黙タイプ変換の詳細は、「データ型の変換」を参照してください。
使用上の注意
value_expression が列参照である場合、その列は関数によって得られたビュー列で
あってはなりません。
SUM は数値データに対してのみ有効です。
結果の計算には NULL は含められません。詳細については、<SQL 基礎、
B035-1141>の「Null の操作」、および「集約と Null」を参照してください。
デフォルトの出力形式によって、SUM 関数を使用した結果、数値のあふれやデータ
の喪失が起こる場合があります。それらが発生した場合は、データ タイプの宣言を
使用してデフォルトをオーバーライドすることができます。
たとえば、QUANTITY が INTEGER 値の多数の列から成る場合は、SUM 関数に対し
て次のようなデータ タイプ宣言を指定する必要があるかもしれません。
SUM(QUANTITY(FLOAT))
SELECT Sum の結果オーバーフローが発生する可能性
SELECT Sum の結果オーバーフローが発生する可能性
この関数を使用する場合に、データ型とフォーマットが同期していないと、結果に
よりオーバーフローが発生することがあります。列が以下のように定義されている
場合:
Salary Decimal(15,2) Format ‘$ZZZ,ZZ9.99’
SQL 関数、演算子、式および述部
75
第 2 章 集約関数
VAR_POP
以下の問合わせを実行します。
SELECT SUM (Salary) FROM Employee;
小数オペランドおよび書式が一致していないため、オーバーフローが発生します。
オーバーフローが発生する可能性を回避するには、結果のデータ タイプでの、その
小数の合計が収まる十分な大きさで、小数の合計の書式を明示的に指定します。
SELECT Sum(Salary) (format ‘$Z,ZZZ,ZZZ,ZZ9.99) FROM Employee;
例
例: 売掛金
30 日以上前に請求書を発行してきたすべてのベンダーに支払う必要がある現金の額
を知る必要があるとします。
SELECT SUM(Invoice)
FROM AcctsRec
WHERE (CURRENT_DATE - InvDate) >= 30;
例: 在庫の額面値
在庫のすべての商品の額面の合計を知る必要があるとします。
SELECT SUM(QUANTITY * Price)
FROM Inventory;
Sum((QUANTITY * Price))
----------------------38,525,151.91
関連トピック
詳細は、以下を参照してください。
• 書式における書式設定文字についての説明は、<SQL データ タイプおよびリテラ
ル>の「概要」を参照してください。
• 累計、グループ合計、および移動合計を戻す SUM 関数については、ウィンドウ
集約関数を参照してください。
VAR_POP
目的
value_expression 内のデータ点に対して母集団分散を戻します。
76
SQL 関数、演算子、式および述部
第 2 章 集約関数
VAR_POP
構文
VAR_POP
value_expression )
(
DISTINCT
ALL
構文要素
ALL
null でない value_expression のすべての値が、重複も含めて、この計算に含まれま
す。
DISTINCT
value_expression の重複を計算から除外します。
value_expression
母集団の分散を計算する数値リテラルまたは列式。
この式に順序付き分析関数や集約関数を含めることはできません。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
定義
母集団の分散は、その母集団の平均からのばらつきの尺度となります。
処理中のデータ点が完全な母集団でない場合は、VAR_POP を使用しないでください。
計算
母集団に非 NULL のデータ点がない場合、VAR_POP は NULL を戻します。
ゼロで割ると、エラーではなく NULL になります。
結果のタイプと属性
VAR_POP(x)のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ: REAL
• オペランドが文字である場合、書式は FLOAT のデフォルトの書式です。
• オペランドが数値、日付、または間隔である場合、書式は x と同じ書式です。
• オペランドが UDT である場合、書式は UDT の暗黙キャスト先のデータ タイプの
書式です。
データ タイプのデフォルトの書式の詳細については、< SQL データ型とリテラル、
B035-1143>の「データ タイプの書式および書式句」を参照してください。
SQL 関数、演算子、式および述部
77
第 2 章 集約関数
VAR_POP
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの間
でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行な
います。
•
•
•
•
数値
文字
DATE
間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
VAR_POP を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、ANSI
SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レコード
の DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳細は、
<ユーティリティ 、B035-1102>を参照してください。
他の関数との組み合わせ
VAR_POP は、SELECT リスト、QUALIFY 句、または ORDER BY 句の中で、順序付
き分析関数と組み合わせることができます。
VAR_POP は、同じ SELECT リスト、QUALIFY 句、または ORDER BY 句の中の集約
関数と組み合わせることはできません。
GROUP BY がレポートの区切りに与える影響
GROUP BY 句は VAR_POP 操作に影響を与えます。
問合わせ
VAR_POP の報告対象
GROUP BY 句を指定する場合
個々のグループ
GROUP BY 句を指定しない場合
サンプル内のすべての行
母集団の標準偏差の測定
データが、変数の母集団全体の標本を表わすにすぎない場合は、VAR_SAMP 関数を
使用してください。詳細については、「VAR_SAMP」を参照してください。
標本サイズが大きくなると、VAR_SAMP の値と VAR_POP は同じ数値に近づいてい
きます。しかし、変数に関してデータが母集団全体を成しているという絶対的な確
信がない限り、より控えめな VAR_SAMP 計算を常に使用するようにしてください。
関連トピック
詳細は、以下を参照してください。
• ウィンドウ集約関数
78
SQL 関数、演算子、式および述部
第 2 章 集約関数
VAR_SAMP
•
•
•
•
概要
SQL データ定義言語 - 構文規則および例、B035-1144
UDT の暗黙タイプ変換の詳細は、「データ型の変換」を参照してください。
順序付き分析関数の詳細は、「順序付き分析関数/ウィンドウ集約関数」を参照
してください。
• グループ、累計、または移動を計算する VAR_POP ウィンドウ関数については、
「ウィンドウ集約関数」を参照してください。
VAR_SAMP
目的
value_expression 内のデータ点の標本分散を戻します。
構文
VAR_SAMP
value_expression )
(
DISTINCT
ALL
構文要素
ALL
null でない value_expression のすべての値が、重複も含めて、この計算に含まれま
す。
DISTINCT
value_expression の重複を計算から除外します。
value_expression
標本の分散を計算する数値リテラルまたは列式。
この式に順序付き分析関数や集約関数を含めることはできません。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
定義
標本の分散は、その標本の平均からのばらつきの尺度となります。それは標本標準
偏差の 2 乗です。
SQL 関数、演算子、式および述部
79
第 2 章 集約関数
VAR_SAMP
この計算は、算出値に与える他者の影響を最小限にするため、母集団の分散よりも
控えめなものとなります。
計算
計算に使用される標本に非 null データ点が 2 つ未満しかない場合、VAR_SAMP は
NULL を返します。
ゼロで割ると、エラーではなく NULL になります。
他の関数との組み合わせ
VAR_SAMP は、SELECT リスト、QUALIFY 句、または ORDER BY 句の中で、順序付
き分析関数と組み合わせることができます。
VAR_SAMP は、同じ SELECT リスト、QUALIFY 句、または ORDER BY 句の中の集
約関数と組み合わせることはできません。
GROUP BY がレポートの区切りに与える影響
VAR_SAMP は、SELECT 文に GROUP BY 句があるかどうかによって、動作が異なり
ます。
問合わせ
VAR_SAMP の報告対象
GROUP BY 句を指定する場合
個々のグループ
GROUP BY 句を指定しない場合
サンプル内のすべての行
母集団の分散の測定
データが、変数の母集団全体を表わしている場合は、VAR_POP 関数を使用してくだ
さい。
標本サイズが大きくなると、VAR_SAMP の値と VAR_POP は同じ数値に近づいてい
きます。しかし、変数に関してデータが母集団全体を成しているという絶対的な確
信がない限り、より控えめな VAR_SAMP 計算を常に使用するようにしてください。
結果のタイプと属性
VAR_SAMP のデータ タイプ、書式、およびタイトルは、次のとおりです。
データ タイプ: REAL
• オペランドが文字である場合、書式は FLOAT のデフォルトの書式です。
• オペランドが数値、日付、または間隔である場合、書式は x と同じ書式です。
• オペランドが UDT である場合、書式は UDT の暗黙キャスト先のデータ タイプの
書式です。
80
SQL 関数、演算子、式および述部
第 2 章 集約関数
VAR_SAMP
UDT のサポート
Teradata Database はデフォルトで、UDT と、以下のいずれかの事前定義タイプの
間でキャストを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行
ないます。
• 数値
• 文字
• DATE
• 間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。
VAR_SAMP を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、ANSI
SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レコー
ドの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。
関連トピック
詳細は、以下を参照してください。
• 順序付き分析関数の詳細は、「順序付き分析関数/ウィンドウ集約関数」を参照
してください。
• グループ、累計、または移動を計算する VAR_SAMP ウィンドウ関数については、
「順序付き分析関数/ウィンドウ集約関数」を参照してください。
• データが、変数の母集団全体を表わしている場合は、VAR_POP 関数を使用して
ください。詳細は、「VAR_POP」を参照してください。
• CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>
を参照してください。
• DisableUDTImplCastForSysFuncOp フィールドの詳細については、<ユーティリ
ティ、B035-1102>を参照してください。
• UDT の暗黙タイプ変換の詳細は、「データ型の変換」を参照してください。
SQL 関数、演算子、式および述部
81
第 2 章 集約関数
VAR_SAMP
82
SQL 関数、演算子、式および述部
第3章
算術演算子/関数、三角関数、双曲線関数
概要
この章では、SQL の算術演算子/関数、三角関数、双曲線関数について説明します。
Teradata SQL は、次の算術演算子をサポートします。
演算子
関数
**
べき乗算
これは、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
*
乗算
/
除算
MOD
モジュロ(剰余)
MOD は、除算における剰余を計算します。
例、60 MOD 7 = 4:これは、60 を 7 で割ります。商は 8、剰余は 4 です。結
果は、次のような被除数の符号になります。
-17 MOD 4 = -1
-17 MOD -4 = -1
17 MOD -4 = 1
17 MOD 4 = 1
これは、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
+
加算
-
減算
+
正符号(正数値)
-
負符号(負数値)
ANSI への準拠
MOD と**を除き、算術演算子は ANSI SQL:2011 準拠です。
算術演算子と LOB
算術演算子は BLOB または CLOB タイプをサポートしていません。
SQL 関数、演算子、式および述部
83
第 3 章 算術演算子/関数、三角関数、双曲線関数
2 項算術演算子の結果のデータ タイプ
算術演算子と UDT
Teradata Database はデフォルトで、UDT と、FLOAT または INTEGER などの事前定
義された数値データ タイプとの間でキャストを行なう暗黙 CAST を持つ UDT 引数に
対して、暗黙のタイプ変換を行ないます。
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。
算術演算子を含め、システム演算子および関数用の UDT の暗黙の型変換は、ANSI
SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レコード
の DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。
関連トピック
詳細は、以下を参照してください。
• DateTime および間隔データ型で許可されている算術演算子の詳細は、「算術演
算子および ANSI の DateTime と間隔のデータ型」を参照してください。
• PERIOD データ型で許可されている算術演算子の詳細は、「算術演算子」を参照
してください。
• CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>
を参照してください。
• DBS 制御レコードの DisableUDTImplCastForSysFuncOp フィールドの詳細につい
ては、<ユーティリティ 、B035-1102>を参照してください。
• UDT の暗黙タイプ変換の詳細は、「暗黙的な型の変換」を参照してください。
2 項算術演算子の結果のデータ タイプ
算術式の結果のデータ タイプは、2 つのオペランドのデータ タイプによって決まり
ます。オペランドは、操作が行なわれる前に結果の型に変換されます。
たとえば、INTEGER 値が FLOAT 値に加算される前に、INTEGER 値は結果のデータ
タイプである FLOAT に変換されます。
結果のデータ タイプ
2 項算術演算子の結果のデータ タイプを次の表に示します。
UDT オペランドが関与する 2 項算術演算の結果のデータ タイプは、UDT の暗黙キャ
スト先の事前定義データ タイプの場合の結果データ タイプと同じです。
日時および間隔データ タイプを使用したバイナリ算術操作の結果データ タイプの詳
細は、「算術演算子と結果タイプ」を参照してください。
左のオペランド
右のオペランド
任意のデータ タ
イプ
任意のデータ タイプ **
84
使用する演算子 結果のデータ タイプ
FLOAT
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
2 項算術演算子の結果のデータ タイプ
左のオペランド
右のオペランド
使用する演算子 結果のデータ タイプ
DATE
BYTEINT
SMALLINT
INTEGER
BIGINT
+-
BYTEINT
SMALLINT
INTEGER
* / MOD
BIGINT
* / MOD
DATE(続き)
DATE
日付の結果の値が DATE 型に許容されている
範囲内にないとき、エラーが報告されます。
その範囲とは、西暦の 1 年から 9999 年ま
での任意の日付です。
INTEGER
DATE のこれらの演算はエラーを報告しませ
んが、結果は、通常意味がありません。
BIGINT
DATE のこれらの演算はエラーを報告しませ
んが、結果は、通常意味がありません。
DECIMAL(k,j)
+-
DATE
DATE のこれらの演算はエラーを報告しませ
んが、結果は、通常意味がありません。
日付の値に対する加算または減算の場合、
小数の小数点以下は切り捨てられます。
日付の結果の値が DATE 型に許容されている
範囲内にないとき、エラーが報告されます。
その範囲とは、西暦の 1 年から 9999 年ま
での任意の日付です。
* / MOD
DECIMAL(p,j)
DATE のこれらの演算はエラーを報告しませ
んが、結果は、通常意味がありません。
p の値について、詳細は「DECIMAL の結果
のデータ型」を参照してください。
NUMBER(k,j)
NUMBER(k)
NUMBER(*,j)
NUMBER
+-
DATE
DATE のこれらの演算はエラーを報告しませ
んが、結果は、通常意味がありません。
日付の値に対する加算または減算の場合、
小数の小数点以下は切り捨てられます。
日付の結果の値が DATE 型に許容されている
範囲内にないとき、エラーが報告されます。
その範囲とは、西暦の 1 年から 9999 年ま
での任意の日付です。
* / MOD
NUMBER
FLOAT
* / + - MOD
FLOAT
DATE
-
INTEGER
2 つの日付の差は、これらの日付の間の日数
です。これは、値の数値の差ではないこと
に注意する必要があります。
SQL 関数、演算子、式および述部
85
第 3 章 算術演算子/関数、三角関数、双曲線関数
2 項算術演算子の結果のデータ タイプ
左のオペランド
右のオペランド
使用する演算子 結果のデータ タイプ
+ * / MOD
INTEGER
DATE のこれらの演算はエラーを報告しませ
んが、結果は、通常意味がありません。
CHAR(n)
VARCHAR(n)
* / + - MOD
FLOAT
DATE のこれらの演算はエラーを報告しませ
んが、結果は、通常意味がありません。
算術演算子の引数が文字列の場合には、最
初のアクションとしてその文字列から浮動
小数点の数値への変換が試みられます。こ
の変換が失敗した場合には、エラーが報告
されます。
BYTEINT
SMALLINT
INTEGER
BYTEINT
SMALLINT
INTEGER
* / + - MOD
INTEGER
BIGINT
* / + - MOD
BIGINT
DECIMAL(k,j)
* / + - MOD
DECIMAL(p,j)
p の値について、詳細は「DECIMAL の結果
のデータ型」を参照してください。
NUMBER(k,j)
NUMBER(k)
NUMBER(*,j)
NUMBER
* / + - MOD
NUMBER
FLOAT
* / + - MOD
FLOAT
CHAR(n)
VARCHAR(n)
* / + - MOD
FLOAT
DATE
+
算術演算子の引数が文字列の場合には、最
初のアクションとしてその文字列から浮動
小数点の数値への変換が試みられます。こ
の変換が失敗した場合には、エラーが報告
されます。
DATE
日付の結果の値が DATE 型に許容されている
範囲内にないとき、エラーが報告されます。
その範囲とは、西暦の 1 年から 9999 年ま
での任意の日付です。
-
エラー
* / MOD
INTEGER
DATE のこれらの演算はエラーを報告しませ
んが、結果は、通常意味がありません。
86
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
2 項算術演算子の結果のデータ タイプ
左のオペランド
右のオペランド
使用する演算子 結果のデータ タイプ
BIGINT
BYTEINT
SMALLINT
INTEGER
BIGINT
* / + - MOD
BIGINT
DECIMAL(k,j)
* / + - MOD
DECIMAL(p,j)
p の値について、詳細は「DECIMAL の結果
のデータ型」を参照してください。
NUMBER(k,j)
NUMBER(k)
NUMBER(*,j)
NUMBER
* / + - MOD
NUMBER
FLOAT
* / + - MOD
FLOAT
CHAR(n)
VARCHAR(n)
* / + - MOD
FLOAT
DATE
+
算術演算子の引数が文字列の場合には、最
初のアクションとしてその文字列から浮動
小数点の数値への変換が試みられます。こ
の変換が失敗した場合には、エラーが報告
されます。
DATE
日付の結果の値が DATE 型に許容されている
範囲内にないとき、エラーが報告されます。
その範囲とは、西暦の 1 年から 9999 年ま
での任意の日付です。
-
エラー
* / MOD
BIGINT
DATE のこれらの演算はエラーを報告しませ
んが、結果は、通常意味がありません。
DECIMAL(m,n)
DECIMAL(p,n)
BYTEINT
SMALLINT
INTEGER
BIGINT
+-*
/ MOD
DECIMAL(m,n)
DECIMAL(k, j)
+-
DECIMAL(min(p,(1+max(n,j)+max(m -n,kj))),max(n,j))
p の値について、詳細は「DECIMAL の結果
のデータ型」を参照してください。
p の値について、詳細は「DECIMAL の結果
のデータ型」を参照してください。
*
DECIMAL(min(p,m +k),(n+j))
p の値について、詳細は「DECIMAL の結果
のデータ型」を参照してください。
/ MOD
SQL 関数、演算子、式および述部
DECIMAL(p,max(n,j))
87
第 3 章 算術演算子/関数、三角関数、双曲線関数
2 項算術演算子の結果のデータ タイプ
左のオペランド
右のオペランド
使用する演算子 結果のデータ タイプ
p の値について、詳細は「DECIMAL の結果
のデータ型」を参照してください。
NUMBER(k,j)
NUMBER(k)
NUMBER(*,j)
NUMBER
* / + - MOD
NUMBER
FLOAT
* / + - MOD
FLOAT
CHAR(n)
VARCHAR(n)
* / + - MOD
FLOAT
DATE
+
算術演算子の引数が文字列の場合には、最
初のアクションとしてその文字列から浮動
小数点の数値への変換が試みられます。こ
の変換が失敗した場合には、エラーが報告
されます。
DATE
日付の値に対する加算または減算の場合、
小数の小数点以下は切り捨てられます。
日付の結果の値が DATE 型に許容されている
範囲内にないとき、エラーが報告されます。
その範囲とは、西暦の 1 年から 9999 年ま
での任意の日付です。
-
エラー
*
DECIMAL(p,n)
DATE のこれらの演算はエラーを報告しませ
んが、結果は、通常意味がありません。
p の値について、詳細は「DECIMAL の結果
のデータ型」を参照してください。
/ MOD
DECIMAL(m,n)
DATE のこれらの演算はエラーを報告しませ
んが、結果は、通常意味がありません。
NUMBER(m,n)
NUMBER(m)
NUMBER(*,n)
NUMBER
BYTEINT
SMALLINT
INTEGER
BIGINT
* / + - MOD
NUMBER
* / + - MOD
FLOAT
DECIMAL(k,j)
FLOAT
CHAR(n)
VARCHAR(n)
88
FLOAT
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
2 項算術演算子の結果のデータ タイプ
左のオペランド
右のオペランド
使用する演算子 結果のデータ タイプ
算術演算子の引数が文字列の場合には、最
初のアクションとしてその文字列から浮動
小数点の数値への変換が試みられます。こ
の変換が失敗した場合には、エラーが報告
されます。
DATE
+
DATE
日付の値に対する加算または減算の場合、
小数の小数点以下は切り捨てられます。
日付の結果の値が DATE 型に許容されている
範囲内にないとき、エラーが報告されます。
その範囲とは、西暦の 1 年から 9999 年ま
での任意の日付です。
-
エラー
*
NUMBER
DATE のこれらの演算はエラーを報告しませ
んが、結果は、通常意味がありません。
/ MOD
NUMBER
DATE のこれらの演算はエラーを報告しませ
んが、結果は、通常意味がありません。
FLOAT
NUMBER(k,j)
NUMBER(k)
NUMBER(*,j)
NUMBER
* / + - MOD
NUMBER
BYTEINT
SMALLINT
INTEGER
BIGINT
DECIMAL(k,j)
NUMBER(k,j)
NUMBER(k)
NUMBER(*,j)
NUMBER
FLOAT
* / + - MOD
FLOAT
DATE
* / + - MOD
FLOAT
DATE のこれらの演算はエラーを報告しませ
んが、結果は、通常意味がありません。
CHAR(n)
VARCHAR(n)
SQL 関数、演算子、式および述部
* / + - MOD
FLOAT
算術演算子の引数が文字列の場合には、最
初のアクションとしてその文字列から浮動
小数点の数値への変換が試みられます。こ
の変換が失敗した場合には、エラーが報告
されます。
89
第 3 章 算術演算子/関数、三角関数、双曲線関数
2 項算術演算子の結果のデータ タイプ
左のオペランド
右のオペランド
使用する演算子 結果のデータ タイプ
CHAR(n)
VARCHAR(n)
BYTEINT
SMALLINT
INTEGER
BIGINT
DECIMAL(k,j)
NUMBER(k,j)
NUMBER(k)
NUMBER(*,
j)
DATE
NUMBER
FLOAT
CHAR(n)
VARCHAR(n)
* / + - MOD
FLOAT
算術演算子の引数が文字列の場合には、最
初のアクションとしてその文字列から浮動
小数点の数値への変換が試みられます。こ
の変換が失敗した場合には、エラーが報告
されます。
* / + - MOD
FLOAT
DATE のこれらの演算はエラーを報告しませ
んが、結果は、通常意味がありません。
算術演算子の引数が文字列の場合には、最
初のアクションとしてその文字列から浮動
小数点の数値への変換が試みられます。こ
の変換が失敗した場合には、エラーが報告
されます。
DECIMAL の結果のデータ型
DECIMAL オペランドが関与するバイナリ算術演算の結果のデータ タイプは、次の
ようになります。
左のオペランド
右のオペランド
使用する演
算子
結果のデータ タイプ
DATE
DECIMAL(k,j)
* / MOD
DECIMAL(p,j)
DATE のこれらの演算はエラーを報告しませんが、結果は、
通常意味がありません。
* / + - MOD
DECIMAL(p,j)
BYTEINT
SMALLINT
INTEGER
BIGINT
+-*
DECIMAL(p,n)
DATE
*
DECIMAL(p,n)
BYTEINT
SMALLINT
INTEGER
BIGINT
DECIMAL(m,n)
DATE のこれらの演算はエラーを報告しませんが、結果は、
通常意味がありません。
この場合、p の値、つまり小数結果の桁数は、以下によって異なります。
• DBSControl で MaxDecimal に指定した値。
DBSControl と MaxDecimal の詳細は、<ユーティリティ 、B035-1102>の「DBS
Control(DBS 制御)ユーティリティ」を参照してください。
• 小数オペランドの桁数。ただし、演算子の右の DECIMAL(k,j)オペランドの場合は
桁数は k、演算子の左の DECIMAL(m,n)オペランドの場合は桁数は m。
90
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
2 項算術演算子の結果のデータ タイプ
MaxDecimal の値
小数オペランドの桁数
p
0 または 15
<= 15
15
15 より大きく 18 より小さい
18
> 18
38
<= 18
18
> 18
38
任意の値
38
18
38
左のオペランド
右のオペランド
使用する演
算子
結果のデータ タイプ
DECIMAL(m,n)
DECIMAL(k,j)
+-
DECIMAL(min(p, (1+max(n,j)+max(m -n,k -j))),max(n,j))
*
DECIMAL(min(p,m +k),(n +j))
/ MOD
DECIMAL(p,max(n,j))
この場合、DBSControl 内の MaxDecimal に指定した値と、DECIMAL(m,n)オペラン
ドおよび DECIMAL(k,j)オペランドの桁数によって、小数結果のデータ型の定義にお
ける p の値は異なります。
MaxDecimal の値
および
p
0 または 15
m および k <= 15
15
(m または k > 15)と(m および k <=18)
18
m または k > 18
38
m および k <= 18
18
m または k > 18
38
m および k = 任意の値
38
18
38
数値の結果と四捨五入
式を計算した結果、数値の結果がちょうどではない場合は、切り捨てではなく四捨
五入されます。
四捨五入の規則、および DBSControl 内の RoundHalfwayMagUp および
RoundNumberAsDec フィールドが四捨五入に与える影響について 、詳細は< SQL
データ型とリテラル、B035-1143>の「数値データ型」および<ユーティリティ 、
B035-1102>の「DBS 制御ユーティリティ」を参照してください。
エラー条件
次の場合は、エラーが報告されます。
• ゼロによる除算が行なわれようとした。
• 数値の範囲を超えている。
SQL 関数、演算子、式および述部
91
第 3 章 算術演算子/関数、三角関数、双曲線関数
Structure of Arithmetic Expressions
• べき乗演算で左の引数が負、右の引数が整数以外で行なわれようとした。
整数の除算と切り捨て
整数の除算では、切り捨てが実行されて整数になります。
Structure of Arithmetic Expressions
評価の順序
次の表に、算術式での演算の優先順位を示します。
優先順位
演算
最高
+オペランド(正符号)
-オペランド(負符号)
中
オペランド**オペランド(べき乗算)
オペランド*オペランド(乗算)
オペランド/オペランド(除算)
オペランド MOD オペランド(比率演算子)
オペランド+オペランド(加算)
オペランド-オペランド(減算)
一般に、評価の順序は以下のようになります。
1. 括弧内の演算が最初に実行されます。
2. 括弧がないときは、演算は優先順位の順序で実行されます。
3. 同一の優先順位の演算子は、左から右に向かって評価されます。
最適化ルーチンでは、関与する演算の結合および可換プロパティに基づいて評価が
並べ替えられることがあります。
書式
算術式の書式は、結果のデータ タイプのデフォルトの書式と同じです。
FORMAT 句を使って、結果のデータ タイプのデフォルト書式を変更することができ
ます。FORMAT 句は、BTEQ アプリケーションなどのフィールド モード、および文
字データ タイプへの変換においてのみ適しています。
例: 従業員の昇給の決定
部門 600 のすべての従業員の給与を勤続年数に比例して 200 ドルずつ昇給する予定
(最高で月額 2500 ドルまで)と想定します。
該当者と新しい給与を決定するには、次の文になります。
92
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
算術関数
SELECT Name, (Salary+(YrsExp*200))/12 AS Projection
FROM Employee
WHERE Deptno = 600
AND Projection < 2500 ;
この文は、次の応答を戻します。
Name
-------Newman P
Projection
---------2483.33
この文は括弧を使って、まず演算 YrsExp * 200 を行ないます。次にその結果が Salary
に加算され、合計が 12 で割られています。
YrsExp * 200 を囲む括弧は厳密には必要ではありませんが、Salary + (YrsExp * 200)
を囲む括弧は必要です。それは、この式で括弧が使用されなかった場合、演算 YrsExp
* 200 は 12 で割られ、その結果が Salary に加算されるので、誤った値を生じるか
らです。
この例の句 AS Projection は、算術式の(Salary + (YrsExp * 200)/12)を Projection に
関連付けます。AS 句の使用によって、式全体を参照するのに WHERE 句内で名前
Projection を使用することになります。
結果は、1000 と 100 の位を区切るカンマなしで書式化されます。
算術関数
これから、次の算術関数について説明します。
• ABS
• CASE_N
• CEILING
• EXP
• FLOOR
• LN
• LOG
• NULLIFZERO
• RANDOM
• RANGE_N
• SQRT
• WIDTH_BUCKET
• ZEROIFNULL
ABS
目的
引数の絶対値を計算します。
SQL 関数、演算子、式および述部
93
第 3 章 算術演算子/関数、三角関数、双曲線関数
ABS
構文
ABS
( arg )
構文要素
arg
SUM()が要求される数値列。入力を動的 UDT として指定する必要があります。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果のタイプと属性
次の表に、ABS の結果のデフォルト属性を示します。
• オペランドが数値である場合、書式は結果のデータ タイプのデフォルトの書式で
す。
• オペランドが文字である場合、書式は FLOAT のデフォルトの書式です。
• オペランドが UDT である場合、書式は UDT の暗黙キャスト先の事前定義タイプ
のデフォルト書式です。
注: NULL キーワードのデータ タイプは INTEGER です。
データ タイプ書式については、< SQL データ型とリテラル、B035-1143>を参照し
てください。
引数のタイプと規則
引数は、数値でない場合は暗黙のタイプ変換規則に基づいて数値に変換されます。
引数を変換できない場合は、エラーが戻されます。暗黙タイプ変換の詳細は、暗黙
的な型の変換を参照してください。
arg は文字列の場合は、FLOAT データ型の数値に変換されます。
arg が UDT である場合、以下のルールが適用されます。
• 以下のいずれかの事前定義タイプに対する暗黙 CAST が UDT になければなりませ
ん。
• 数値
• 文字
• 日時
• 間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。CREATE CAST の詳細は、<SQL データ定義言
語 - 構文規則および例、B035-1144>を参照してください。
• ABS を含め、システム演算子および関数用の UDT の暗黙の型変換は、ANSI SQL
規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レコードの
DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳細は、
<ユーティリティ 、B035-1102>を参照してください。
94
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
CASE N
次のタイプの引数に ABS を適用することはできません。
• BYTE または VARBYTE
• BLOB または CLOB
• CHARACTER または VARCHAR (サーバーの文字セットが GRAPHIC の場合)
例: ABS 算術関数式の使用
主な ABS 算術関数式とその結果の例を次に示します。
式
結果
ABS(-12)
12
ABS('23')
2.30000000000000E+001
例: ABS 算術関数式の使用
主な ABS 算術関数式とその結果の例を次に示します。
式
結果
ABS(-12)
12
ABS('23')
2.30000000000000E+001
CASE N
目的
条件リストを評価して、TRUE と評価された最初の条件の位置を戻します。ただし、
そのリスト中の以前の条件が UNKNOWN と評価されていないことを前提とします。
構文
,
CASE_N
(
A
conditional_expression
A
)
,
NO CASE
OR UNKNOWN
, UNKNOWN
UNKNOWN
構文要素
conditional_expression
評価する式またはカンマで区切られた条件式のリスト。
条件式は TRUE、FALSE、または UNKNOWN と評価されなければなりません。
SQL 関数、演算子、式および述部
95
第 3 章 算術演算子/関数、三角関数、双曲線関数
CASE N
NO CASE
リスト中のすべての conditional_expression が FALSE と評価される場合に TRUE と
評価されます。
OR UNKNOWN
NO CASE とともに使用します。
リスト中のすべての conditional_expression が FALSE と評価される場合か、または
conditional_expression が UNKNOWN と評価されるとともにリスト中の前の条件が
すべて FALSE と評価される場合、NO CASE OR UNKNOWN 条件は TRUE と評価され
ます。
UNKNOWN
conditional_expression が UNKNOWN と評価され、かつリスト中の前の条件がすべ
て FALSE と評価される場合に TRUE と評価されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
評価
条件の評価が TRUE または UNKNOWN と決まるまでか、またはどの条件の評価も
FALSE となるまで、CASE_N は左から右に向かって conditional_expressions を評価
します。最初の conditional_expression の位置は 1 になり、それに続く条件の位置
は上限を n として 1 ずつ増加します。n は条件式の合計数です。
条件
結果
conditional_expression が CASE_N は conditional_expression の位置を戻します。
TRUE と評価され、前の条
件はすべて FALSE と評価さ
れた場合
conditional_expression が
UNKNOWN と評価され、
前の条件はすべて FALSE と NO CASE OR UNKNOWN を指定した場合、CASE_N は n + 1 を
返します。
評価された場合
UNKNOWN を指定し、NO CASE を指定しない場合、CASE_N
は n + 1 を返します。
NO CASE と UNKNOWN を指定した場合、CASE_N は n + 2 を
返します。
UNKNOWN も NO CASE OR UNKNOWN も指定しない場合、
CASE_N は NULL を返します。
すべての
conditional_expression が
FALSE と評価された場合
96
NO CASE または NO CASE OR UNKNOWN を指定した場合、
CASE_N は n + 1 を返します。
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
CASE N
条件
結果
NO CASE も NO CASE OR UNKNOWN も指定しない場合、
CASE_N は NULL を返します。
結果のタイプと属性
CASE_N のデータ タイプ、書式、およびタイトルは、次のとおりです。
データ タイプ
書式
タイトル
INTEGER
INTEGER のデフォルト書式
<CASE_N 関数>
デフォルトのデータ タイプ書式については、< SQL データ型とリテラル、
B035-1143>を参照してください。
パーティション基本索引を定義するための CASE_N の使用
テーブルの基本索引または結合索引は、各 AMP に対するそのテーブルのデータま
たは結合索引の分散および検索を制御します。基本索引がパーティション 基本索引
(PPI)である場合、AMP 上のユーザー定義のパーティションに対してデータを割り
当てることができます。
テーブルの基本索引または結合索引を定義するには、PRIMARY INDEX 句を CREATE
TABLE または CREATE JOIN INDEX データ定義文に指定します。パーティション基
本索引を定義するには、基本索引の定義時に PARTITION BY 句を組み込みます。
PARTITION BY 句には、行のパーティション割り当てを決定する 1 つ以上のパーティ
ション化式が必要です。CASE_N を使って、パーティション化列において何らかの
値または NULL をもつ行がいずれかのパーティションに割り当てられるようにパー
ティション化式を構築することができます。
また、RANGE_N を使ってパーティション化列を構築することもできます。詳細に
ついては、「RANGE_N」を参照してください。
PARTITION BY 句がパーティション化式のリストを指定する場合、PPI はマルチレ
ベル PPI であり、1 つのレベルの各パーティションはリスト内の次のパーティショ
ン化式に従ってサブパーティション化されます。有効な SQL 式(例外もあり)から成
る単一レベルの PPI のパーティション化式とは異なり、マルチレベル PPI のパー
ティション化式のリスト内の各式は、CASE_N 関数または RANGE_N 関数でなけれ
ばなりません。
CASE_N 関数に基づくパーティション式を、ADD または DROP することはできませ
ん。CASE_N 関数に基づくパーティション式を変更するには、MODIFY PRIMARY
INDEX オプションを指定した ALTER TABLE 文で、PARTITION BY 句全体を再定義
する必要があります。また、その文を使用するテーブルは空でなければなりません。
詳細については、<SQL データ定義言語 - 構文規則および例、B035-1144>の「ALTER
TABLE」を参照してください。
SQL 関数、演算子、式および述部
97
第 3 章 算術演算子/関数、三角関数、双曲線関数
CASE N
CURRENT_DATE または CURRENT_TIMESTAMP を指定した CASE_N を PPI で使用する方法
ビルトイン関数の CURRENT_DATE または CURRENT_TIMESTAMP を指定した
CASE_N を使用して、パーティション式を定義できます。これを定義した後で、
ALTER TABLE TO CURRENT 文を使用すると、改めて解決された現在の日付またはタ
イムスタンプを使用して、テーブル データを再パーティション化できます。
詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>の「更新可能日付
および更新可能タイムスタンプに基づく CASE_N パーティション式の最適化を調整
するルール」を参照してください。
文字比較を指定した CASE_N の使用
CHAR、VARCHAR、GRAPHIC、VARGRAPHIC データ タイプを比較する条件式を、
CASE_N 関数内で指定できます。適用される使用上の規則は、次のとおりです。
• CASE_N パーティション式には、文字またはグラフィック文字の比較を使用でき
ます。ただし、KANJI1 または KANJISJIS の列やリテラル式が関与している比較
は使用できません。
• CASE_N パーティション式には、UPPERCASE 修飾子と、次に示す関数を使用でき
ます。LOWER、UPPER、TRANSLATE、TRIM、VARGRAPHIC、INDEX、
MINDEX、POSITION、TRANSLATE_CHK、CHAR2HEXINT。
• CASE_N 式内で参照する文字列定数は、31,000 バイト未満にする必要があります。
• CASE_N 関数内の条件式を評価する際に使用される文字データの順序は、セッショ
ンの照合と、その条件式に対するケース指定によって決定されます。
• その条件式が PPI の一部ではない場合には、現在のセッションの照合が使用さ
れます。
• その条件式が PPI の一部である場合には、テーブルまたは結合索引が作成され
たときに有効であったセッションの照合が評価に使用されます。または、パー
ティションが ALTER TABLE 文で変更されたときに有効であったセッションの
照合が評価に使用されます。
• 列参照と文字列定数のケース指定は、セッションのデフォルト、明示的な
CAST、またはテーブルが作成されたときの CREATE TABLE 文の指定内容によっ
て決まります。列には CASESPECIFIC または NOT CASESPECIFIC を明示的に指
定できます。また、それらの修飾子でリテラル式を CAST できます。
明示的な指定がないときに、Teradata セッションのトランザクション セマン
ティクスが有効な場合には、NOT CASESPECIFIC が使用されます。ANSI セッ
ションのトランザクション セマンティクスが有効な場合には、CASESPECIFIC
がデフォルトになります。
たとえば、条件式が、NOT CASESPECIFIC 式と、ケース指定修飾子
(CASESPECIFIC、NOT CASESPECIFIC)のないリテラルの組み合わせならば、
ANSI モードのセッションではケース指定が CASESPECIFIC になり、Teradata
モードのセッションでは NOT CASESPECIFIC になります。
グラフィック文字データが関与する文字列比較は、すべてケース指定になりま
す。
• 文字比較演算子(=、<、>、<=、>=、<>、BETWEEN、LIKE)では、文字列定数が比
較対象の列データよりも短い場合、その文字列定数は埋め込み文字が埋め込まれ
ているものとして扱われます。埋め込み文字(例えば、<スペース> 文字)は、文字
セットに固有なものになります。
98
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
CASE N
埋め込み文字は、照合内の最小コード ポイントとして照合されないことがあり
ます。長さ n のリテラルの場合、比較対象の列値がリテラルの最初の n 文字まで
完全に一致していても、列値の n+1 の位置に埋め込み文字よりも小さく照合され
る文字が含まれていると、その列値は文字列リテラルよりも小さいと照合されま
す。
制約事項
CASE_N が PARTITION BY 句で使用される場合、以下のような制限が適用されます。
• 最大 65533 の条件を指定できる(大きなパーティション化式の一部でない場合)。
• システム派生列の PARTITION または PARTITION#L1 から PARTITION#L15 を含
めてはいけません。
• 以下の場合を除いて、PERIOD データ型を使用してはなりません。
• 入力が PERIOD データ タイプの列であり、期間式ではない BEGIN 境界関数。
• 入力が PERIOD データ タイプの列であり、期間式ではない END 境界関数。
• IS [NOT] UNTIL_CHANGED。
• IS [NOT] UNTIL_CLOSED。
CASE_N がマルチレベル PPI のパーティション化式で使用される場合は、少なくと
も 2 つのパーティションを定義する必要があります。
問合わせのパーティション排除は、リテラルに限定されていることが多く、そうで
なければパーティション列に対して等価条件の値を使用することになるため、一部
のパーティションは排除可能であっても、最適化ルーチンによって排除されないこ
とがあります。さらに、CPU サイクルの観点から考えると複雑な CASE_N の評価に
はコストがかかることがあり、CASE_N のオーバーヘッドがテーブル ヘッダーの巨
大化を招くこともあります。
例
例: 行を割り当てるパーティションの定義
以下は、CASE_N と totalorders 列の値を使って行の割り当て先のパーティションを
定義する例です。
CREATE TABLE orders
(storeid INTEGER NOT NULL
,productid INTEGER NOT NULL
,orderdate DATE FORMAT 'yyyy-mm-dd' NOT NULL
,totalorders INTEGER)
PRIMARY INDEX (storeid, productid)
PARTITION BY CASE_N(totalorders < 100, totalorders < 1000,
NO CASE, UNKNOWN);
この例では、CASE_N は totalorders 列の値に基づいて、行の割り当て先となる 4 つ
のパーティションを指定します。
パーティ
ション
番号
条件
1
totalorders 列の値は 100 より小さい。
SQL 関数、演算子、式および述部
99
第 3 章 算術演算子/関数、三角関数、双曲線関数
CASE N
パーティ
ション
番号
条件
2
totalorders 列の値は 1000 より小さいが、100 以上である。
3
totalorders 列の値は 1000 以上である。
4
totalorders 列は NULL である。
例: マルチレベル PPI を定義するパーティション化式のリストで CASE_N の使用
以下の例では、「例: 行が割り当てられるパーティションの定義」を変更して、マル
チレベル PPI を定義するパーティション化式のリストで CASE_N を使用しています。
CREATE TABLE orders
(storeid INTEGER NOT NULL
,productid INTEGER NOT NULL
,orderdate DATE FORMAT 'yyyy-mm-dd' NOT NULL
,totalorders INTEGER NOT NULL)
PRIMARY INDEX (storeid, productid)
PARTITION BY (CASE_N(totalorders < 100, totalorders < 1000,
NO CASE)
,CASE_N(orderdate <= '2005-12-31', NO CASE) );
この例では、行が割り当てられる 6 つのパーティションが定義されています。最初
の CASE_N 式は、totalorders 列の値に基づいて 3 つのパーティションを定義してい
ます。2 番目の CASE_N 式は、orderdate 列の値に基づいて 3 つのパーティションを
それぞれ 2 つのパーティションに再分割しています。
レベル 1
パーティ
ション
番号
レベル 2 条件
パーティ
ション
番号
1
1
totalorders 列の値は 100 より小さく、orderdate 列の値は
'2005-12-31'より小さいか等しい。
2
totalorders 列の値は 100 より小さく、orderdate 列の値は
'2005-12-31'より大きい。
1
totalorders 列の値は 1000 より小さく、100 より大きいか等しい。
orderdate 列の値は'2005-12-31'より小さいか等しい。
2
totalorders 列の値は 1000 より小さく、100 より大きいか等しい。
orderdate 列の値は'2005-12-31'より大きい。
1
totalorders 列の値は 1000 より大きいか等しく、orderdate 列の値は
'2005-12-31'より小さいか等しい。
2
totalorders 列の値は 1000 より大きいか等しく、orderdate 列の値は
'2005-12-31'より大きい。
2
3
例: 各パーティションの行数の表示
以下の例は、CASE_N 式を使って orders テーブルがパーティション化された場合の
各パーティションの行カウントを示します。
100
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
CASE N
CREATE TABLE orders
(orderkey INTEGER NOT NULL
,custkey INTEGER
,orderdate DATE FORMAT 'yyyy-mm-dd' NOT NULL)
PRIMARY INDEX (orderkey);
INSERT INTO orders (1, 1, '1996-01-01');
INSERT INTO orders (2, 1, '1997-04-01');
次の SELECT 文の CASE_N 式は、3 つの条件式と NO CASE 条件を指定します。
SELECT COUNT(*),
CASE_N(orderdate >= '1996-01-01'
orderdate <= '1996-12-31'
custkey <> 999999,
orderdate >= '1997-01-01'
orderdate <= '1997-12-31'
custkey <> 999999,
orderdate >= '1998-01-01'
orderdate <= '1998-12-31'
custkey <> 999999,
NO CASE
) AS Partition_Number
FROM orders
GROUP BY Partition_Number
ORDER BY Partition_Number;
AND
AND
AND
AND
AND
AND
結果は次のようになります。
Count(*)
----------1
1
Partition_Number
---------------1
2
例: 注文データでパーティション化されるテーブルの作成
次の例では、2008 年の四半期ごとの注文(Orders)データでパーティション化された
テーブルを作成しています。
CREATE TABLE Orders
(O_orderkey INTEGER NOT NULL,
O_custkey INTEGER,
O_orderperiod PERIOD (DATE) NOT NULL,
O_orderpriority CHAR (21),
O_comment VARCHAR (79))
PRIMARY INDEX (O_orderkey)
PARTITION BY
CASE_N (END (O_orderperiod) <= date'2008-03-31', /* First Quarter
*/
END (O_orderperiod) <= date'2008-06-30', /* Second Quarter
*/
END (O_orderperiod) <= date'2008-09-30', /* Third Quarter
*/
SQL 関数、演算子、式および述部
101
第 3 章 算術演算子/関数、三角関数、双曲線関数
CASE N
END (O_orderperiod) <= date'2008-12-31' /* Fourth Quarter
*/
);
次の SELECT 文では、2 つのパーティションをスキャンして、年初からの 2 四半期
に受注した注文(Orders)の詳細項目を表示します。
SELECT *
FROM Orders
WHERE END (O_orderperiod) > date'2008-06-30';
例: PERIOD 式の終了境界値の確認
次の例では、PPI のパーティション式に IS [NOT] UNTIL_CHANGED を使用して、期
間式の終了境界が UNTIL_CHANGED かどうかを検査しています。
CREATE TABLE TESTUC
(A INTEGER,
B PERIOD (DATE),
C INTEGER)
PRIMARY INDEX (A)
PARTITION BY
CASE_N (END (b) IS UNTIL_CHANGED,
END (b) IS NOT UNTIL_CHANGED, UNKNOWN);
例: Transaction-time 列の PERIOD 式の終了境界値の確認
次の例では、PPI のパーティション式に IS [NOT] UNTIL_CLOSED を使用して、トラ
ンザクション時間列の終了境界が UNTIL_CLOSED かどうかを検査しています。
CREATE TABLE TESTUC
(A INTEGER,
B PERIOD (TIMESTAMP (6) WITH TIME ZONE) NOT NULL AS
TRANSACTIONTIME,
C INTEGER)
PRIMARY INDEX (A)
PARTITION BY
CASE_N (END (b) IS UNTIL_CHANGED,
END (b) IS NOT UNTIL_CHANGED, UNKNOWN);
例: FALSE 条件の結果の表示
この例では、セッションの照合は ASCII です。
CASE_N (a<'b', a>='ba' and a<'dogg' and b<>'cow', c<>'boy', NO CASE OR
UNKNOWN)
次の表では、a、b、および c に特定の値を指定したときに、上記の CASE_N 関数が
返す結果値を示しています。x および y は、任意の値または NULL を表わします。
条件がすべて FALSE の場合や、先行する条件が FALSE と評価されていて、最後の条
件が UNKNOWN の場合には、値 4 が返されます。
102
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
CASE N
a
b
c
結果
'a'
x
y
1
'boy'
'girl'
y
2
'boy'
NULL
y
4
'boy'
'cow'
'man'
3
'boy'
'cow'
'boy'
4
'dog'
'ball'
y
2
'dogg'
x
NULL
4
'dogg'
x
'man'
3
'egg'
x
'boy'
4
'egg'
x
NULL
4
'egg'
x
'girl'
3
例: UNKNOWN 条件の結果の表示
この例では、セッションの照合は ASCII です。
CASE_N (a<'b', a>='ba' and a<'dogg' and b<>'cow', c<>'boy', UNKNOWN)
次の表では、a、b、および c に特定の値を指定したときに、上記の CASE_N 関数が
返す結果値を示しています。x および y は、任意の値または NULL を表わします。
先行する条件がすべて FALSE に評価され、最後の条件が UNKNOWN の場合は、値
4 が返されます。すべての条件が FALSE の場合は、NULL が返されます。
a
b
c
結果
'a'
x
y
1
'boy'
'girl'
y
2
'boy'
NULL
y
4
'boy'
'cow'
'man'
3
'boy'
'cow'
'boy'
NULL
'dog'
'ball'
y
2
'dogg'
x
NULL
4
'dogg'
x
'man'
3
'egg'
NULL
'boy'
NULL
'egg'
x
'boy'
NULL
SQL 関数、演算子、式および述部
103
第 3 章 算術演算子/関数、三角関数、双曲線関数
CASE N
a
b
c
結果
'egg'
x
NULL
4
'egg'
x
'girl'
3
例: a の値に基づくパーティションの定義
この例では、CREATE TABLE 文を実行しているときのセッションの照合は ASCII で
す。また、埋め込み文字は<スペース>です。この例では、次に示す a の値に基づい
て、2 つのパーティション(番号 1 と 2)を定義します。
'(a の後ろに 9 個のスペース)から'b
'の間である。
• a の値は、'a
• a の値は、'b
'から'c
'の間である。
CREATE SET TABLE t2
(a VARCHAR(10) CHARACTER SET UNICODE NOT CASESPECIFIC,
b INTEGER)
PRIMARY INDEX (a)
PARTITION BY CASE_N(a BETWEEN 'a' AND 'b', a BETWEEN 'b' AND 'c');
以下の INSERT 文では、'b'と'1'の間に 1 つの<tab>文字が入る文字列を挿入します。
INSERT t2 ('b
1', 1);
以下の INSERT 文では、'b'と'1'の間に 1 つの<space>文字が入る文字列を挿入します。
INSERT t2 ('b 1', 2);
以下の SELECT 文は、INSERT 文の結果を示します。タブ文字はスペース文字よりも
コード ポイントが小さいため、最初に挿入された文字列はパーティション 1 にマッ
プされます。
SELECT PARTITION, a, b FROM t2 ORDER BY 1;
*** Query completed. 2 rows found. 3 columns returned.
*** Total elapsed time was 1 second.
PARTITION a
b
----------- ------ ----1 b 1
1
(string contains single <tab> character)
2 b 1
2
(string contains single <space> character)
関連トピック
詳細は、以下を参照してください。
• PPI のプロパティとパフォーマンスに関する考慮事項 、および PPI の考慮事項と
容量に関する計画の詳細については、<データベース設計、B035-1094>を参照し
てください。
• テーブルの PPI の指定の詳細については、 <SQL データ定義言語 - 構文規則およ
び例、B035-1144>の「CREATE TABLE」を参照してください。
• 結合索引の PPI の指定の詳細については、<SQL データ定義言語 - 構文規則および
例、B035-1144>の「CREATE JOIN INDEX」を参照してください。
• テーブルの基本索引のパーティションの修正の詳細については 、<SQL データ定
義言語 - 構文規則および例、B035-1144>の「ALTER TABLE」を参照してください。
104
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
CEILING
• 新規に解決された CURRENT_DATE 値と、CURRENT_TIMESTAMP 値に基づいた
パーティション化の調整の詳細については、<SQL データ定義言語 - 構文規則お
よび例、B035-1144>の「ALTER TABLE TO CURRENT」を参照してください。
CEILING
目的
入力引数よりも小さくならない最小の整数値を返します。
構文
CEILING
TD_SYSFNLIB.
( arg )
CEIL
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
arg
変換される数値式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
CEILING は埋め込みサービス システム関数です 。埋め込みサービス関数の有効化と
呼び出しについて、詳細は埋め込みサービス システム関数 を参照してください。
引数のタイプと規則
この関数に渡される式には、次のいずれかのデータ タイプが含まれている必要があ
ります。
BYTEINT、SMALLINT、INTEGER、BIGINT、FLOAT/REAL/DOUBLE PRECISION、
DECIMAL/NUMERIC、または NUMBER
戻り値
CEILING は次の値を返すスカラー関数です。
SQL 関数、演算子、式および述部
105
第 3 章 算術演算子/関数、三角関数、双曲線関数
CEILING
arg
CEILING の返す値
非正確数
arg より大きい次の整数値。
正確数
入力引数 arg。
NULL
NULL
結果のタイプと属性
結果のタイプは、入力引数の数値と同じデータ タイプになります。
入力引数が DECIMAL/NUMERIC で精度が 38 未満のときには、返される DECIMAL/
NUMERIC 値の精度が 1 だけ増分されます。例えば、DECIMAL(6,4)が渡されたとす
ると、その精度が増分されて DECIMAL(7,4)として返されます。精度が 38 の場合
は、スケールが 1 だけ減分されます(スケールが 0 でない場合)。例えば、
DECIMAL(38,38)の戻りデータ型は DECIMAL(38,37)になります。
デフォルトのデータ タイプ書式については、< SQL データ型とリテラル、B035-1143>
を参照してください。
例
例: SELECT CEILING(157E-1);の問合わせ
次の問合わせは、FLOAT 値 16E0 を返します。これは、FLOAT 値 15.7E0 よりも小
さくならない最小の整数が 16 になるためです。
SELECT CEILING(157E-1);
例: SELECT CEILING(15.7);の問合わせ
次の問合わせは、DECIMAL 値 16.0 を返します。これは、DECIMAL 定数 15.7 より
も小さくならない最小の整数が 16 になるためです。
SELECT CEILING(15.7);
例: SELECT CEILING(-12.3);の問合わせ
次の問合わせは、DECIMAL 値-12.0 を返します。これは、DECIMAL 定数-12.3 より
も小さくならない最小の整数が-12 になるためです。
SELECT CEILING(-12.3);
例: SELECT CEIL( CAST(9.99 AS DECIMAL(3,2)) );の問合わせ
次の問合わせは、データ型が DECIMAL(4,2)の値 10.00 を返します。これは、9.99
よりも小さくならない最小の整数が 10 になるためです。戻り値の精度が 1 だけ増
分されていることに注目してください。
SELECT CEIL( CAST(9.99 AS DECIMAL(3,2)) );
106
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
EXP
EXP
目的
e(自然対数の底)を引数にべき乗します。ただし、e = 2.71828182845905。
構文
EXP
( arg )
構文要素
arg
変換される数値式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果のタイプと属性
次の表に、EXP(arg)の結果のデフォルト属性を示します。
データ タイプ
書式
タイトル
FLOAT
結果のデータ タイプのデフォルト書式
EXP(arg)
引数のタイプと規則
arg は、FLOAT でない場合は暗黙の型変換規則に基づいて FLOAT に変換されます。
引数を変換できない場合は、エラーが戻されます。暗黙タイプ変換の詳細は、「暗
黙的な型の変換」を参照してください。
arg が UDT である場合、以下のルールが適用されます。
• 以下のいずれかの事前定義タイプに対する暗黙 CAST が UDT になければなりま
せん。
• 数値
• 文字
• DATE
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。
• EXP を含め、システム演算子および関数用の UDT の暗黙の型変換は、ANSI SQL
規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レコード
の DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。
次のタイプの引数に EXP を適用することはできません。
• BYTE または VARBYTE
SQL 関数、演算子、式および述部
107
第 3 章 算術演算子/関数、三角関数、双曲線関数
FLOOR
• BLOB または CLOB
• CHARACTER または VARCHAR (サーバーの文字セットが GRAPHIC の場合)
使用上の注意
EXP を実行すると、数値のオーバーフロー エラーになる場合があります。
例: 典型的な EXP 算術関数式
主な EXP 算術関数式とその結果の例を次に示します。
式
結果
EXP(1)
2.71828182845905E+000
EXP(0)
1.00000000000000E+000
関連トピック
詳細は、以下を参照してください。
• デフォルトのデータ タイプ書式については、< SQL データ型とリテラル、
B035-1143>を参照してください。
• CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>
を参照してください。
• DBS 制御レコードの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設
定する詳細については、<ユーティリティ 、B035-1102>を参照してください。
FLOOR
目的
入力引数以下の最大の整数を返します。
構文
FLOOR
( arg )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
108
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
FLOOR
arg
変換される数値式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
FLOOR は埋め込みサービス システム関数です 。埋め込みサービス関数の有効化と
呼び出しについて、詳細は埋め込みサービス システム関数 を参照してください。
引数のタイプと規則
この関数に渡される式には、次のいずれかのデータ タイプが含まれている必要があ
ります。
BYTEINT、SMALLINT、INTEGER、BIGINT、FLOAT/REAL/DOUBLE PRECISION、
DECIMAL/NUMERIC、または NUMBER
戻り値
FLOOR は次の値を返すスカラー関数です。
arg
FLOOR の返す値
非正確数
arg 以下の最大の整数。
正確数
入力引数 arg。
NULL
NULL
結果のタイプと属性
結果のタイプは、入力引数の数値と同じデータ タイプになります。
入力引数が DECIMAL/NUMERIC で精度が 38 未満のときには、返される DECIMAL/
NUMERIC 値の精度が 1 だけ増分されます。例えば、DECIMAL(6,4)が渡されたとす
ると、その精度が増分されて DECIMAL(7,4)として返されます。精度が 38 の場合
は、スケールが 1 だけ減分されます(スケールが 0 でない場合)。例えば、
DECIMAL(38,38)の戻りデータ型は DECIMAL(38,37)になります。
FLOOR のデフォルト タイトルは、FLOOR(arg)です。
デフォルトのデータ タイプ書式については、< SQL データ型とリテラル、
B035-1143>を参照してください。
SQL 関数、演算子、式および述部
109
第 3 章 算術演算子/関数、三角関数、双曲線関数
LN 関数
例
例: SELECT FLOOR (136E-1);の問合わせ
次の問合わせは、FLOAT 値 13E0 を返します。これは、FLOAT 値 13.6E0 よりも小
さい最大の整数が 13 になるためです。
SELECT FLOOR (136E-1);
例: SELECT FLOOR(-6.5);の問合わせ
次の問合わせは、DECIMAL 値-7.0 を返します。これは、DECIMAL 定数-6.5 よりも
小さい最大の整数が-7 になるためです。
SELECT FLOOR(-6.5);
例: SELECT FLOOR (CAST(-6.5 AS DECIMAL(2,1)));の問合わせ
次の問合わせは、データ型が DECIMAL(3,1)の値-7.0 を返します。これは、DECIMAL
の-6.5 よりも小さい最大の整数が-7 になるためです。戻り値の精度が 1 だけ増分さ
れていることに注目してください。
SELECT FLOOR (CAST(-6.5 AS DECIMAL(2,1)));
関連トピック
詳細は、以下を参照してください。
• 「埋め込みサービス システム関数 」
• SQL データ型とリテラル、B035-1143
LN 関数
目的
引数の自然対数を計算します。
構文
LN
( arg )
構文要素
arg
非ゼロの正数値引数。
110
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
LN 関数
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果のタイプと属性
LN(arg)のデータ タイプ、書式、およびタイトルは、次のとおりです。
データ タイプ
書式
タイトル
FLOAT
FLOAT のデフォルト書式
LN(arg)
引数のタイプと規則
arg は、FLOAT でない場合は暗黙の型変換規則に基づいて FLOAT に変換されます。
引数を変換できない場合は、エラーがレポートされます。
arg が UDT である場合、以下のルールが適用されます。
• 以下のいずれかの事前定義タイプに対する暗黙 CAST が UDT になければなりま
せん。
• 数値
• 文字
• DATE
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。
• LN を含め、システム演算子および関数用の UDT の暗黙の型変換は、ANSI SQL
規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レコード
の DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。
次のタイプの引数に LN を適用することはできません。
• BYTE または VARBYTE
• BLOB または CLOB
• CHARACTER または VARCHAR (サーバーの文字セットが GRAPHIC の場合)
例: 典型的な LN 算術関数式
例: 典型的な LN 算術関数式
主な LN 算術関数式とその結果の例を次に示します。
式
結果
LN(2.71828182845905)
1.00000000000000E+000
LN(0)
エラー
関連トピック
詳細は、以下を参照してください。
SQL 関数、演算子、式および述部
111
第 3 章 算術演算子/関数、三角関数、双曲線関数
LOG 関数
• 暗黙タイプ変換の詳細は、「暗黙的な型の変換」を参照してください。
• CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>
を参照してください。
• DBS 制御レコードの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設
定する詳細については、<ユーティリティ 、B035-1102>を参照してください。
• デフォルトのデータ タイプ書式については、< SQL データ型とリテラル、
B035-1143>を参照してください。
LOG 関数
目的
引数の底 10 の対数を計算します。
構文
LOG
( arg )
構文要素
arg
非ゼロの正数値引数。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果のタイプと属性
LOG(arg)のデータ タイプ、書式、およびタイトルは、次のとおりです。
データ タイプ
書式
タイトル
FLOAT
FLOAT のデフォルト書式
LOG(arg)
デフォルトのデータ タイプ書式については、< SQL データ型とリテラル、B035-1143>
を参照してください。
引数のタイプと規則
arg は、FLOAT でない場合は暗黙の型変換規則に基づいて FLOAT に変換されます。
引数を変換できない場合は、エラーが戻されます。暗黙タイプ変換の詳細は、暗黙
的な型の変換を参照してください。
arg が UDT である場合、以下のルールが適用されます。
112
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
NULLIFZERO
• 以下のいずれかの事前定義タイプに対する暗黙 CAST が UDT になければなりま
せん。
• 数値
• 文字
• DATE
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。CREATE CAST の詳細は、<SQL データ定義言
語 - 構文規則および例、B035-1144>を参照してください。
• LOG を含め、システム演算子および関数用の UDT の暗黙の型変換は、ANSI SQL
規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レコード
の DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳細
は、<ユーティリティ 、B035-1102>を参照してください。
次のタイプの引数に LOG を適用することはできません。
• BYTE または VARBYTE
• BLOB または CLOB
• CHARACTER または VARCHAR (サーバーの文字セットが GRAPHIC の場合)
例: 典型的な LOG 算術関数式
主な LOG 算術関数式とその結果の例を次に示します。
式
結果
LOG(50)
1.69897000433602E+000
LOG(100)
2.00000000000000E+000
関連トピック
詳細は、以下を参照してください。
•
•
•
•
暗黙的な型の変換
SQL データ定義言語 - 構文規則および例、B035-1144
ユーティリティ 、B035-1102
SQL データ型とリテラル、B035-1143
NULLIFZERO
目的
ゼロによる除算の問題を避けるために、データをゼロから null に変換します。
構文
NULLIFZERO
( arg )
SQL 関数、演算子、式および述部
113
第 3 章 算術演算子/関数、三角関数、双曲線関数
NULLIFZERO
構文要素
arg
暗黙のタイプ変換規則に基づいて数値引数に変換される数値引数または引数。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
この関数の ANSI 形式は、CASE の簡略式である NULLIF です。詳細は、「NULLIF
式」を参照してください。
結果のタイプと属性
次の表に、NULLIFZERO の結果のデフォルト属性を示します。
• arg が数値である場合、データ型は arg と同じ型であり、形式は arg と同じ形式
です。
• arg が文字である場合、データ型は FLOAT であり、デフォルトの形式は FLOAT
です。
• arg が UDT である場合、データ型は UDT が暗黙的にキャストされる型であり、
形式は UDF が暗黙的にキャストされるデータ型の形式です。
注: NULL キーワードのデータ タイプは INTEGER です。
データ タイプ書式については、< SQL データ型とリテラル、B035-1143>を参照し
てください。
結果値
arg の値
NULLIFZERO から戻されるもの
非ゼロ
数値引数の値
NULL またはゼロ
NULL
引数のタイプと規則
arg は、数値でない場合は暗黙の型変換規則に基づいて数値に変換されます。引数を
変換できない場合は、エラーが戻されます。暗黙タイプ変換の詳細は、暗黙的な型
の変換を参照してください。
arg は文字列の場合は、FLOAT データ型の数値に変換されます。
arg が UDT である場合、以下のルールが適用されます。
• 以下のいずれかの事前定義タイプに対する暗黙 CAST が UDT になければなりませ
ん。
• 数値
• 文字
• DATE
114
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
NULLIFZERO
• 間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。CREATE CAST の詳細は、<SQL データ定義言
語 - 構文規則および例、B035-1144>を参照してください。
• NULLIFZERO を含め、システム演算子および関数用の UDT の暗黙の型変換は、
ANSI SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御
レコードの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定しま
す。詳細は、<ユーティリティ 、B035-1102>を参照してください。
次のタイプの引数に NULLIFZERO を適用することはできません。
• BYTE または VARBYTE
• BLOB または CLOB
• CHARACTER または VARCHAR (サーバーの文字セットが GRAPHIC の場合)
例
例: NULLIFZERO に対して返された式のエラー
次の式は、x または expression の値がゼロになるとエラーを戻します。
6 / x
6 / expression
一方、次の式は、null 戻します。ゼロによる除算の違反が生じていないため、これ
はエラーではありません。
6 / NULLIFZERO(x)
6 / NULLIFZERO(expression)
例: NULLIFZERO に対して返された要求のエラー
次の要求は、Newman の HCap フィールドの値がゼロであるため、2 番目の列に null
を戻します。BTEQ (フィールド モード)ではこれは「?」と表示されます。
SELECT empno, NULLIFZERO(hcap)
FROM employee
WHERE empno = 10019 ;
関連トピック
NULL の検査に関係するさらに別の式については、以下を参照してください。
• COALESCE 式
• NULLIF 式
• ZEROIFNULL
• 暗黙的な型の変換
• SQL データ定義言語 - 構文規則および例、B035-1144
• ユーティリティ 、B035-1102
• SQL データ型とリテラル、B035-1143
SQL 関数、演算子、式および述部
115
第 3 章 算術演算子/関数、三角関数、双曲線関数
POWER
POWER
目的
base_value の exponent_value 乗を返します。
構文
POWER
( base_value, exponent_value )
SYSLIB.
構文要素
SYSLIB
関数が格納されているデータベースの名前。
base_value
変換される数値式。
base_value が負の場合、exponent_value は整数にする必要があります。
任意の入力引数が NULL の場合、この関数は NULL を返します。
exponent_value
変換される数値式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
POWER は埋め込みサービス システム関数です 。埋め込みサービス関数の有効化と
呼び出しについて、詳細は埋め込みサービス システム関数 を参照してください。
引数のタイプと規則
この関数に渡される式には、次のいずれかのデータ タイプが含まれている必要があ
ります。
BYTEINT、SMALLINT、INTEGER、BIGINT、DECIMAL/NUMERIC、FLOAT/REAL/
DOUBLE PRECISION、または NUMBER
116
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
RANDOM
結果のタイプ
入力引数のどちらかが FLOAT タイプの場合、結果のデータ タイプは FLOAT になり
ます。それ以外の場合、結果のデータ タイプは NUMBER になります。
例: exponent_value の乗を返す問合わせ
例 1: exponent_value の乗。
以下の問合わせは結果として 8.0 を返します。
SELECT POWER(2, 3);
例 2:
以下の問合わせは結果として 0.125 を返します。
SELECT POWER(2, -3);
例 3:
以下の問合わせは結果として 10.648 を返します。
SELECT POWER(2.2, 3);
例 4:
次の問合わせは、エラーを返します。これは、基底値(base_value)が負であるのに
指数値(exponent_value)が整数でないためです。
SELECT POWER(-2.2, 3.1);
関連トピック
詳細は、以下を参照してください。
• 「埋め込みサービス システム関数 」
• SQL データ型とリテラル、B035-1143
RANDOM
目的
結果テーブルの各行について、整数の乱数を戻します。
構文
RANDOM
( lower_bound, upper_bound )
SQL 関数、演算子、式および述部
117
第 3 章 算術演算子/関数、三角関数、双曲線関数
RANDOM
構文要素
lower_bound
乱数を選択するための一定間隔の下限を定義する整数リテラル。
lower_bound の限度は、-2147483648~2147483647 の範囲です。
lower_bound は upper_bound 以下の値である必要があります。
upper_bound
乱数を選択するための一定間隔の上限を定義する整数リテラル。
upper_bound の限度は、-2147483648 以上、2147483647 以下の範囲です。
upper_bound は lower_bound 以上の値である必要があります。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果のタイプと属性
RANDOM(x,y)のデータ タイプ、書式、およびタイトルは、次のとおりです。
データ タイプ
書式
タイトル
INTEGER
INTEGER のデフォルト書式
Random(x,y)
デフォルトのデータ タイプ書式については、< SQL データ型とリテラル、B035-1143>
を参照してください。
計算
RANDOM は、線形一致アルゴリズムと 48 ビット整数計算を使用します。
このアルゴリズムは、48 ビット整数値のシーケンス(Xi)を生成することで機能します。
SELECT リスト内の複数 RANDOM 呼出し
SELECT リストでは、次のように RANDOM を何度でも呼び出すことができます。
SELECT RANDOM(1,100), RANDOM(1,100);
それぞれの呼出しで、新しい乱数値が定義されます。
制約事項
RANDOM 関数の使用については、以下の規則と制約が適用されます。
• RANDOM を呼び出せるのは、以下の SELECT 問合わせ句のいずれかにおいてのみ
です。
118
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
RANDOM
• WHERE
• GROUP BY
• ORDER BY
• HAVING/QUALIFY
• RANDOM は、GROUP BY 句や ORDER BY 句の中で位置による参照を行なえませ
ん。
• 集約内や順序付き分析関数内では RANDOM をネストすることはできません。
• INSERT 文中の式リストで RANDOM を使用して基本索引列またはパーティショ
ン列の値を作成することはできません。
以下に例を示します。
INSERT t1 (RANDOM(1,10),...)
テーブルの最初の列が基本索引列またはパーティション列の場合にこれを使用す
ると、RANDOM が原因でエラーになり、報告されます。
索引の条件としての RANDOM の使用
RANDOM 関数は選択された行ごとに評価されるため、索引列の条件として RANDOM
関数が組み込まれると、結果として全 AMP 操作になります。
たとえば、次のテーブル定義の場合を考えてみましょう。
CREATE TABLE t1
(c1 INTEGER
,c2 VARCHAR(9))
PRIMARY INDEX ( c1 );
次の SELECT 文は、結果として全 AMP 操作になります。
SELECT *
FROM t1
WHERE c1 = RANDOM(1,12);
例: 乱数の整数を結果として返す
sales_table という名前のテーブルに、以下のような列のサブセットがあるとします。
Store_ID
Product_ID
Sales
1003
C
20000
1002
C
35000
1001
C
60000
1002
D
50000
1003
D
50000
1001
D
35000
1001
A
100000
1002
A
40000
SQL 関数、演算子、式および述部
119
第 3 章 算術演算子/関数、三角関数、双曲線関数
RANGE_N
Store_ID
Product_ID
Sales
1001
E
30000
以下の SELECT 文は、結果行の各行ごとに 1~3 の範囲の乱数を戻します。
SELECT store_id, product_id, sales, RANDOM(1,3)
FROM sales_table;
結果テーブルは、たとえば以下のようなものになります。
Store_ID
Product_ID
Sales
RANDOM(1,3)
1003
C
20000
1
1002
C
35000
2
1001
C
60000
2
1002
D
50000
3
1003
D
50000
2
1001
D
35000
3
1001
A
100000
2
1002
A
40000
1
1001
E
30000
2
関連トピック
詳細は、以下を参照してください。
• SQL データ型とリテラル、B035-1143
RANGE_N
目的
式を評価して、指定範囲のリストのうちの 1 つに結果をマップしてから、リスト内
に範囲の位置を戻します。
120
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
RANGE_N
構文
RANGE_N
A
( test_expression
start_expression
*
A
BETWEEN
AND
end_expression
AND
*
end_expression
B
EACH
range_size
*
| range_list |
B
)
,
NO RANGE
OR UNKNOWN
, UNKNOWN
UNKNOWN
range_list
C
start_expression
AND
end_expression
AND
end_expression
EACH
range_size
*
D
C
,
start_expression
AND
D
,
start_expression
AND
end_expression
EACH
range_size
EACH
range_size
end_expression
*
構文要素
test_expression
BYTEINT、SMALLINT、INTEGER、DATE、CHAR、VARCHAR、GRAPHIC、または
VARGRAPHIC データ型となる式。
start_expression
*
範囲の開始境界を定義するリテラルまたはリテラル式。
start_expression のデータ型は test_expression のデータ型と同じにする必要があり
ます。または、test_expression と同じデータ型に暗黙的にキャストする必要があり
ます。
終了境界を指定しない場合、範囲はその開始境界(この境界は範囲に含まれます)か
ら次の範囲の開始境界(この境界は範囲に含まれません)までと定義されます。
リスト内の最初の範囲の開始境界にアスタリスク( * )を使用して、使用可能な最小
値(すべての値と NULL は、アスタリスクで指定された開始境界より大きくなりま
す)を示します。アスタリスクは、どのデータ タイプとも互換性があります。
SQL 関数、演算子、式および述部
121
第 3 章 算術演算子/関数、三角関数、双曲線関数
RANGE_N
end_expression
*
範囲の終了境界を定義するリテラルまたはリテラル式。
end_expression のデータ型は test_expression のデータ型と同じにする必要がありま
す。または、test_expression と同じデータ型に暗黙的にキャストする必要があります。
リスト内の最後の範囲では、終了境界を指定しなければなりません。それ以外の範
囲については、終了境界値を指定しない場合、範囲はその開始境界値から(この開始
境界値は範囲に含まれます)次の範囲の開始境界値まで(この開始境界値は範囲に含ま
れません)と定義されます。
リスト内の最後の範囲の終了境界にはアスタリスク( * )を使用して、使用可能な最大
値(すべての値と NULL は、アスタリスクで指定された終了境界より小さくなりま
す)を示します。
EACH range_size
値が 0 より大きいリテラルまたはリテラル式。
EACH 句を指定する範囲は一連の範囲に等しくなります。ここで、その一連の中の
最初の範囲は start_expression から始まり、それに続く範囲は start_expression +
(range_size * n)から始まります。ここで、n は 1 から始まり、start_expression +
(range_size * n)が end_expression 以下であるか、または範囲リスト内の次の
start_expression より小さい間は 1 つずつ増えます。
DATE タイプの場合、後続範囲内の有効な日付を計算する際には、+算術演算子では
なく ADD_MONTHS を使用します。
range_size のデータ型は、test_expression への追加のために互換性がなければなり
ません。
注: test_expression のデータ型が文字データ型(CHAR、VARCHAR、GRAPHIC、また
は VARGRAPHIC)の場合は、EACH 句を指定できません。
NO RANGE
どの指定範囲にもマップされない test_expression を処理する範囲。
OR UNKNOWN
NO RANGE とともに使用します。
どの指定範囲にもマップされない test_expression や、RANGE_N が範囲 BETWEEN
* AND *を指定しない場合に NULL と評価される test_expression は、NO RANGE OR
UNKNOWN が処理します。
UNKNOWN
RANGE_N が範囲 BETWEEN * AND *を指定しない場合に NULL と評価される
test_expression を処理します。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
122
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
RANGE_N
範囲の定義
範囲は、開始境界とオプションの終了境界で定義されます。終了境界を指定しない
場合の範囲は、その開始境界(この境界を含む)から次の範囲の開始境界(この境界を
含まない)までと定義されます。
範囲リストは範囲を昇順で指定しなければなりません。その範囲の終了境界は次の
範囲の開始境界の手前までとなります。
評価
RANGE_N は test_expression を評価して、結果が範囲リスト中の範囲内に収まるか
どうかを判断します。最初の範囲の位置は 1 になり、それに続く範囲の位置は n を
上限として 1 ずつ増加します。n は範囲の合計数です。
条件
結果
test_expression RANGE_N から範囲の位置が戻されます。
の結果は範囲内に
収まります
test_expression
の結果は NULL
です
RANGE_N に以下のうちの 1 つを指定しない場合。
• BETWEEN * AND *
• UNKNOWN
• NO RANGE OR UNKNOWN
RANGE_N は NULL を戻します。
RANGE_N に範囲 BETWEEN * AND *を指定した場合、NO RANGE、NO
RANGE OR UNKNOWN、UNKNOWN のどれを指定しても、RANGE_N は
1 を返します。
RANGE_N に範囲 BETWEEN * AND *を指定しない場合。
• NO RANGE OR UNKNOWN を指定した場合、RANGE_N は n + 1 を返
します。
• UNKNOWN を指定し、NO RANGE を指定しない場合、RANGE_N は
n + 1 を返します。
• NO RANGE と UNKNOWN を指定した場合、RANGE_N は n + 2 を返
します。
test_expression NO RANGE または NO RANGE OR UNKNOWN を指定した場合、
は、リスト内のど RANGE_N は n + 1 を返します。
の範囲からも外れ
NO RANGE も NO RANGE OR UNKNOWN も指定しない場合、RANGE_N
ています
は NULL を返します。
結果のタイプと属性
RANGE_N のデータ タイプ、書式、およびタイトルは、次のとおりです。
データ タイプ
書式
タイトル
INTEGER
INTEGER データ タイプのデフォルト書式
<RANGE_N 関数>
SQL 関数、演算子、式および述部
123
第 3 章 算術演算子/関数、三角関数、双曲線関数
RANGE_N
デフォルトのデータ タイプ書式については、< SQL データ型とリテラル、B035-1143>
を参照してください。
パーティション基本索引を定義するための RANGE_N の使用
テーブルの基本索引または結合索引は、各 AMP に対するそのテーブルのデータまた
は結合索引の分散およびその検索を制御します。基本索引がパーティション基本索
引(PPI)である場合、AMP 上のユーザー定義のパーティションに対してデータを割り
当てることができます。
テーブルの基本索引または結合索引を定義するには、PRIMARY INDEX 句を CREATE
TABLE または CREATE JOIN INDEX データ定義文に指定します。パーティション基
本索引を定義するには、基本索引の定義時に PARTITION BY 句を組み込みます。
PARTITION BY 句には、行のパーティション割り当てを決定する 1 つ以上のパーティ
ション化式が必要です。RANGE_N を使って、パーティション化列において何らかの
値または NULL をもつ行がいずれかのパーティションに割り当てられるようにパー
ティション化式を構築することができます。
また、CASE_N を使ってパーティション化列を構築することもできます 。詳細は、
CASE N を参照してください。
PARTITION BY 句がパーティション化式のリストを指定する場合、PPI はマルチレベ
ル PPI であり、1 つのレベルの各パーティションはリスト内の次のパーティション
化式に従ってサブパーティション化されます。有効な SQL 式(例外もあり)から成る
単一レベルの PPI のパーティション化式とは異なり、マルチレベル PPI のパーティ
ション化式のリスト内の各式は、CASE_N 関数または RANGE_N 関数でなければなり
ません。
CURRENT_DATE または CURRENT_TIMESTAMP を指定した RANGE_N を PPI で使用する
方法
ビルトイン関数の CURRENT_DATE または CURRENT_TIMESTAMP を指定した
RANGE_N を使用して、パーティション式を定義できます。データを 1 つ以上の現在
のパーティションと、1 つ以上の履歴のパーティションとしてパーティション化す
る必要があるときに、現在および履歴のパーティションが、パーティション式内で
解決される CURRENT_DATE または CURRENT_TIMESTAMP に基づく場合は、パー
ティション式内で CURRENT_DATE または CURRENT_TIMESTAMP を使用すること
が最適になります。これにより、ALTER TABLE DROP/ADD RANGE を実行する度に
決定しなければならない明示的な日付を使用したパーティションの再定義の代わり
に、古いデータを現在のパーティションから 1 つ以上の履歴のパーティションに移
動する、定期的なテーブルの調整が可能になります。
詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>の「更新可能日付
および更新可能タイムスタンプに基づく RANGE_N パーティション式の最適化を調
整するルール」を参照してください。
文字データを指定した RANGE_N の使用
RANGE_N 関数内では、test_expression や範囲の境界として、文字式(CHAR、
VARCHAR、GRAPHIC または VARGRAPHIC)を指定できます。適用される使用上の規
則は、次のとおりです。
124
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
RANGE_N
• RANGE_N パーティション式には、UPPERCASE 修飾子と、次に示す関数を使用
できます: LOWER、UPPER、TRANSLATE、TRIM、VARGRAPHIC、INDEX、
MINDEX、POSITION、TRANSLATE_CHK、CHAR2HEXINT。
• test_expression が文字データ型の場合は、EACH 句を指定できません。
• RANGE_N 式内で参照する文字列定数は、31,000 バイト未満にする必要がありま
す。
• test_expression が文字データ型であり、いずれかの範囲の境界の長さ(後続の埋
め込み文字を除く)が、test_expression の長さよりも長い場合、エラーが返され
ます。
• 文字の RANGE_N でパーティション化する場合は、範囲の昇順がセッションの照
合と、test_expression のケース指定によって異なります。例えば、
test_expression が、NOT CASESPECIFIC 式と、ケース指定修飾子
(CASESPECIFIC、NOT CASESPECIFIC)のないリテラルの組み合わせならば、ANSI
モードのセッションではケース指定が CASESPECIFIC になり、Teradata モードの
セッションでは NOT CASESPECIFIC になります。
注: グラフィック文字データが関与する文字列比較は、すべてケース指定になり
ます。
• 指定した範囲のいずれかが、NULL 境界で定義されていてる場合や、昇順になっ
ていない場合、または部分的に重なる場合には、エラーが返されます。文字のテ
スト値の昇順は、セッションの照合と、test_expression のケース指定によって異
なります。
• 列の参照とリテラルの大文字/小文字の区別は、セッションのデフォルト、明
示的な CAST、またはテーブルが作成されたときの CREATE TABLE 文の指定内
容によって決まります。列には CASESPECIFIC または NOT CASESPECIFIC を
明示的に指定できます。また、それらの修飾子で定数式を CAST できます。
明示的な指定がないときに、Teradata セッションのトランザクション セマン
ティクスが有効な場合には、NOT CASESPECIFIC が使用されます。ANSI セッ
ションのトランザクション セマンティクスが有効な場合には、CASESPECIFIC
がデフォルトになります。
例えば、条件式が、NOT CASESPECIFIC 式と、大文字/小文字の区別修飾子
(CASESPECIFIC、NOT CASESPECIFIC)のない定数の組み合わせならば、ANSI
モードのセッションでは大文字/小文字の区別が CASESENSITIVE になり、
Teradata モードのセッションでは CASEBLIND になります。
グラフィック データが関わる文字列比較では、すべて大文字と小文字が区別
されます。
• 文字比較演算子(=、<、>、<=、>=、<>、BETWEEN、LIKE)では、文字列定数が比
較対象の列データよりも短い場合、その文字列定数は埋め込み文字が埋め込まれ
ているものとして扱われます。埋め込み文字(例えば、<スペース> 文字)は、文字
セットに固有なものになります。そのため、文字の test_expression が、文字範
囲の境界よりも長い長さで定義されていると、その範囲の境界と test _expression
の比較は、範囲の境界が埋め込み文字で埋め込まれているものとして動作します。
埋め込み文字は、照合内の最小コード ポイントとして照合されないことがあり
ます。範囲の境界の長さが n の場合に、その範囲の境界と test_expression が最
初の n 文字まで完全に一致していても、n+1 の位置に埋め込み文字よりも小さく
照合される文字が含まれていると、その test_expression は範囲の境界よりも小
さいと照合されます。「例」を参照してください。
SQL 関数、演算子、式および述部
125
第 3 章 算術演算子/関数、三角関数、双曲線関数
RANGE_N
制約事項
RANGE_N が PARTITION BY 句で使用される場合、以下のような制限が適用されます。
• 最大 65,533 の範囲を指定できる(大きなパーティション化式の一部でない場合)。
• システム派生列の PARTITION または PARTITION#L1 から PARTITION#L15 を含
めてはいけません。
• PERIOD データ タイプを使用してはいけません。ただし、結果が DATE データ タ
イプになれば、BEGIN 境界関数または END 境界関数を PERIOD データ タイプの
列に対して使用することはできます。
RANGE_N がマルチレベル PPI のパーティション化式で使用される場合は、少なくと
も 2 つのパーティションを定義する必要があります。
パーティション式で RANGE_N が CURRENT_DATE または CURRENT_TIMESTAMP
を指定している場合は、ALTER TABLE を使用してテーブルの範囲を追加または削除
することはできません。この機能を実現するには、ALTER TABLE TO CURRENT 文を
使用する必要があります。
テスト式としての UDT の使用
test_expression は、結果が UDT データ型になる式であってはいけません。RANG_N
を使用して PPI を定義するときにこれが発生すると、エラーが報告されます。PPI
の定義に RANGE_N を使用しない場合は、暗黙の変換に頼らず、BYTEINT、
SMALLINT、INTEGER、DATE、CHAR、VARCHAR、GRAPHIC、または
VARGRAPHIC となるように、式を明示的にキャストしてください。
例
例 1: 行を割り当てることが可能な 4 つのパーティションの指定
以下は、RANGE_N と totalorders 列の値を使って行の割り当て先のパーティション
を定義する例です。
CREATE TABLE orders
(storeid INTEGER NOT NULL
,productid INTEGER NOT NULL
,orderdate DATE FORMAT 'yyyy-mm-dd' NOT NULL
,totalorders INTEGER)
PRIMARY INDEX (storeid, productid)
PARTITION BY RANGE_N(totalorders BETWEEN *, 100, 1000 AND *,
UNKNOWN);
この例では、RANGE_N は totalorders 列の値に基づいて、行の割り当て先となる 4
つのパーティションを指定します。
パーティ
条件
ション番号
126
1
totalorders 列の値は 100 より小さい。
2
totalorders 列の値は 1000 より小さいが、100 以上である。
3
totalorders 列の値は 1000 以上である。
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
RANGE_N
パーティ
条件
ション番号
4
totalorders 列は NULL であるため、範囲は UNKNOWN となります。
例 2: パーティション式のリストでの RANGE_N の使用
以下の例では、「例」を変更して、マルチレベル PPI を定義するパーティション化
式のリストで RANGE_N を使用しています。
CREATE TABLE orders
(storeid INTEGER NOT NULL
,productid INTEGER NOT NULL
,orderdate DATE FORMAT 'yyyy-mm-dd' NOT NULL
,totalorders INTEGER NOT NULL)
PRIMARY INDEX (storeid, productid)
PARTITION BY (RANGE_N(totalorders BETWEEN *, 100, 1000 AND *)
,RANGE_N(orderdate BETWEEN *, '2005-12-31' AND *) );
この例では、行が割り当てられる 6 つのパーティションが定義されています。最初
の RANGE_N 式は、totalorders 列の値に基づいて 3 つのパーティションを定義して
います。2 番目の RANGE_N 式は、orderdate 列の値に基づいて 3 つのパーティショ
ンをそれぞれ 2 つのパーティションに再分割しています。
レベル 1
パーティ
ション
番号
レベル 2 条件
パーティ
ション
番号
1
1
totalorders 列の値は 100 より小さく、orderdate 列の値は
'2005-12-31'より小さい。
2
totalorders 列の値は 100 より小さく、orderdate 列の値は
'2005-12-31'より大きいか等しい。
1
totalorders 列の値は 1000 より小さく、100 より大きいか等しい。
orderdate 列の値は'2005-12-31'より小さい。
2
totalorders 列の値は 1000 より小さく、100 より大きいか等しい。
orderdate 列の値は'2005-12-31'より大きいか等しい。
1
totalorders 列の値は 1000 より大きいか等しく、orderdate 列の値は
'2005-12-31'より小さい。
2
totalorders 列の値は 1000 より大きいか等しく、orderdate 列の値は
'2005-12-31'より大きいか等しい。
2
3
例 3: 1 つのパーティションを指定するパーティション基本索引の定義
以下に、NULL を含めた totalorders 列の任意の値について、行の割り当て先の 1 つ
のパーティションを指定するパーティション基本索引を定義する例を示します 。
CREATE TABLE orders
(storeid INTEGER NOT NULL
,productid INTEGER NOT NULL
,orderdate DATE FORMAT 'yyyy-mm-dd' NOT NULL
,totalorders INTEGER)
SQL 関数、演算子、式および述部
127
第 3 章 算術演算子/関数、三角関数、双曲線関数
RANGE_N
PRIMARY INDEX (storeid, productid)
PARTITION BY RANGE_N(totalorders BETWEEN * AND *);
例 4: RANGE_N 式を使ってテーブルがパーティション化されている場合の各パーティショ
ンの行数をカウントする
以下の例は、RANGE_N 式を使ってテーブルがパーティション化された場合の各パー
ティション内の行カウントを示します。
CREATE TABLE orders
(orderkey INTEGER NOT NULL
,custkey INTEGER
,orderdate DATE FORMAT 'yyyy-mm-dd')
PRIMARY INDEX (orderkey);
INSERT
INSERT
INSERT
INSERT
INSERT
INSERT
INSERT
INSERT
INSERT
INSERT
INTO
INTO
INTO
INTO
INTO
INTO
INTO
INTO
INTO
INTO
orders
orders
orders
orders
orders
orders
orders
orders
orders
orders
(1,
(2,
(3,
(4,
(5,
(6,
(7,
(8,
(9,
(10,
100,
100,
109,
101,
100,
109,
101,
101,
111,
111,
'1998-01-01');
'1998-04-01');
'1998-04-01');
'1998-04-10');
'1998-07-01');
'1998-07-10');
'1998-08-01');
'1998-12-01');
'1999-01-01');
NULL);
以下の SELECT 文中の RANGE_N 式は、EACH 句を使って一連の 12 個の範囲を定義
しています。ただし最初の範囲は'1998-01-01'から開始し、その後に続く範囲は、
1 ヶ月ずつの間隔で順番に増加し、開始境界を含みます。
SELECT COUNT(*),
RANGE_N(orderdate
BETWEEN DATE '1998-01-01' AND DATE '1998-12-31'
EACH INTERVAL '1' MONTH
) AS Partition_Number
FROM orders
GROUP BY Partition_Number
ORDER BY Partition_Number;
結果は次のようになります。
Count(*) Partition_Number
----------- ---------------2
?
1
1
3
4
2
7
1
8
1
12
例 5: RANGE_N 式を使ったテーブルのパーティション化
次の例では、パーティション化を指定してテーブルを作成します。このパーティショ
ン化の定義には、END 境界関数が関与する RANGE_N 式を使用します。テーブルに
128
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
RANGE_N
は、それぞれのパーティションが各年の販売履歴を表わす 10 個のパーティション
が作成されます。
CREATE TABLE SalesHistory
(product_code CHAR (8),
quantity_sold INTEGER,
transaction_period PERIOD (DATE))
PRIMARY INDEX (product_code)
PARTITION BY
RANGE_N (END (transaction_period) BETWEEN date'2006-01-01'
AND date '2015-12-31' EACH INTERVAL'1' YEAR);
次の SELECT 文は、2010 年よりも前の販売履歴の 5 つのパーティションをスキャ
ンします。
SELECT *
FROM SalesHistory
WHERE transaction_period < period (date'2010-01-01');
例 6: Start_expression と CURRENT_DATE
CURRENT_DATE または CURRENT_TIMESTAMP が、RANGE_N 内の最初の範囲で
ある start_expression に指定されている場合、CURRENT_DATE または
CURRENT_TIMESTAMP で改めて解決された start_expression がパーティション境
界と一致すると、一致したパーティションより前のすべてのパーティションが削除
されます。それ以外の場合は、新しいパーティション式でテーブル全体が再パーティ
ション化されます。
次の CREATE TABLE 文が、2006 年 4 月 1 日に実行されたとします。
CREATE TABLE ppi (i INT, j DATE)
PRIMARY INDEX (i)
PARTITION BY
RANGE_N (j BETWEEN CURRENT_DATE AND
CURRENT_DATE + INTERVAL '1' YEAR - INTERVAL '1' DAY
EACH INTERVAL '1' MONTH);
最後に解決された日付は、2006 年 4 月 1 日になります。ALTER TABLE TO
CURRENT 文を 2006 年 6 月 1 日に実行すると、start_expression は、改めて
CURRENT_DATE('2006-06-01')に解決されます。これは、3 番目のパーティション
境界と一致します。そのため、パーティション 1 と 2 は削除され、最後に調整され
た日付は、改めて解決された CURRENT_DATE に設定されます。
ただし、ALTER TABLE TO CURRENT 文を 2006 年 6 月 1 日ではなく、2006 年 6
月 10 日に実行したとすると、start_expression は改めて
CURRENT_DATE('2006-06-10')に解決され、パーティション境界と一致しなくなり
ます。そのため、すべての行がスキャンされ、それらの行は新しいパーティション
式に基づいて再パーティション化されます。この文の後のパーティション境界は、
それまでの月の最初の日ではなく、月の 10 日目に揃えられます。
例 7: 履歴を記録するためのテーブルのパーティション化
次のテーブル定義は、2007 年(この時点で、現在の年)に作成されています。テーブ
ルは、5 年間分の注文履歴と、現在および将来のそれぞれ 1 年分の注文を記録する
ためにパーティション化されます。
SQL 関数、演算子、式および述部
129
第 3 章 算術演算子/関数、三角関数、双曲線関数
RANGE_N
CREATE TABLE Orders
(o_orderkey INTEGER NOT NULL,
o_custkey INTEGER,
o_orderstatus CHAR(1) CASESPECIFIC,
o_totalprice DECIMAL(13,2) NOT NULL,
o_orderdate DATE FORMAT 'yyyy-mm-dd' NOT NULL,
o_orderpriority CHAR(21),
o_comment VARCHAR(79))
PRIMARY INDEX (o_orderkey)
PARTITION BY RANGE_N(
o_orderdate BETWEEN DATE '2002-01-01' AND DATE '2008-12-31'
EACH INTERVAL '1' MONTH)
UNIQUE INDEX (o_orderkey);
2008 年に、以前と同じように、5 年間分の履歴と、現在および将来のそれぞれ 1 年
間分の記録を保守するためにテーブルを変更しようと考えたときには、次の文を
2008 年に実行します。
ALTER TABLE Orders MODIFY PRIMARY INDEX (o_orderkey)
DROP RANGE WHERE PARTITION BETWEEN 1 AND 12
ADD RANGE BETWEEN DATE '2009-01-01' AND DATE '2009-12-31'
EACH INTERVAL '1' MONTH
WITH DELETE;
この場合、新しい日付を計算して、その日付を明示的に ADD RANGE 句に指定する
必要があります。これでは、この文を実行する年ごとに手動の介入が必要になって
しまいます。
それとは別に、CURRENT_DATE を使用して、次に示すようにテーブルを定義できま
す。これにより、パーティションの変更が容易になります。
CREATE TABLE Orders
(o_orderkey INTEGER NOT NULL,
o_custkey INTEGER,
o_orderstatus CHAR(1) CASESPECIFIC,
o_totalprice DECIMAL(13,2) NOT NULL,
o_orderdate DATE FORMAT 'yyyy-mm-dd' NOT NULL,
o_orderpriority CHAR(21),
o_comment VARCHAR(79))
PRIMARY INDEX (o_orderkey)
PARTITION BY RANGE_N(o_orderdate BETWEEN
CAST(((EXTRACT(YEAR FROM CURRENT_DATE)-5-1900)*10000+0101) AS DATE)
AND
CAST(((EXTRACT(YEAR FROM CURRENT_DATE)+1-1900)*10000+1231) AS DATE)
EACH INTERVAL '1' MONTH)
UNIQUE INDEX (o_orderkey);
次の ALTER TABLE 文を毎年実行するように、スケジュールすることができます。こ
の文は、パーティションの削除と追加を効率的に実行して、パーティションのウィ
ンドウを前方に進めます。
ALTER TABLE Orders TO CURRENT WITH DELETE;
CURRENT_DATE を使用することで、新しい日付に基づいてデータを再パーティショ
ン化しようとしたときに、ALTER TABLE 文を毎回修正する必要がなくなります。
130
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
RANGE_N
どちらの場合も、年境界でパーティション化が開始されます。最初の例では、これ
を ALTER TABLE 文が変更することはありません。そのため、パーティション化は
年境界で開始され続けます。ただし、別の境界で開始するようにパーティション化
を変更する、ALTER TABLE 文の指定は可能です。たとえば、ALTER TABLE 文に希
望の日付を指定すると、ある年の特定の月に開始するようにロール フォワードでき
ます。
CURRENT_DATE を使用する 2 番目の例では、年境界で開始するロール フォワード
のみ可能です。ただし、この例を変更すると、月初めに開始するロール フォワード
にパーティション化を使用できるようになります。この例では、CREATE TABLE の
日付を起点として、Orders テーブルに過去 71 カ月分の履歴と、今月および将来の
12 カ月分(合計 84 カ月)の記録を格納することを想定しています。
CREATE TABLE Orders
(o_orderkey INTEGER NOT NULL,
o_custkey INTEGER,
o_orderstatus CHAR(1) CASESPECIFIC,
o_totalprice DECIMAL(13,2) NOT NULL,
o_orderdate DATE FORMAT 'yyyy-mm-dd' NOT NULL,
o_orderpriority CHAR(21),
o_comment VARCHAR(79))
PRIMARY INDEX (o_orderkey)
PARTITION BY RANGE_N(o_orderdate BETWEEN
CAST(((EXTRACT(YEAR FROM CURRENT_DATE)-1900)*10000 +
EXTRACT(MONTH FROM CURRENT_DATE)*100 + 01) AS DATE) INTERVAL '71' MONTH
AND
CAST(((EXTRACT(YEAR FROM CURRENT_DATE)+1-1900)*10000 +
EXTRACT(MONTH FROM CURRENT_DATE)*100 + 01) AS DATE)+
INTERVAL '13' MONTH - INTERVAL '1' DAY
EACH INTERVAL '1' MONTH)
UNIQUE INDEX (o_orderkey);
次の ALTER TABLE 文を、毎月またはそれより少ない(ただし、将来の月を越えな
い)頻度で実行するようにスケジュールできます。この文は、Orders テーブルに過
去 71 カ月の履歴と、現在の月、将来の 12 カ月の記録が含まれ続けるように、パー
ティションの削除と追加を実行してパーティションのウィンドウを先に進めます 。
ALTER TABLE Orders TO CURRENT WITH DELETE;
次に示す、より単純なパーティション化を定義できますが、これは最適化されない
ことがあり、ALTER TABLE TO CURRENT 文を実行すると、調整のためにテーブル
全体がスキャンされる可能性があります。この例では、CREATE TABLE の日付を起
点として、Orders テーブルには約 2,191 日分の履歴と、今日と将来の 356 日分(合
計、約 7 年)の記録を格納することを想定しています。
CREATE TABLE Orders
(o_orderkey INTEGER NOT NULL,
o_custkey INTEGER,
o_orderstatus CHAR(1) CASESPECIFIC,
o_totalprice DECIMAL(13,2) NOT NULL,
o_orderdate DATE FORMAT 'yyyy-mm-dd' NOT NULL,
o_orderpriority CHAR(21),
o_comment VARCHAR(79))
PRIMARY INDEX (o_orderkey)
SQL 関数、演算子、式および述部
131
第 3 章 算術演算子/関数、三角関数、双曲線関数
RANGE_N
PARTITION BY RANGE_N(o_orderdate BETWEEN
CURRENT_DATE - INTERVAL '6' YEAR
AND
CURRENT_DATE + INTERVAL '1' YEAR
EACH INTERVAL '1' MONTH)
UNIQUE INDEX (o_orderkey);
次の ALTER TABLE 文を、毎日またはそれより少ない(ただし、将来の日を越えない)
頻度で実行するようにスケジュールできます。この文は、CURRENT_DATE と、最後
に CREATE TABLE または ALTER TABLE TO CURRENT 文が実行された日付が同じ場
合にのみ、パーティションの削除と追加を実行してパーティションのウィンドウを
前進させます。それ以外の場合は、行を調整するために、テーブル全体がスキャン
されます。
ALTER TABLE Orders TO CURRENT WITH DELETE;
これは、最後に CREATE TABLE または ALTER TABLE TO CURRENT 文が実行された
日とは違う日に ALTER TABLE 文が実行された場合に、効率が非常に悪化することが
あります。パフォーマンスは、最後に解決された日付と改めて解決された日付の間
の日数が増えるほど悪化します。その理由は、移動しなければならない行の数が増
えるためです。
たとえば、最後に解決された日付が 2008 年 1 月 1 日で、その後の 2008 年 2 月 2
日に ALTER TABLE TO CURRENT 文が実行されたとすると、テーブル内のすべての
行が新しいパーティションに移動されることになります。
例 8: 範囲の定義
次の例では、5 つの範囲を定義しています。セッションの照合は ASCII です。
RANGE_N(animal BETWEEN *, 'ape', 'bird', 'bull' AND 'cow',
'dog' AND *, NO RANGE, UNKNOWN)
説明:
Range
Includes...
1
'ape'より小さいすべての値。
2
'ape'以上'bird'未満の文字列。
3
'bird'以上'bull'未満の文字列。
4
'bull'と'cow'の間の文字列。
5
'dog'以上の文字列。
animal の値が定義した範囲のいずれかと一致すると、RANGE_N は一致した範囲の
番号を返します。
animal の値が、'cow'より大きく'dog'よりも小さい場合には、どの範囲にも一致しま
せんが、NO RANGE が指定されているため、RANGE_N は 6 を返します。
animal の値が NULL の場合には、UNKNOWN が指定されているため、RANGE_N は
7 を返します。
例 9: 5 つの範囲の定義
次の例では、5 つの範囲を定義しています。セッションの照合は ASCII です。
132
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
RANGE_N
RANGE_N(animal BETWEEN *, 'ape', 'bird', 'bull' AND 'cow',
'dog' AND *, UNKNOWN)
説明:
Range
Includes...
1
'ape'より小さいすべての値。
2
'ape'以上'bird'未満の文字列。
3
'bird'以上'bull'未満の文字列。
4
'bull'と'cow'の間の文字列。
5
'dog'以上の文字列。
animal の値が定義した範囲のいずれかと一致すると、RANGE_N は一致した範囲の
番号を返します。
animal の値が、'cow'より大きく'dog'よりも小さい場合には、どの範囲にも一致し
ません。この場合、NO RANGE が指定されていないため、RANGE_N は NULL を返
します。
animal の値が NULL の場合には、UNKNOWN が指定されているため、RANGE_N は
6 を返します。
例 10: 2 つの範囲の定義
この例では、CREATE TABLE 文を実行しているときのセッションの照合は ASCII で
す。また、埋め込み文字は<スペース>です。この例では、2 つの範囲を定義してい
ます(番号 1 と 2)。
• 'a
'(a の後ろに 9 個のスペース)以上'b
'未満の値はパーティション 1 に
マップされます。
• 'b
'以上'c
'未満の値は、パーティション 2 にマップされます。
CREATE SET TABLE t2
(a VARCHAR(10) CHARACTER SET UNICODE NOT CASESPECIFIC,
b INTEGER)
PRIMARY INDEX (a)
PARTITION BY RANGE_N(a BETWEEN 'a','b' AND 'c');
以下の INSERT 文では、'b'と'1'の間に 1 つの<tab>文字が入る文字列を挿入します。
INSERT t2 ('b
1', 1);
以下の INSERT 文では、'b'と'1'の間に 1 つの<space>文字が入る文字列を挿入します。
INSERT t2 ('b 1', 2);
以下の SELECT 文は、INSERT 文の結果を示します。タブ文字はスペース文字よりも
コード ポイントが小さいため、最初に挿入された文字列はパーティション 1 にマッ
プされます。
SELECT PARTITION, a, b FROM t2 ORDER BY 1;
*** Query completed. 2 rows found. 3 columns returned.
*** Total elapsed time was 1 second.
PARTITION a
b
----------- ------ -----
SQL 関数、演算子、式および述部
133
第 3 章 算術演算子/関数、三角関数、双曲線関数
ROUND
1
2
b 1
b 1
1
2
(string contains single <tab> character)
(string contains single <space> character)
関連トピック
詳細は、以下を参照してください。
• PPI のプロパティとパフォーマンスに関する考慮事項 、または PPI の考慮事項と
容量に関する計画の詳細については、<データベース設計、B035-1094>を参照し
てください。
• テーブルの PPI の指定の詳細については、<SQL データ定義言語 - 構文規則および
例、B035-1144>の「CREATE TABLE」を参照してください。
• 結合索引の PPI の指定の詳細については、<SQL データ定義言語 - 構文規則および
例、B035-1144>の「CREATE JOIN INDEX」を参照してください。
• テーブルの基本索引のパーティションの修正の詳細については 、<SQL データ定
義言語 - 構文規則および例、B035-1144>の「ALTER TABLE」を参照してください。
• 新規に解決された CURRENT_DATE 値と、CURRENT_TIMESTAMP 値に基づいた
パーティション化の調整の詳細については、<SQL データ定義言語 - 構文規則およ
び例、B035-1144>の「ALTER TABLE TO CURRENT」を参照してください。
• ADD_MONTHS について、詳細は ADD_MONTHS を参照してください。
ROUND
目的
小数点の右側または左側の桁位置 places_value で丸められた numeric_value を返し
ます。
構文
ROUND
( numeric_value
TD_SYSFNLIB.
)
, places_value
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
numeric_value
変換される数値式。
places_value
丸める桁位置。指定されていない場合、numeric_value は桁位置 0 で丸められます
(デフォルト)。
134
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
ROUND
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
ROUND は埋め込みサービス システム関数です 。埋め込みサービス関数の有効化と
呼び出しについて、詳細は埋め込みサービス システム関数 を参照してください。
引数のタイプと規則
この関数に渡された式は、次のデータ タイプを持っている必要があります。
• numeric_value = BYTEINT、SMALLINT、INTEGER、BIGINT、DECIMAL/
NUMERIC、FLOAT/REAL/DOUBLE PRECISION、または NUMBER
• places_value = NUMBER
places_value 引数では、UDF に適用される暗黙のデータ型変換規則を使用して
INTEGER に変換できるデータ型の値も渡すことができます。numeric_value 引数に
ついては、暗黙の型変換はサポートされていません。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
詳細については、<SQL 外部ルーチン プログラミング、B035-1147>の「互換デー
タ型」を参照してください。
結果のタイプ
結果のデータ型は、numeric_value 引数のデータ型と同じになります。
numeric_value のデータ型が DECIMAL/NUMERIC で精度が 38 未満の場合、返され
る DECIMAL/NUMERIC 値の精度は 1 だけ増分されます。例えば、DECIMAL(6,4)の
引数は DECIMAL(7,4)として返されます。精度が 38 の場合は、スケールが 1 だけ減
分されます(スケールが 0 でない場合)。例えば、DECIMAL(38,38)の引数は
DECIMAL(38,37)として返されます。
デフォルトのデータ タイプ書式については、< SQL データ型とリテラル、
B035-1143>を参照してください。
使用上の注意
ROUND は次のように機能します。
places_value が正の場合、小数点の右側の桁位置 places_value で丸めます。
places_value が負の場合、小数点の左側の桁位置 places_value で丸めます。
places_value がゼロまたは省略されている場合、桁位置 0 で丸めます。
numeric_value または places_value が NULL の場合、この関数は NULL を返しま
す。
• ROUND は、ゼロから進めた先の桁の値を、その次の桁の値が 5 以上のときに切
り上げます。
•
•
•
•
SQL 関数、演算子、式および述部
135
第 3 章 算術演算子/関数、三角関数、双曲線関数
ROUND
注: 丸めの動作は、常に上記の公式に従います。これは、DBS 制御レコードの
RoundHalfWayMagUp フィールドには影響されません。つまり、丸めの動作は、
RoundHalfWayMagUp フィールドが常に TRUE に設定されているものとして機能す
るということです。
例
例 1: 結果 32.4000 を返す問合わせを行なう
以下の問合わせは結果として 32.4000 を返します。
SELECT ROUND(32.4467, 1);
例 2: 結果 32.4600 を返す問合わせを行なう
以下の問合わせは結果として 32.4600 を返します。
SELECT ROUND(32.4567, 2);
例 3: 結果 100.0000 を返す問合わせを行なう
以下の問合わせは結果として 100.0000 を返します。
SELECT ROUND(99.9999, 3);
例 4: 結果 30.0000 を返す問合わせを行なう
以下の問合わせは結果として 30.0000 を返します。
SELECT ROUND(32.4567, -1);
例 5: 結果 100.0000 を返す問合わせを行なう
以下の問合わせは結果として 100.0000 を返します。
SELECT ROUND(55.4567, -2);
例 6: 結果 0.0000 を返す問合わせを行なう
以下の問合わせは結果として 0.0000 を返します。
SELECT ROUND(55.4567, -3);
例 7: 結果-5.00 を返す問合わせを行なう
以下の問合わせは結果として-5.00 を返します。
SELECT ROUND(-5.35, 0);
例 8: 結果-6.00 を返す問合わせを行なう
以下の問合わせは結果として-6.00 を返します。
SELECT ROUND(-5.55, 0);
136
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
SIGN
関連トピック
詳細は、以下を参照してください。
•
•
•
•
SQL 外部ルーチン プログラミング、B035-1147
「埋め込みサービス システム関数 」
SQL データ型とリテラル、B035-1143
SQL 外部ルーチン プログラミング、B035-1147
SIGN
目的
numeric_value の符号を返します。
構文
SIGN
( numeric_value )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
numeric_value
変換される数値式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
SIGN は埋め込みサービス システム関数です 。埋め込みサービス関数の有効化と呼
び出しについて、詳細は埋め込みサービス システム関数 を参照してください。
引数のタイプと規則
この関数に渡される式には、次のいずれかのデータ タイプが含まれている必要があ
ります。
BYTEINT、SMALLINT、INTEGER、BIGINT、DECIMAL/NUMERIC、FLOAT/REAL/
DOUBLE PRECISION、または NUMBER
SQL 関数、演算子、式および述部
137
第 3 章 算術演算子/関数、三角関数、双曲線関数
SIGN
結果のタイプ
結果のデータ タイプは NUMBER です。
NUMBER の、デフォルトのデータ タイプ書式については、< SQL データ型とリテラ
ル、B035-1143>を参照してください。
使用上の注意
FLOAT/REAL/DOUBLE PRECISION 以外の数値タイプの場合、SIGN は以下を返しま
す。
• numeric_value が< 0 の場合、-1 が返されます。
• numeric_value = 0 の場合は、0 が返されます。
• numeric_value が >0 の場合、1 が返されます。
FLOAT/REAL/DOUBLE PRECISION の場合、SIGN は以下を返します。
• numeric_value が< 0 の場合、-1 が返されます。
• numeric_value が>= 0 の場合、1 が返されます。
入力引数が NULL の場合、この関数は NULL を返します。
例
例 1: SELECT SIGN(-2);の問合わせ
以下の問合わせは結果として-1 を返します。
SELECT SIGN(-2);
例 2: 値が整数で 0 に等しい場合の結果の問合わせ
次の問合わせは、結果 0 を返します。これは、値が整数であり 0 と等しいためです。
SELECT SIGN(CAST(0 AS INTEGER));
例 3: データ型が FLOAT で値が 0 以上の場合の結果の問合わせ
次の問合わせは結果 1 を返します。これは、データ型が FLOAT であり、値が 0 以上
だからです。
SELECT SIGN(CAST(0 as FLOAT));
例 4: SELECT SIGN(3.74);の問合わせ
以下の問合わせは結果として 1 を返します。
SELECT SIGN(3.74);
関連トピック
詳細は、以下を参照してください。
• 「埋め込みサービス システム関数 」
138
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
SQRT
• SQL データ型とリテラル、B035-1143
SQRT
目的
引数の平方根を計算します。
構文
SQRT
( arg )
構文要素
arg
正数、数値引数。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果のタイプと属性
SQRT(arg)のデータ タイプ、書式、およびタイトルは、次のとおりです。
データ タイプ
書式
タイトル
FLOAT
FLOAT のデフォルト書式
SQRT(arg)
引数のタイプと規則
arg は、FLOAT でない場合は暗黙の型変換規則に基づいて FLOAT に変換されます。
引数を変換できない場合は、エラーが戻されます。暗黙タイプ変換の詳細は、暗黙
的な型の変換を参照してください。
arg が UDT である場合、以下のルールが適用されます。
• 以下のいずれかの事前定義タイプに対する暗黙 CAST が UDT になければなりま
せん。
• 数値
• 文字
• DATE
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。CREATE CAST の詳細は、<SQL データ定義言
語 - 構文規則および例、B035-1144>を参照してください。
• SQRT を含め、システム演算子および関数用の UDT の暗黙の型変換は、ANSI SQL
規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レコード
SQL 関数、演算子、式および述部
139
第 3 章 算術演算子/関数、三角関数、双曲線関数
TRUNC
の DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳細
は、<ユーティリティ 、B035-1102>を参照してください。
次のタイプの引数に SQRT を適用することはできません。
• BYTE または VARBYTE
• BLOB または CLOB
• CHARACTER または VARCHAR (サーバーの文字セットが GRAPHIC の場合)
例: 典型的な SQRT 算術関数式
主な SQRT 算術関数式とその結果の例を次に示します。
式
結果
SQRT(2)
1.41421356237309E+000
SQRT(-2)
エラー
関連トピック
詳細は、以下を参照してください。
•
•
•
•
「暗黙的な型の変換」
SQL データ定義言語 - 構文規則および例、B035-1144
ユーティリティ 、B035-1102
SQL データ型とリテラル、B035-1143
TRUNC
目的
小数点の右側または左側の桁位置 places_value で切り捨てられた numeric_value を
返します。
構文
TRUNC
( numeric_value
TD_SYSFNLIB.
)
, places_value
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
numeric_value
変換される数値式。
140
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
TRUNC
places_value
切り捨てる桁位置。指定されていない場合、numeric_value は桁位置 0 で切り捨て
られます(デフォルト)。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
TRUNC は埋め込みサービス システム関数です 。埋め込みサービス関数の有効化と
呼び出しについて、詳細は埋め込みサービス システム関数 を参照してください。
引数のタイプと規則
この関数に渡された式は、次のデータ タイプを持っている必要があります。
• numeric_value = BYTEINT、SMALLINT、INTEGER、BIGINT、DECIMAL/
NUMERIC、FLOAT/REAL/DOUBLE PRECISION、または NUMBER
• places_value = NUMBER
places_value 引数では、UDF に適用される暗黙のデータ型変換規則を使用して
INTEGER に変換できるデータ型の値も渡すことができます。numeric_value 引数に
ついては、暗黙の型変換はサポートされていません。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
詳細については、<SQL 外部ルーチン プログラミング、B035-1147>の「互換デー
タ型」を参照してください。
結果のタイプ
結果のデータ型は、numeric_value 引数のデータ型と同じになります。例えば、
numeric_value のデータ型が DECIMAL/NUMERIC の場合、返されるタイプは、引数
numeric_value と同じ精度とスケールを持つ DECIMAL/NUMERIC になります。
デフォルトのデータ タイプ書式については、< SQL データ型とリテラル、
B035-1143>を参照してください。
使用上の注意
TRUNC は次のように機能します。
• places_value が正の場合、小数点の右側の桁位置 places_value で切り捨てます。
• places_value が負の場合、小数点の左側の桁位置 places_value で切り捨てます(0
にします)。
• places_value がゼロまたは省略されている場合、桁位置 0 で切り捨てます。
SQL 関数、演算子、式および述部
141
第 3 章 算術演算子/関数、三角関数、双曲線関数
WIDTH BUCKET
• numeric_value または places_value が NULL の場合、この関数は NULL を返しま
す。
例: 問合わせにより、SELECT TRUNC を返す
以下の問合わせは結果として 32.4500 を返します。
SELECT TRUNC(32.4567, 2);
以下の問合わせは結果として 30.0000 を返します。
SELECT TRUNC(32.4567, -1);
関連トピック
詳細は、以下を参照してください。
• SQL 外部ルーチン プログラミング、B035-1147
• 「埋め込みサービス システム関数 」
• SQL データ型とリテラル、B035-1143
WIDTH BUCKET
目的
value_expression が割り当てられるパーティションの番号を戻します。
構文
WIDTH BUCKET
( value_expression, lower_bound, upper_bound, partition_count )
構文要素
value_expression
パーティション番号が返される値。
lower_bound
等しくパーティション化される値の範囲の下限。
upper_bound
等しくパーティション化される値の範囲の上限。
partition_count
作成されるパーティションの数。
この値はデフォルトでパーティションの幅も指定します。
142
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
WIDTH BUCKET
作成されるパーティション数は partition_count + 2 となります。パーティション 0
とパーティション partition_count + 1 は、上限と下限内に収まらない
value_expression の値になります。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果のタイプと属性
WIDTH_BUCKET(x、l、u、y)のデータ タイプ、書式、およびタイトルは、次のよう
になります。
データ タイプ
書式
タイトル
INTEGER
INTEGER のデフォルト書式
Width_bucket(x, l, u, y)
引数のタイプと規則
WIDTH_BUCKET 引数に関する規則については、以下の表を参考にしてください。
データ タイプ
規則
数値
WIDTH_BUCKET では、引数として任意の数値データ
タイプを使用できます。引数 value_expression、
lower_bound、および upper_bound は、REAL に変換
されてから処理されます。partition_count 引数は、
INTEGER に変換されてから処理されます。
文字
WIDTH_BUCKET では、数値を表わす文字列を使用す
ることができ、その文字列は該当する数値タイプに変
換されます。
• TIME、TIMESTAMP または
PERIOD
• INTERVAL
• BYTE または VARBYTE
• BLOB または CLOB
• CHARACTER または VARCHAR
(サーバーの文字セットが
GRAPHIC の場合)
WIDTH_BUCKET では、これらのタイプの引数を使用
できません。
UDT
• 以下のいずれかの事前定義タイプに対する暗黙
CAST が UDT になければなりません。
数値
文字
DATE
SQL 関数、演算子、式および述部
143
第 3 章 算術演算子/関数、三角関数、双曲線関数
WIDTH BUCKET
データ タイプ
規則
UDT 用の暗黙 CAST を定義するには、CREATE
CAST 文を使用し、AS ASSIGNMENT 節を指定しま
す。CREATE CAST の詳細は、< SQL データ型とリ
テラル、B035-1143>を参照してください。
• WIDTH_BUCKET を含め、システム演算子および関
数用の UDT の暗黙の型変換は、ANSI SQL 規格の
Teradata 拡張機能です。この拡張を無効にするに
は、DBS 制御レコードの
DisableUDTImplCastForSysFuncOp フィールドを
TRUE に設定します。詳細は、<ユーティリティ 、
B035-1102>を参照してください。
引数を妥当なタイプに暗黙変換できない場合は、エラーが戻されます。暗黙タイプ
変換の詳細は、暗黙的な型の変換を参照してください。
規則
WIDTH_BUCKET には次の規則が適用されます。
• いずれかの引数が NULL の場合、結果も NULL になります。
• partition_count <=0、または partition_count > 2147483646 の場合、要求元にエ
ラーが戻されます。
• lower_bound = upper_bound の場合、要求元にエラーが戻されます。
• lower_bound < upper_bound の場合、以下の表の規則が適用されます。
条件
結果
value_expression < 0。
lower_bound
value_expression >= partition_count +1。
upper_bound
結果に指定されたデータ タイプでは結果を表現できない場合、エ
ラーが戻されます。
その他
以下の式以下になる最大の正確な数値。位取りは 0 です。
• lower_bound > upper_bound の場合、以下の表の規則が適用されます。
条件
結果
value_expression > 0.
lower_bound
value_expression <= partition_count +1。
upper_bound
結果に指定されたデータ タイプでは結果を表現できない場合、エ
ラーが戻されます。
その他
144
以下の式以下になる最小の正確な数値。位取りは 0 です。
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
WIDTH BUCKET
条件
結果
例: 範囲内における従業員の給与を示すヒストグラムの作成
給与が$70000 から$200000 の範囲の従業員すべての給与のヒストグラムを作成す
るとします。指定された範囲内の各パーティション(バケット)の幅は$32500 にな
ります。
従業員の給与テーブルに記録されている従業員は 8 人です。
salary
-------50000
150000
220000
199999
70000
70000
70000
120000
first_name
-----------William
Todd
Bob
Donald
Betty
James
Mary
Mary
last_name
----------Crawford
Crawford
Stone
Stone
Crawford
Crawford
Lee
Stone
次の SELECT 文を実行します。
SELECT salary, WIDTH_BUCKET(salary,70000,200000,4),COUNT(salary)
FROM emp_salary
GROUP BY 1
ORDER BY 1;
この文によって作成されるレポートは次のようになります。
salary
-------50000
70000
120000
150000
199999
220000
Width_bucket(salary,70000,200000,4)
-----------------------------------0
1
2
3
4
5
Count(salary)
---------------1
3
1
1
1
1
関連トピック
詳細は、以下を参照してください。
•
•
•
•
ユーティリティ 、B035-1102
「暗黙的な型の変換」
SQL データ定義言語 - 構文規則および例、B035-1144
SQL データ型とリテラル、B035-1143
SQL 関数、演算子、式および述部
145
第 3 章 算術演算子/関数、三角関数、双曲線関数
ZEROIFNULL
ZEROIFNULL
目的
NULL 結果が原因でエラーにならないように、データを NULL からゼロに変換します。
構文
ZEROIFNULL
( arg )
構文要素
arg
変換される数値式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果のタイプと属性
次の表に、ZEROIFNULL の結果のデフォルト属性を示します。
• オペランドが数値である場合、書式は arg と同じ書式です。
• オペランドが文字である場合、書式は FLOAT のデフォルトの書式です。
• オペランドが UDT である場合、書式は UDT の暗黙キャスト先の事前定義タイプ
の書式です。
注: NULL キーワードのデータ タイプは INTEGER です。
引数のタイプと規則
arg の値
ZEROIFNULL から戻されるもの
非 null
数値引数の値
null またはゼロ
ゼロ
注: STRUCTURED 型 UDT 列の値が NULL
になるのは、NULL に設定された属性を
STRUCTURED 型 UDT インスタンスが持っ
ている場合ではなく、その列に明示的に
NULL を入れた場合だけです。
引数は、数値でない場合は暗黙のタイプ変換規則に従って数値に変換されます。引
数を変換できない場合は、エラーが戻されます。暗黙タイプ変換の詳細は、暗黙的
な型の変換を参照してください。
arg は文字列の場合は、FLOAT データ型の数値に変換されます。
146
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
TRIGONOMETRIC
arg が UDT である場合、以下のルールが適用されます。
• 以下のいずれかの事前定義タイプに対する暗黙 CAST が UDT になければなりま
せん。
• 数値
• 文字
• DATE
• 間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。CREATE CAST の詳細は、<SQL データ定義言
語 - 構文規則および例、B035-1144>を参照してください。
• ZEROIFNULL を含め、システム演算子および関数用の UDT の暗黙の型変換は、
ANSI SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御
レコードの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定しま
す。詳細は、<ユーティリティ 、B035-1102>を参照してください。
次のタイプの引数に ZEROIFNULL を適用することはできません。
• BYTE または VARBYTE
• BLOB または CLOB
• CHARACTER または VARCHAR (サーバーの文字セットが GRAPHIC の場合)
例: Salary 列が Null かどうかのテスト
この例では、Salary 列が null かどうかをテストすることができます。
SELECT empno, ZEROIFNULL(salary)
FROM employee ;
ゼロ以外の値が各従業員番号ごとに戻され、Salary 列には null が存在しないことを
示します。
関連トピック
NULL の検査に関係するさらに別の式については、以下を参照してください。
•
•
•
•
•
•
•
COALESCE 式
NULLIF 式
「NULLIFZERO」
SQL データ型とリテラル、B035-1143
ユーティリティ 、B035-1102
SQL データ定義言語 - 構文規則および例、B035-1144
暗黙的な型の変換
TRIGONOMETRIC
目的
引数の三角関数または逆三角関数を実行します。
SQL 関数、演算子、式および述部
147
第 3 章 算術演算子/関数、三角関数、双曲線関数
TRIGONOMETRIC
構文
COS
( arg )
SIN
TAN
ACOS
ASIN
ATAN
ATAN2
( x, y )
構文要素
arg
ラジアン単位で角を表わす任意の有効な数値式。
x
逆正接計算で使用する点の x 座標。
y
逆正接計算で使用する点の y 座標。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
定義
148
関数
定義
逆余弦
逆余弦は、余弦が引数になる角のことです。
逆正弦
逆正弦は、正弦が引数になる角のことです。
逆正接
逆正接は、正接が引数になる角のことです。
余弦
角の余弦は、直角の 2 辺の比になります。この比は、角に接する辺の長さを斜
辺の長さで割ったものです。
正弦
角の正弦は、直角の 2 辺の比になります。この比は、角の対面にある辺の長さ
を斜辺の長さで割ったものです。
正接
角の正接は、直角の 2 辺の比になります。この比は、角の対面にある辺の長さ
を角に接する辺の長さで割ったものです。
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
TRIGONOMETRIC
結果のタイプと属性
次の表に、三角関数および逆三角関数の結果のデフォルトのデータ タイプ、書式、
およびタイトルを示します。
データ タイプ
書式
タイトル
FLOAT
FLOAT のデフォルト書式
Cos(arg)
Sin(arg)
Tan(arg)
ArcCos(arg)
ArcSin(arg)
ArcTan(arg)
Atan2(x,y)
デフォルトのデータ タイプ書式については、< SQL データ型とリテラル、
B035-1143>を参照してください。
結果値
関数
結果値
COS(arg)
-1 以上 1 以下のラジアン単位の arg の余弦。
SIN(arg)
-1 以上 1 以下のラジアン単位の arg の正弦。
TAN(arg)
ラジアン単位の arg の正接。
ACOS(arg)
0~π ラジアンの範囲の角。
ASIN(arg)
-π/2~π/2 ラジアンの範囲の角。
ATAN(arg)
-π/2~π/2 ラジアンの範囲の角。
ATAN2(x,y)
-π および π ラジアン(-π を除く)の範囲の角。
正の結果は、x 軸から左回りで見た角を表わします。負の結果は、右回りで
見た角を表わします。
ATAN2(x,y)では x を 0 にできるが ATAN(y/x)では x を 0 にできない(ゼロ除算
エラーになるため)ことを除き、ATAN2(x,y)は ATAN(y/x)と等しくなります。
x と y の両方が 0 の場合は、エラーが戻されます。
引数のタイプと規則
FLOAT でない引数は、暗黙のタイプ変換規則に基づいて FLOAT に変換されます。
引数を変換できない場合は、エラーが戻されます。暗黙タイプ変換の詳細は、暗黙
的な型の変換を参照してください。
引数が UDT である場合、以下の規則が適用されます。
• 以下のいずれかの事前定義タイプに対する暗黙 CAST が UDT になければなりま
せん。
SQL 関数、演算子、式および述部
149
第 3 章 算術演算子/関数、三角関数、双曲線関数
TRIGONOMETRIC
• 数値
• 文字
• DATE
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。CREATE CAST の詳細は、<SQL データ定義言
語 - 構文規則および例、B035-1144>を参照してください。
• 三角関数および逆三角関数を含め、システム演算子および関数用の UDT の暗黙の
型変換は、ANSI SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、
DBS 制御レコードの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設
定します。詳細は、<ユーティリティ 、B035-1102>を参照してください。
三角関数および逆三角関数は、以下のタイプの引数を取ることはできません。
• BYTE または VARBYTE
• BLOB または CLOB
• CHARACTER または VARCHAR (サーバーの文字セットが GRAPHIC の場合)
例: 典型的な関数式
以下は主な関数式と結果です。
式
結果
COS(5-4)
5.40302305868140E -001
SIN(LOG(0.5))
-2.96504042171437E -001
SIN(RADIANS(180.0))
1.22464679914735E-016
TAN(ABS(-3))
-1.42546543074278E -001
ACOS(-0.5)
2.09439510239320E 000
ASIN(1)
1.57079632679490E 000
ATAN(1+2)
1.24904577239825E 000
ATAN2(1,1)
7.85398163397448E -001
関連トピック
詳細は、以下を参照してください。
•
•
•
•
150
「暗黙的な型の変換」
SQL データ定義言語 - 構文規則および例、B035-1144
ユーティリティ 、B035-1102
SQL データ型とリテラル、B035-1143
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
DEGREES RADIANS
DEGREES RADIANS
目的
DEGREES は、ラジアン単位で指定された値を取り、この値を度(角度)に変換します。
RADIANS は、度(角度)単位で指定された値を取り、この値をラジアンに変換します。
構文
DEGREES
( arg )
RADIANS
構文要素
arg
変換される数値式。
• 関数が DEGREES である場合、arg はラジアン単位の角であると解釈されます。
• 関数が RADIANS である場合、arg は度(角度)単位の角であると解釈されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果のタイトル
以下の表に DEGREES(arg)および RADIANS(arg)のデフォルト タイトルを示します。
関数
タイトル
DEGREES(arg)
(5.72957795130823E001*arg)
RADIANS(arg)
(1.74532925199433E-002*arg)
結果のタイプと書式
次に、DEGREES と RADIANS の結果のタイプと書式を示します。
• オペランドが数値である場合、書式は結果のデータ タイプのデフォルトの書式
です。
• オペランドが文字である場合、書式は FLOAT のデフォルトの書式です。
• オペランドが UDT である場合、書式は UDT の暗黙キャスト先の事前定義タイプ
のデフォルト書式です。
注: NULL キーワードのデータ タイプは INTEGER です。
データ タイプ書式については、< SQL データ型とリテラル、B035-1143>を参照し
てください。
SQL 関数、演算子、式および述部
151
第 3 章 算術演算子/関数、三角関数、双曲線関数
HYPERBOLIC
引数のタイプと規則
引数は、数値でない場合は暗黙のタイプ変換規則に基づいて数値に変換されます。
引数を変換できない場合は、エラーが戻されます。暗黙タイプ変換の詳細は、暗黙
的な型の変換を参照してください。
arg は文字列の場合は、FLOAT データ型の数値に変換されます。
arg が UDT である場合、以下のルールが適用されます。
• 以下のいずれかの事前定義タイプに対する暗黙 CAST が UDT になければなりませ
ん。
• 数値
• 文字
• 日時
• 間隔
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。CREATE CAST の詳細は、<SQL データ定義言
語 - 構文規則および例、B035-1144>を参照してください。
• DEGREES および RADIANS を含め、システム演算子および関数用の UDT の暗黙
の型変換は、ANSI SQL 規格の Teradata 拡張機能です。この拡張を無効にするに
は、DBS 制御レコードの DisableUDTImplCastForSysFuncOp フィールドを TRUE
に設定します。詳細は、<ユーティリティ 、B035-1102>を参照してください。
DEGREES および RADIANS のいずれも、以下のタイプの引数には適用できません。
• BYTE または VARBYTE
• BLOB または CLOB
• CHARACTER または VARCHAR (サーバーの文字セットが GRAPHIC の場合)
使用上の注意
DEGREES および RADIANS は、引数がラジアン単位で指定されることを求める SIN
および COS などの三角関数、およびラジアン単位で指定された値を戻す ASIN およ
び ACOS などの逆三角関数を処理する際に役立ちます。
例: 主な DEGREES および RADIANS 関数式
主な DEGREES および RADIANS 関数式とその結果の例を次に示します。
式
結果
SIN(RADIANS(60.0))
8.66025403784439E-001
DEGREES(1.0)
5.72957795130823E 001
HYPERBOLIC
目的
引数の双曲線関数または逆双曲線関数を実行します。
152
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
HYPERBOLIC
構文
COSH
( arg )
SINH
TANH
ACOSH
ASINH
ATANH
構文要素
arg
任意の実数。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果のタイプと属性
次の表に、双曲線関数および逆双曲線関数の結果のデフォルト属性を示します。
データ タイプ
書式
タイトル
FLOAT
FLOAT のデフォルト書式
Hyperbolic Cos(arg)
Hyperbolic Sin(arg)
Hyperbolic Tan(arg)
Hyperbolic ArcCos(arg)
Hyperbolic ArcSin(arg)
Hyperbolic ArcTan(arg)
デフォルトのデータ タイプ書式については、< SQL データ型とリテラル、
B035-1143>を参照してください。
結果値
関数
結果
COSH(arg)
arg の双曲余弦。
SINH(arg)
arg の双曲正弦。
TANH(arg)
arg の双曲正接。
ACOSH(arg)
arg の逆双曲余弦。逆双曲余弦は、双曲余弦が次の式を満たす数になる値
です。
acosh(cosh(arg)) = arg
SQL 関数、演算子、式および述部
153
第 3 章 算術演算子/関数、三角関数、双曲線関数
HYPERBOLIC
関数
結果
ASINH(arg)
arg の逆双曲正弦。逆双曲正弦は、双曲正弦が次の式を満たす数になる値
です。
asinh(sinh(arg)) = arg
ATANH(arg)
arg の逆双曲正接。逆双曲正接は、双曲正接が次の式を満たす数になる値
です。
atanh(tanh(arg)) = arg
引数のタイプと規則
arg は、FLOAT でない場合は暗黙の型変換規則に基づいて FLOAT 値に変換されま
す。引数を変換できない場合は、エラーが戻されます。暗黙タイプ変換の詳細は、
暗黙的な型の変換を参照してください。
arg が UDT である場合、以下のルールが適用されます。
• 以下のいずれかの事前定義タイプに対する暗黙 CAST が UDT になければなりませ
ん。
• 数値
• 文字
• DATE
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。CREATE CAST の詳細は、<SQL データ定義言
語 - 構文規則および例、B035-1144>を参照してください。
• 双曲線関数および逆双曲線関数を含めた、システム演算子および関数用の UDT の
暗黙の型変換は、ANSI SQL 規格の Teradata 拡張機能です。この拡張を無効にす
るには、DBS 制御レコードの DisableUDTImplCastForSysFuncOp フィールドを
TRUE に設定します。詳細は、<ユーティリティ 、B035-1102>を参照してくださ
い。
双曲線関数および逆双曲線関数は、以下のタイプの引数には適用できません。
• BYTE または VARBYTE
• BLOB または CLOB
• CHARACTER または VARCHAR (サーバーの文字セットが GRAPHIC の場合)
例: 典型的な双曲線関数式と逆双曲線関数式
以下は、主な双曲線関数および逆双曲線関数の式と結果です。
154
式
結果
COSH(EXP(1))
7.61012513866229E 000
SINH(1)
1.17520119364380E 000
TANH(0)
0E 000
ACOSH(3)
1.76274717403909E 000
ASINH(LOG(0.1))
-8.81373587019543E -001
ATANH(LN(0.5))
-8.53988047997524E -001
SQL 関数、演算子、式および述部
第 3 章 算術演算子/関数、三角関数、双曲線関数
HYPERBOLIC
関連トピック
詳細は、以下を参照してください。
•
•
•
•
暗黙的な型の変換
ユーティリティ 、B035-1102
SQL データ定義言語 - 構文規則および例、B035-1144
SQL データ型とリテラル、B035-1143
SQL 関数、演算子、式および述部
155
第 3 章 算術演算子/関数、三角関数、双曲線関数
HYPERBOLIC
156
SQL 関数、演算子、式および述部
第4章
ARRAY/VARRAY 関数および演算子
概要
この章では、1 次元(1-D)、多次元(n-D)、またはその両方の ARRAY データ型の関数、
演算子、式およびメソッドについて説明します。これらの関数を使用すると、配列
内のすべての構成要素や、配列を構成する構成要素の部分集合に対して、算術演算、
関係演算および集合演算を実行できるようになります。
ARRAY データ型について、詳細は< SQL データ型とリテラル、B035-1143>の
「ARRAY/VARRAY データ型」を参照してください。1 次元配列および多次元配列の
作成について、詳細は<SQL データ定義言語 - 構文規則および例、B035-1144>の
「CREATE TYPE(ARRAY/VARRAY 形式)」を参照してください。
注: この章で取り上げる関数は、埋め込みサービス システム関数です。埋め込みサー
ビス関数の有効化と呼び出しについて、詳細は「埋め込みサービス システム関数 」
を参照してください。
ARRAY 構成要素の参照
目的
ARRAY データ タイプ値の中の、指定した構成要素の値にアクセスします。
構文
5
array_expression
[ index_value ]
構文要素
array_expression
ARRAY データ型と評価される式。
index_value
アクセスする値を保持する配列内の構成要素への索引。
SQL 関数、演算子、式および述部
157
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY 構成要素の参照
1-D ARRAY タイプの場合、index_value は範囲が 1~n(n は ARRAY タイプの宣言サ
イズ)の正の整数であることが必要です。
n-D ARRAY タイプの場合、index_value は範囲が m~n(m は、配列の次元について
宣言された下限、n は宣言された上限)の正または負の整数であることが必要です。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠していますが、非 ANSI の Teradata Database 拡張
機能が含まれています。
使用上の注意
参照先の配列の構成要素は、値または NULL で初期化する必要があります。参照先
の配列の構成要素が未初期化状態の場合は、エラーが返されます。DEFAULT NULL
句を使用すると、その ARRAY データ タイプが作成される時点で配列のすべての構
成要素を NULL で初期化できます。また、ARRAY コンストラクタ式を使用して、配
列を初期化することもできます。DEFAULT NULL 句について、詳細は<SQL データ
定義言語 - 構文規則および例、B035-1144>の「CREATE TYPE (ARRAY 形式)」を参
照してください。ARRAY コンストラクタ式については、「ARRAY コンストラクタ
式」を参照してください。
1-D ARRAY タイプの場合、1 組の角括弧を付けた ARRAY 構成要素の参照構文を使用
すると、単一の構成要素を参照できます。例えば、MyArray[n]のようにします。こ
の MyArray は 1-D ARRAY データ型です。
n-D ARRAY タイプの場合、n 組の角括弧を付けた ARRAY 構成要素の参照構文を使用
して、単一の構成要素を参照できます。この n は、n-D ARRAY タイプの次元数に対
応します。例えば、my3DArray が 3-D ARRAY データ型を定義する場合、この配列
の 1 つの構成要素にアクセスする ARRAY 構成要素の参照構文は、my3DArray[x][y]
[z]になります。角括弧の最大セット数は 5 です。これは、Teradata がサポートする
n-D ARRAY タイプの最大次元数に対応しています。
ARRAY 構成要素の参照に含まれる参照次元数は、その構成要素の参照を使用して配
列値の構成要素にアクセスしようとしたときに検証されます。この検証には、参照
先の ARRAY 値が存在している必要があり、SQL 文で構成要素の参照を実際に実行す
る必要があります。そのため、まれに、ARRAY 構成要素の参照を含む SQL 文が実際
には実行されない場合があります。たとえば、行を格納していないテーブルからの
SELECT や、左側の評価が真になる OR 句の右側で構成要素の参照を行なう SELECT
内の WHERE 句などが挙げられます。このような場合、ARRAY 構成要素の参照は、
UDF の呼び出しと同じ動作になります。
ARRAY 構成要素の参照を SET 句で使用する方法
UPDATE 文や MERGE 文の SET 句のターゲット値として ARRAY 構成要素の参照を使
用すると、ARRAY 内の個々の構成要素の値を設定できます。
158
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY 構成要素の参照
1-D 配列の中ほどの構成要素に特定の値を設定したときに、それより前の構成要素
が初期化されていない場合には、それらの構成要素が自動的に NULL に初期化され
ます。n-D ARRAY タイプの場合、配列の中ほどの構成要素を特定の値に設定したと
きに、それより前(行優先順で全次元)の構成要素が初期化されていない場合には、
それらの構成要素が自動的に NULL に初期化されます。
配列の要素型が可変長型で、要素の初期化のため渡された値が要素型の最大サイズ
より大きい場合、Teradata Database は要素型の最大サイズになるように渡された値
を自動的に切り捨てます。この切り捨て動作は、Teradata セッション モードのトラ
ンザクション処理でのみ発生します。ANSI セッション モードでは、Teradata
Database は渡された値の切り捨ては行なわず、代わりにエラーを返します。この動
作は、DISTINCT 型 UDT および STRUCTURED 型 UDT の動作と同じです。
さらに、CHAR から TIMESTAMP へ、または TIMESTAMP から DATE へのキャスト
など、既存の暗黙の CAST 機能は、既存の ARRAY 構成要素の参照ではサポートして
いません。SET 句の変換元のデータ タイプは、配列の構成要素のデータ タイプと同
じでなければなりません。SET 句の変換先が ARRAY 構成要素の参照の場合、配列
の構成要素のタイプとは異なるデータ タイプを持つ SET 句の変換元値に対しては、
明示的な CAST を使用する必要があります。
例
例: ARRAY 要素の参照構文の表示
テーブルに ephone という名前の列が含まれ、ephone 列のデータ タイプが 1-D
ARRAY の場合、配列の 5 番目の構成要素の値にアクセスする ARRAY 構成要素の参
照構文を次に示します。
ephone[5]
例: 1-D ARRAY でのテーブルとセット要素の作成
次の 1-D ARRAY データ タイプについて考えてみましょう。
CREATE TYPE phonenumbers_ary AS CHAR(10) ARRAY[5];
次の文は、ephone という名前でデータ タイプが phonenumbers_ary の列を持つテー
ブルを作成します。
CREATE TABLE my_table (eno INTEGER, ephone phonenumbers_ary);
次の文は、ARRAY 構成要素の参照を使用して、配列の構成要素 3 の値を
「5551234567」に設定します。配列内の構成要素 1 と 2 が初期化されていなかっ
た場合、この UPDATE 文により、それらの構成要素は自動的に null に設定されます。
UPDATE my_table
SET ephone[3] = '5551234567';
SQL 関数、演算子、式および述部
159
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_Constructor_Expression
例: 3-D ARRAY でのテーブルとセット要素の作成
次の STRUCTURED 型 UDT について考えてみましょう。
CREATE TYPE measures_UDT AS(amplitude INTEGER,
phase
INTEGER,
frequency INTEGER);
次の文は、shots という名前で構成要素のタイプが measures_UDT の 3-D ARRAY
データ タイプを作成します。
CREATE TYPE shots AS measures_UDT ARRAY[-2:2][-5:5][-3:3];
次の文は、shot_ary という名前の列を持つテーブルを作成します。shot_ary 列のデー
タ タイプは shots です。これは 3-D ARRAY タイプです。
CREATE TABLE seismic_table (id INTEGER, shot_ary shots);
次の問合わせは、3-D 配列の構成要素の値を選択します。
SELECT shot_ary[-1][1][3] FROM seismic_table;
関連トピック
詳細は、「ARRAY コンストラクタ式」を参照してください。
ARRAY_Constructor_Expression
目的
ARRAY タイプの新しいインスタンスを生成し、そのインスタンスを指定されたコン
ストラクタ メソッドまたは関数を使って初期化します。
構文
array_name
NEW
(
)
,
n
element_expression
構文要素
array_name
初期化する ARRAY データ型の名前。
160
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_Constructor_Expression
element_expression
リテラル値と評価される式。値のデータ型は、array_name 配列の要素型と同じに
する必要があります。
element_expression は n 回繰り返すことができます。n は array_name アレイの宣
言サイズです。n の最大値は 2559 です。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプと規則
ARRAY コンストラクタに渡す式は、array_name 配列の要素型のデータ型に暗黙的
に変換できるものである必要があります。CHAR から TIMESTAMP へ、または
TIMESTAMP から DATE へのキャストなど、既存の暗黙の CAST 機能は、既存の
ARRAY コンストラクタ式ではサポートしていません。
ARRAY コンストラクタ式には、ゼロ個以上の引数を使用できます。引数がない場
合、ARRAY コンストラクタは空の ARRAY タイプ値を初期化し、その ARRAY デー
タ型が DEFAULT NULL 句を指定せずに作成された場合には、配列のすべての構成
要素の値を未初期化状態に設定します。その ARRAY データ型が DEFAULT NULL 句
を指定して作成された場合は、ARRAY コンストラクタが配列のすべての構成要素の
値を null に初期化します。未初期化状態の配列の構成要素へのアクセスを試みる
と、エラーが返されるので注意してください。
ARRAY コンストラクタ式に対しては、最大 n 個の引数を渡すことができます。この
とき、n は、ARRAY データ型の宣言サイズです。1 次元 ARRAY タイプの場合、
ARRAY コンストラクタは配列の構成要素の先頭から、引数が渡される順に引数を入
れていきます。多次元 ARRAY タイプの場合、ARRAY コンストラクタ式に引数を行
優先順で渡します。これは、多次元配列の構成要素が行優先順で埋め込まれるため
です。
引数の数が配列の構成要素数より少ない場合、引数の値が指定されていない残りの
構成要素は、初期化されていない状態に設定されます。ただし、DEFAULT NULL 句
を使用して ARRAY データ型を作成した場合、そのような構成要素は null に設定さ
れます。
UDT のコンストラクタ メソッドは、128 個を超える引数は受け付けませんが、こ
の制限は ARRAY データ型には適用されません。ARRAY コンストラクタに指定でき
る引数の数は、ARRAY タイプに定義できる構成要素の最大数または 2559 個のどち
らか小さい方に制限されます。
配列の要素型が可変長型で、要素の初期化のため渡された値が要素型の最大サイズ
より大きい場合、Teradata Database は要素型の最大サイズになるように渡された値
を自動的に切り捨てます。この切り捨て動作は、Teradata セッション モードのトラ
ンザクション処理でのみ発生します。ANSI セッション モードでは、Teradata
SQL 関数、演算子、式および述部
161
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_Constructor_Expression
Database は渡された値の切り捨ては行なわず、代わりにエラーを返します。この動
作は、DISTINCT 型 UDT および STRUCTURED 型 UDT の動作と同じです。
NEW キーワードを使用しない ARRAY コンストラクタ式の呼び出し
NEW キーワードを使用しなくても、ARRAY コンストラクタ式を呼び出すことがで
きます。これは Oracle 構文と互換性があります。NEW キーワードを使用せずに呼
び出すと、この式を Teradata Database は UDF 式のように扱います。これは、ARRAY
コンストラクタ式を使用できる場所を、スカラー UDF と同じ用法に制限します。こ
れは、同じシナリオで、NEW キーワードを使用しない ARRAY コンストラクタ式が
使用できない SQL 文内でも、NEW キーワードを使用する ARRAY コンストラクタ式
は使用できることを意味します。たとえば、CREATE TABLE 文の DEFAULT 句で、
NEW キーワードを使用する ARRAY コンストラクタ式を使用できます。ただし、
DEFAULT 句で NEW キーワードを使用しない ARRAY コンストラクタ式は使用でき
ません。
さらに、NEW キーワードを使用しない ARRAY コンストラクタ式はスカラー UDF の
ように扱われるので、この場合、UDF の既存の検索順序ルールが適用されます。
Teradata Database は次のデータベース内の UDF を次の順序で検索します。
1 デフォルト データベース
2 SYSLIB データベース
3 TD_SYSFNLIB データベース
4 SYSUDTLIB データベース
UDF がデフォルト データベース、SYSLIB、または、TD_SYSFNLIB 内にあり、かつ、
定義された ARRAY データ型と同じ名前を持つ場合、また、NEW キーワードを指定
しない ARRAY コンストラクタ式を呼び出す場合は、Teradata Database は ARRAY コ
ンストラクタに代わって UDF を呼び出します。この対立を回避するには、ARRAY コ
ンストラクタを呼び出すときに NEW キーワードを使用します。
例: ARRAY コンストラクタ式の使用
次の 1-D ARRAY データ タイプについて考えてみましょう。
CREATE TYPE phonenumbers_ary AS CHAR(10) ARRAY[5];
phonenumbers_ary 内の最初の 2 つの構成要素に指定した値を設定し、また、配列
内の他の構成要素を初期化されていない状態に設定する ARRAY コンストラクタ式を
次に示します。
NEW phonenumbers_ary('5551234567', '8585551234')
または
phonenumbers_ary('5551234567', '8585551234')
162
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY 適用範囲の参照
ARRAY 適用範囲の参照
目的
ARRAY 関数を呼び出すときに、ARRAY データ タイプの複数の構成要素を参照します。
構文
array_lower_bounds, array_upper_bounds
構文要素
array_lower_bounds
整数値または事前定義された ARRAY タイプ ArrayVec の配列インスタンスで、範囲
の下限を定義する整数値のカンマ区切りリストを指定したもの。
array_upper_bounds
整数値または事前定義された ARRAY タイプ ArrayVec の配列インスタンスで、範囲
の上限を定義する整数値のカンマ区切りリストを指定したもの。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
ARRAY 関数を呼び出すときに 1 つ以上の ARRAY データ タイプの構成要素を参照す
るには、1-D 配列には整数値を使用できますが、n-D 配列には ArrayVec ARRAY デー
タ タイプを使用する必要があります。ArrayVec ARRAY データ タイプは、システム
によって自動的に作成され、次のように定義されています。
CREATE TYPE ArrayVec AS INTEGER ARRAY[1000];
任意選択の scope_reference 引数または array_bound 引数を持つすべての ARRAY
関数については、ArrayVec ARRAY タイプの 1 つ以上のインスタンスを使用して、
n-D ARRAY データ型の各次元の境界を記述できます。
規則
ARRAY 関数で任意選択の scope_reference パラメータが指定されているときは、次
のルールが適用されます。
• scope_reference には、2 つの整数値または 2 つの ArrayVec 値を渡せます。1 次
元 ARRAY 引数を使用して ARRAY 関数を呼び出す場合、scope_reference には整
数と ArrayVec を組み合わせた値を渡せます。例えば、scope_reference は
SQL 関数、演算子、式および述部
163
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY 適用範囲の参照
integer_value、ArrayVec_value または ArrayVec_value、integer_value にするこ
とができます。
• scope_reference の範囲の上限または下限を指定するのに ArrayVec インスタンス
を使用する場合、次の操作は許されません。
• 配列引数の境界を定義するために必要な ArrayVec 構成要素のいずれかに NULL
を渡す。
• 配列引数の境界を定義するには不十分な数の構成要素を ArrayVec に渡す。
• 配列引数の境界を定義するには多すぎる数の構成要素を ArrayVec に渡す。
• RETURNS NULL ON NULL INPUT 句を定義するすべての ARRAY 関数については、
scope_reference を定義する任意選択のパラメータの 1 つが NULL として渡され
ると、結果値として NULL が返されます。
• scope_reference を指定して呼び出される ARRAY 関数は、その適用範囲が明示的
に定義されているとみなされるので、初期化されていない構成要素のいずれか
が、ARRAY 入力引数のいずれかで scope_reference の範囲内にあれば、そのよう
な関数はエラーを返します。CARDINALITY 関数は、このルールの例外となりま
す。これは、初期化されていない構成要素が含まれている、明示的な適用範囲
は、この関数の入力として受け入れられないためです。
アプリケーションを 2 つの配列の間で操作する必要がある場合、作成時に DEFAULT
NULL 句を使用してそうした配列を作成することを考慮します。こうすると、配列の
すべての構成要素が初期化されるので、システムから無効な構成要素の参照による
エラーを回避できます。
ARRAY 関数で任意選択の scope_reference パラメータが指定されていないときは、
次のルールが適用されます。
• scope_reference を指定せずに ARRAY 関数を呼び出すと、使用されるデフォルト
の適用範囲は入力 ARRAY 引数で初期化されている構成要素の数になります。
ARRAY 関数が 2 つの ARRAY 引数を受け付け、初期化された構成要素の数が 2 つ
の配列で異なっている場合、エラーが返されます。
• ARRAY 関数が ARRAY 値を返すとき、結果の ARRAY 値に含まれる初期化された
構成要素の数は、入力 ARRAY 引数の構成要素の数と同じになります。
例: 範囲内の固有(Distinct)要素の数を返す
次の問合わせにより、phonelist 配列の各次元の範囲 5~10 内にある固有(Distinct)
構成要素の数が返されます。
SELECT CARDINALITY(phonelist, NEW ArrayVec(5,5), NEW ArrayVec(10,10));
関連トピック
詳細は、「ARRAY コンストラクタ式」を参照してください。
164
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_AGG
ARRAY_AGG
目的
問合わせの SELECT リストの一部として配列を作成できる ARRAY データ タイプと
ともに使用する集約関数。
構文
ARRAY_AGG
A
( element_value_expr
TD_SYSFNLIB.
, array_expression )
A
ORDER BY
value_expression
ASC
DESC
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
element_value_expr
ARRAY のエレメント タイプと評価される式。
value_expression
比較可能な Teradata データ型と評価される式。
ASC
結果が昇順で整列されます。
整列フィールドが文字列の場合、システムは現在のセッションの照合順序の定義に
従って、昇順で整列します。
デフォルトの順序は ASC です。
DESC
結果が降順で整列されます。
整列フィールドが文字列の場合、システムは現在のセッションの照合順序の定義に
従って、降順で整列します。
array_expression
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
SQL 関数、演算子、式および述部
165
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_AGG
ANSI への準拠
この文は、ANSI SQL:2011 に準拠していますが、非 ANSI の Teradata Database 拡張
機能が含まれています。
引数のタイプ
ARRAY_AGG では、2 つの引数を使用できます。第 1 引数は、定義済みの ARRAY
データ タイプの構成要素の値として現在使用されているデータ タイプを評価する式
です。第 2 引数は、構成要素のタイプが第 1 引数と一致する定義済みの ARRAY デー
タ タイプを評価する式です。
結果のタイプ
ARRAY データ型を解決する array_expression から得たデータ型情報は、ARRAY_AGG
が返すタイプの設定に使用されます。
結果値およびルール
ARRAY_AGG は ARRAY タイプ値を返し、その構成要素は第 1 パラメータとして渡さ
れた構成要素式値の集約セットです。n-D ARRAY 結果値の場合、配列に集約される
value_expression 値は行優先順で入力されます。
第 1 引数で ORDER BY 句を指定すると、結果の配列に入力される値は、この句で指
定された列値の順に並べられます。ARRAY_AGG の ORDER BY 句には、次のルール
が適用されます。
• ARRAY_AGG の ORDER BY 句に渡してもよい値は 1 つのみです。この点が、
ORDERE BY に対して複数の値を渡すことができる SELECT 文の ORDER BY とは
異なります。
• ARRAY 列値は、ORDER BY 句における整列キーとしては渡せません。ARRAY 値
のリレーショナル比較はできません。それ以外に、BLOB または CLOB など、比
較できないデータ タイプ値は、ORDER BY 句における整列キーとしては渡せませ
ん。
• ORDER BY に渡される単一の値の場合、リレーショナル比較ができる式は渡して
もかまいません。ただし、渡される値が列値ではない場合、結果の配列構成要素
の整列は行なわれません。また、結果は結果の配列に順不同で書き込まれます。
適切な整列を行なうには、SQL 文内で参照先のテーブルの 1 つから得られる列値
を使用します。
使用上の注意
任意の array_expression を渡せることから、渡す ARRAY タイプ値には、初期化され
た構成要素が含まれていても、いなくてもかまいません。ただし、ARRAY_AGG は
166
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_AGG
array_expression 内の初期化済みの構成要素は無視します。array_expression は、
結果値のデータ型を指定する場合にのみ使用されます。
推奨事項: このパラメータには、NEW myArray()など、必要な ARRAY タイプ値の空
のインスタンスを渡します。
ARRAY_AGG に渡される array_expression 引数が NULL リテラルの場合、エラーが
返されます。array_expression 引数を ARRAY データ型に解決できる場合、データ
に NULL が含まれていても関数は正常に実行されます。
処理中の現在行の value_expression 引数が NULL と評価される場合、その式は集計
中の値のリストから除外されず、非 NULL 構成要素で行なうのと同様に、適切な
ARRAY 構成要素の値を設定するために使用されます。これは ANSI SQL:2011 規格
に対応し、規格では、ARRAY_AGG とその他の集計関数との違いとして注記されて
います。
ARRAY_AGG は、CLASS AGGREGATE 値を 64000 として作成されています。これ
は、そのサイズで中間集計ストレージが割り当てられることを意味します。中間集
計ストレージは固定長値なので、このバッファがオーバーフローするような非常に
大きな入力セットを処理する場合も考えられます。すべての集計 UDF にこの制限が
あります。
例: ソース テーブルのデータを新しいテーブルに挿入する
この例では、ある従業員に付随する電話番号を記録するソース テーブルからデータ
を取り出し、電話番号を ARRAY タイプで記録する新しいテーブルに挿入します。
多くの場合、一人の従業員が、会社の電話、携帯電話、自宅の電話など、複数の電
話番号を持つことができます。こうしたタイプのデータを表わすには、複数の電話
番号を記録する 1-D ARRAY タイプの方が適しています。これはテーブルの行数を減
らします。
注:同じタイプの動作を n-D ARRAY タイプで表わすことも可能です。両者の唯一の
違いは、構成要素の格納が行優先順で処理されることです。
次の文は、最大 100 件の電話番号値を持つことのできる 1-D ARRAY タイプを作成
します。
CREATE TYPE emp_phone_array AS VARCHAR(14) ARRAY[100];
次のソース表は、従業員の電話番号それぞれが 1 行になっています。
CREATE SET TABLE employee
(emp_id INTEGER,
emp_name VARCHAR(30),
emp_phone CHAR(14));
SELECT * FROM employee;
emp_id
emp_name
-----------------1
Beth
SQL 関数、演算子、式および述部
emp_phone
------------(619) 619-6190
167
第 4 章 ARRAY/VARRAY 関数および演算子
UNNEST
1
1
2
2
2
3
3
3
Beth
Beth
Greg
Greg
Greg
Louise
Louise
Louise
(619)
(619)
(858)
(858)
(858)
(421)
(421)
(421)
620-6200
720-7200
858-8580
859-8590
860-8600
421-4210
422-4220
423-4230
次のターゲット表では、従業員それぞれが 1 行になっており、その従業員に関連す
るすべての電話番号を ARRAY タイプに格納します。
CREATE SET TABLE employeePhoneInfo
(emp_id INTEGER,
emp_name VARCHAR(30),
emp_phone emp_phone_array);
INSERT INTO employeePhoneInfo
SELECT emp_id, emp_name,
ARRAY_AGG(emp_phone, NEW emp_phone_array())
FROM employee GROUP BY emp_id,emp_name
WHERE emp_id < 100;
SELECT * FROM employeePhoneInfo;
emp_id
---------
emp_name
-----------
emp_phone
---------
1
Beth
( (619) 619-6190, (619) 620-6200, (619) 720-7200 )
2
Greg
( (858) 858-8580, (858) 859-8590, (858) 860-8600 )
3
Louise
( (421) 421-4210, (421) 422-4220, (421) 423-4230 )
UNNEST
目的
ARRAY データ タイプで使用するテーブル関数で、配列を列テーブルに変換できます。
構文
UNNEST
TD_SYSFNLIB.
168
(
array_expr )
key_expr,
WITH ORDINALITY
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
UNNEST
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
key_expr
ARRAY、UDT、PERIOD データ型、BLOB、または CLOB 以外の Teradata データ型
と評価される式。
array_expr
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
ANSI への準拠
この文は、ANSI SQL:2011 に準拠していますが、非 ANSI の Teradata Database 拡
張機能が含まれています。
引数のタイプ
UNNEST が受け取る引数は、1 つまたは 2 つのいずれかです。任意選択のキー値引
数により結果のテーブルに生成される行をグループ化できます。これは特に、
UNNEST を ARRAY_AGG 関数の補足として使用する場合に役立ちます。というの
も、ARRAY_AGG は、集計 GROUP BY 句を使用して呼び出され、グループ化に基づ
いて複数の ARRAY 値を生成するからです。
array_expr 引数は、現在システム内で定義されている ARRAY データ型と評価され
る式です。
結果のタイプと値
UNNEST は、1~3 列を含むテーブルを返します。第 1 の出力列は、任意選択のキー
値が指定されていた場合に、それに対応します。第 2 の出力列は、渡された ARRAY
タイプの構成要素のタイプと同じデータ タイプです。 任意選択の WITH ORDINALITY
句が指定された場合、UNNEST は各構成要素に関連付けられた位置を含む追加の整
数列を集計します。
テーブルでは、UNNEST に渡された ARRAY 値の各構成要素が 1 行に取り込まれま
す。n-D ARRAY 入力値の場合、入力の n-D ARRAY から得た構成要素の値を格納す
る列が、行優先順で出力されます。
SQL 関数、演算子、式および述部
169
第 4 章 ARRAY/VARRAY 関数および演算子
UNNEST
使用上の注意
テーブル UDF はテーブル関数です。したがって、SQL SELECT 文の FROM 句でのみ
使用できます。
ARRAY 式引数が NULL と評価されると、結果のテーブルに行は返りません。ARRAY
式引数が NULL でなくても、存在しない構成要素が 1 つ以上ある場合は、対応する
結果行の配列構成要素の列値は NULL になります。
例: UNNEST の呼び出し
この例は、UNNEST を呼び出し、1-D ARRAY タイプの列 myarray を使用して、任意
選択のキー値引数を渡し、任意選択の WITH ORDINALITY 句を使用します。例では、
tt2 テーブルの各行の myarray 配列に格納される値ごとに 1 行ずつ、20 行を返しま
す。3 つの列の結果が返されます。
• out_key は、UNNEST に渡される任意選択のキー値です。この例では tt2 テーブ
ルの int_key 列の値に対応するため、tt2 テーブルの各行から発生した結果の配列
値を識別します。
• pos は、配列内の構成要素の位置です。例では WITH ORDINALITY 句を使用して
いるため、結果に含まれます。
• val は、配列の構成要素の値です。
CREATE TYPE myarray AS INTEGER ARRAY[10];
CREATE TABLE tt2(
pkey INTEGER,
int_key INTEGER,
vc_key VARCHAR(20),
myarr myarray);
INS INTO tt2 VALUES(0, 0, 'item 0', NEW myarray(10, 20, 30, 40, 50));
INS INTO tt2 VALUES(1, 1, 'item 1', NEW myarray(11, 21, 31, 41, 51));
INS INTO tt2 VALUES(2, 2, 'item 2', NEW myarray(12, 22, 32, 42, 52));
INS INTO tt2 VALUES(3, 3, 'item 3', NEW myarray(NULL, 23, 33, 43,
NULL));
INS INTO tt2 VALUES(4, 4, 'item 4', NULL);
SELECT out_key, tf.pos, tf.val
FROM tt2,
TABLE (UNNEST(tt2.int_key, tt2.myarr) WITH ORDINALITY) AS
tf(out_key, val, pos) WHERE tt2.int_key = tf.out_key ORDER BY 1,2;
*** Query completed. 20 rows found. 3 columns returned.
*** Total elapsed time was 1 second.
out_key
pos
val
----------- ----------- ----------0
1
10
0
2
20
0
3
30
170
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
CARDINALITY
0
0
1
1
1
1
1
2
2
2
2
2
3
3
3
3
3
4
5
1
2
3
4
5
1
2
3
4
5
1
2
3
4
5
40
50
11
21
31
41
51
12
22
32
42
52
?
23
33
43
?
関連トピック
詳細は、「ARRAY コンストラクタ式」を参照してください。
CARDINALITY
目的
現在値が割り当てられている ARRAY データ タイプ内の構成要素数を表わす整数、
または、特定の適用範囲の参照内で初期化された構成要素数を返します。
構文
システム関数の構文
CARDINALITY
( array_expr
)
, scope_reference
メソッドスタイルの構文
array_expr. CARDINALITY
(
)
scope_reference
構文要素
array_expr
次のいずれかである ARRAY 式。
• ARRAY 列の参照
SQL 関数、演算子、式および述部
171
第 4 章 ARRAY/VARRAY 関数および演算子
CARDINALITY
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
scope_reference
ARRAY 適用範囲の参照。
ARRAY 式が CARDINALITY 関数に指定されている場合、初期化されていない構成要
素が含まれている、明示的な適用範囲は、入力として受け入れられます。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠していますが、非 ANSI の Teradata Database 拡張
機能が含まれています。
引数のタイプ
array_expr 引数は、現在システム内で定義されている ARRAY データ型と評価される
式です。
結果のタイプと値
CARDINALITY は、現在値が割り当てられている ARRAY 内の構成要素数を表わす整
数値を返します。この数には、NULL の構成要素も含まれます。ARRAY 値に割り当
てられている構成要素の値の数が、定義されている最大サイズ n より少ない場合が
あるので、CARDINALITY 関数から n より小さい値が返る場合があります。
配列引数が空の(つまり、構成要素が割り当てられていない)場合、関数は 0 を返しま
す。配列引数が NULL の場合は、CARDINALITY は結果として NULL を返します。
初期化されていないいずれかの構成要素が、ARRAY 入力引数のいずれかに指定した
scope_reference の範囲にある場合、通常、ARRAY 関数はエラーを返しますが、
CARDINALITY 関数内に指定された ARRAY 式の動作は異なります。ARRAY 式が
CARDINALITY 関数に指定されている場合、初期化されていない構成要素が含まれて
いる、明示的な適用範囲は入力として受け入れられます。
例: 1-D ARRAY の要素数を表わす整数を返す
次の例では、現在値が割り当てられている 1-D ARRAY 内の構成要素数を表わす整数
値を返します。
CREATE TYPE phonenumbers AS CHAR(10) ARRAY[20];
CREATE TABLE employee_info (eno INTEGER, phonelist phonenumbers);
SELECT CARDINALITY(phonelist)
FROM employee_info;
172
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_CONCATENATION_OPERATOR
CARDINALITY 関数を使用して、特定の適用範囲の参照内で現在初期化されている
構成要素数を返すこともできます。たとえば、次の問合わせにより、phonelist 配列
の範囲 5~10 で初期化された構成要素数が返ります。
SELECT CARDINALITY(phonelist, 5, 10);
次の 2-D ARRAY データ タイプについて考えてみましょう。
CREATE TYPE shot_ary AS INTEGER ARRAY[1:50][1:50];
CREATE TABLE seismic_table(shots shot_ary);
CREATE TABLE seismic_data (
id INTEGER,
shot1 shot_ary,
shot2 shot_ary);
次の例では、現在値が割り当てられている 2-D ARRAY 内の構成要素数を表わす整数
値を返します。
SELECT CARDINALITY(shot1) FROM seismic_data;
次に、メソッドスタイルの構文を使用した同じ問合わせを示します。
SELECT shot1.CARDINALITY() FROM seismic_data;
次の問合わせにより、phonelist 配列の各次元の範囲 5~10 で初期化された構成要
素の数が返ります。
SELECT CARDINALITY(phonelist, NEW ArrayVec(5,5), NEW ArrayVec(10,10));
関連トピック
詳細は、「ARRAY コンストラクタ式」を参照してください。
ARRAY_CONCATENATION_OPERATOR
目的
1 次元の ARRAY データ タイプを連結します。
構文
array_expr1
SQL 関数、演算子、式および述部
array_expr2
173
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_CONCATENATION_OPERATOR
構文要素
array_expr1/array_expr1
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
||
連結演算子。
ANSI への準拠
1 次元(1-D)の ARRAY データ タイプの ARRAY 連結演算子は、部分的に ANSI SQL:
2011 に準拠しています。
ARRAY 連結演算子では、両方のオペランドが同じ ARRAY タイプのインスタンスで
あることと、連結演算の変換先タイプも同じタイプであることが必要です。これは、
1-D ARRAY 連結の変換先データ タイプが、両方の演算子の長さの合計として定義さ
れた長さを持つ新しい 1-D ARRAY タイプとなるよう定義されているため、ANSI 規
格とはずれがあります。
引数のタイプ
array_expr1 および array_expr2 は、CREATE TYPE 文で定義したものと同じ 1-D
ARRAY データ型であることが必要です。
結果のタイプと値
連結演算の結果は、2 つの引数のデータ型と同じ型の新しい 1-D ARRAY 値です。こ
のとき、array_expr1 にあるすべての構成要素の後ろに、array_expr2 にあるすべて
の構成要素が続きます。存在する構成要素には、NULL 構成要素も含まれますが、初
期化されていない状態にある構成要素は含まれません。
結果値と引数値が同じ 1-D ARRAY タイプなので、最大サイズ n も同じです。そのた
め、array_expr1 と array_expr2 の連結の結果、構成要素数が定義済みの 1-D ARRAY
タイプの最大サイズ n を超えると、操作はエラーでアボートします。
どちらかの引数が NULL の場合、操作の結果は NULL になります。
制約事項
ARRAY 連結演算子は、多次元の ARRAY データ タイプと一緒には使用できません。
174
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_CONCATENATION_FUNCTION
例: 1-D ARRAY 値の連結
この例では、同じデータ タイプの 1-D ARRAY 値を 2 つ受け取り、それを連結します。
CREATE TYPE address AS CHAR(10) ARRAY[5];
CREATE TABLE employee_info (eno INTEGER, addressval address);
/* Assume one row in table employee_info contains the following value
for "addressval":
Addressval[1] = '123 Main St.'
Addressval[2] = 'San Diego'
Addressval[3] = 'CA'
*/
/* The following select statement concatenates the current value in
"addressval" with ZIP code and country information, which are stored as
additional elements of the 1-D array. */
SELECT addressval || NEW address('92101', 'USA');
FROM employee_info;
/* Result value is the following:
Addressval[1] = '123 Main St.'
Addressval[2] = 'San Diego'
Addressval[3] = 'CA'
Addressval[4] = '92101'
Addressval[5] = 'USA'
*/
ARRAY_CONCATENATION_FUNCTION
目的
1 次元 ARRAY データ タイプを連結し、その配列の構成要素のサブセットに適用で
きます。
構文
システム関数の構文
ARRAY_CONCAT
( expr1, expr2
)
, scope_reference
メソッドスタイルの構文
expr1. ARRAY_CONCAT
( expr2
)
, scope_reference
SQL 関数、演算子、式および述部
175
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_CONCATENATION_FUNCTION
構文要素
expr1
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
scope_reference
ARRAY 適用範囲の参照。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
expr1 および expr2 が ARRAY 式であること、また、両方が CREATE TYPE 文で定義
したものと同じ 1-D ARRAY データ型であることが必要です。
結果のタイプと値
連結演算の結果は、2 つの引数のデータ型と同じ型の新しい 1-D ARRAY 値です。こ
のとき、expr1 にあるすべての構成要素の後ろに、expr2 にあるすべての構成要素が
続きます。存在する構成要素には、null 構成要素も含まれますが、初期化されてい
ない状態にある構成要素は含まれません。
結果値と引数値が同じ 1-D ARRAY タイプなので、最大サイズ n も同じです。そのた
め、expr1 と expr2 の連結の結果、構成要素数が定義済みの 1-D ARRAY タイプの最
大サイズ n を超えると、操作はエラーでアボートします。
どちらかの引数が NULL の場合、操作の結果は NULL になります。
制約事項
ARRAY 連結関数は、多次元の ARRAY データ タイプと一緒には使用できません。
例: 2 つの 1-D ARRAY 値の連結
この例では、同じデータ タイプの 1-D ARRAY 値を 2 つ受け取り、それを連結しま
す。PhoneNum と OldPhoneNum は employee_info テーブル内の列で、どちらの列
も同じ 1-D ARRAY データ タイプです。
176
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_COMPARISON_FUNCTION
/* The following select statement concatenates the current value in
"PhoneNum" with the value in "OldPhoneNum". */
/* Assume one row in table employee_info contains the following value
for "PhoneNum":
PhoneNum[1] = '6197211000'
PhoneNum[2] = '6197221000'
PhoneNum[3] = '6197231000'
Also, assume one row in table employee_info contains the following value
for "OldPhoneNum":
OldPhoneNum[1] = '8582001000'
OldPhoneNum[2] = '8582002000'
OldPhoneNum[3] = '8582003000'
*/
SELECT ARRAY_CONCAT(PhoneNum, OldPhoneNum)
FROM employee_info;
/* Result value is the following:
PhoneNum[1] = '6197211000'
PhoneNum[2] = '6197221000'
PhoneNum[3] = '6197231000'
PhoneNum[4] = '8582001000'
PhoneNum[5] = '8582002000'
PhoneNum[6] = '8582003000'
*/
次に、メソッドスタイルの構文を使用した同じ問合わせを示します。
SELECT PhoneNum.ARRAY_CONCAT(OldPhoneNum)
FROM employee_info;
ARRAY_COMPARISON_FUNCTION
目的
ARRAY 値の個々の構成要素の比較を実行し、配列全体または適用範囲のいずれかを
参照します。
構文
システム関数の構文
ARRAY_GT
ARRAY_GE
( expr1, expr2
)
, scope_reference
ARRAY_LT
ARRAY_LE
ARRAY_EQ
ARRAY_NE
SQL 関数、演算子、式および述部
177
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_COMPARISON_FUNCTION
メソッドスタイルの構文
expr1.
ARRAY_GT
( expr2
ARRAY_GE
)
, scope_reference
ARRAY_LT
ARRAY_LE
ARRAY_EQ
ARRAY_NE
構文要素
expr1
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
配列の構成要素のタイプは NUMERIC データ型でなければなりません。
scope_reference
ARRAY 適用範囲の参照。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
expr1 または expr2、または両方の引数は ARRAY 式でなければなりません。詳細に
ついては、「使用上の注意」を参照してください。
サポートされている ARRAY 比較関数
次の表に、サポートされる ARRAY 比較関数の説明を示します。
リレーショナル
関数
ARRAY_GT
178
説明
「より大きい」関数。2 つの式を比較し、expr1 が expr2 より大きいか
どうかを判断します。その場合、関数は対応する結果の ARRAY 構成要
素にゼロ以外の値を返します。expr1 が expr2 以下の場合、関数は対
応する結果の ARRAY 構成要素にゼロを返します。
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_COMPARISON_FUNCTION
リレーショナル
関数
説明
ARRAY_GE
「~以上」関数。2 つの式を比較し、expr1 が expr2 以上かどうかを判
断します。その場合、関数は対応する結果の ARRAY 構成要素にゼロ以
外の値を返します。expr1 が expr2 より小さい場合、関数は対応する
結果の ARRAY 構成要素にゼロを返します。
ARRAY_LT
「より小さい」関数。2 つの式を比較し、expr1 が expr2 より小さいか
どうかを判断します。その場合、関数は対応する結果の ARRAY 構成要
素にゼロ以外の値を返します。expr1 が expr2 以上の場合、関数は対
応する結果の ARRAY 構成要素にゼロを返します。
ARRAY_LE
「~以下」関数。2 つの式を比較し、expr1 が expr2 以下かどうかを判
断します。その場合、関数は対応する結果の ARRAY 構成要素にゼロ以
外の値を返します。expr1 が expr2 より大きい場合、関数は対応する
結果の ARRAY 構成要素にゼロを返します。
ARRAY_EQ
「等しい」関数。2 つの式を比較し、expr1 が expr2 に等しいかどうか
を判断します。その場合、関数は対応する結果の ARRAY 構成要素にゼ
ロ以外の値を返します。expr1 が expr2 と等しくない場合、関数は対
応する結果の ARRAY 構成要素にゼロを返します。
ARRAY_NE
「等しくない」関数。2 つの式を比較し、expr1 が expr2 に等しくない
かを判断します。2 つの式が等しくない場合、関数は対応する結果の
ARRAY 構成要素にゼロ以外の値を返します。expr1 が expr2 と等しい
場合、関数は対応する結果の ARRAY 構成要素にゼロを返します。
使用上の注意
リレーショナル関数 ARRAY_GT、ARRAY_GE、ARRAY_LT、ARRAY_LE、
ARRAY_EQ、および ARRAY_NE の場合、ARRAY タイプでは 2 つの形式をサポート
しています。
第 1 の形式では、左側と右側両方のオペランドが同じ ARRAY タイプの 2 つのイン
スタンスです。
リレーショナル演算が対になって、2 つの引数内の一致する構成要素のペアそれぞ
れを 1 つずつ実行します。任意選択の引数 scope_reference が定義されている場合、
操作はその適用範囲内の構成要素についてのみ実行されます。scope_reference の
境界外にある構成要素はすべて NULL に設定されます。
結果は、入力配列引数と同じタイプの ARRAY となり、m=n である DECIMAL(m,n)
以外のすべての数値タイプについて、1 (true)、0 (false)、または NULL の 3 つのう
ちいずれかの値が入ります。m=n である DECIMAL(m,n)の場合、小数点の左側の桁
は許されないことから、関数は 1 という値を格納できません。この場合、関数は.
9[0]を返します。1 を超える高レベルの精度の場合、右側は 0 が埋め込まれます。
SQL 関数、演算子、式および述部
179
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_COMPARISON_FUNCTION
第 2 の形式では、左側または右側のいずれか一方が、有効な Teradata データ タイ
プを持つ ARRAY です。また、その他のオペランドは、左側の ARRAY に対して定義
されたものと同じデータ タイプの数値です。
リレーショナル演算は、数値引数を ARRAY 引数の各構成要素に適用することで実行
します。任意選択の引数 scope_reference が定義されている場合、操作はその適用範
囲内の構成要素についてのみ実行されます。scope_reference の境界外にある構成要
素はすべて NULL に設定されます。
結果は、入力配列引数と同じタイプの ARRAY となり、m=n である DECIMAL(m,n)以
外のすべての数値タイプについて、1 (true)、0 (false)、または NULL の 3 つのうち
いずれかの値が入ります。m=n である DECIMAL(m,n)の場合、小数点の左側の桁は
許されないことから、関数は 1 という値を格納できません。この場合、関数は.9[0]
を返します。1 を超える高レベルの精度の場合、右側は 0 が埋め込まれます。右側
が NULL と判断されると、NULL が返されます。
リレーショナル比較関数のどちらの形式でも、ARRAY 引数内に NULL 構成要素があ
ると、結果の ARRAY のその位置には NULL 構成要素が入ります。配列を呼び出す比
較は、CREATE TYPE 文内の任意選択の DEFAULT NULL 句の影響は受けません。た
だし、DEFAULT NULL 句を指定せずに作成された配列を比較するときにエラーにな
る確率は高まります。
ARRAY 引数に初期化されていない状態にある構成要素が含まれている場合、エラー
が返されます。適用範囲の参照を使用して、初期化されてない構成要素が含まれて
いる ARRAY の範囲の参照を回避するか、初期化されていない構成要素を NULL に設
定します。これは、OEXTEND メソッドを使用して行なえます。「OEXTEND」を参
照してください。
制約事項
ARRAY 値のリレーショナル比較はできません。ARRAY データには、いかなるリレー
ショナル比較演算子も使用できません。リレーショナル比較ができるのは、ARRAY
の個々の構成要素に限られます。
例
例: 1-D ARRAY データ型とテーブルへの問合わせ
次の 1-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE item_price AS DECIMAL(7,2) ARRAY[10];
CREATE TABLE inventory (itemkind INTEGER,
regular_price item_price,
sale_price item_price);
sale_price と regular_price という配列の構成要素の値が次のようになっているとし
ます。
180
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_COMPARISON_FUNCTION
sale_price[1:10] = 50, 100, 200, 90, 250, 550, 200, 200, 50, 75
regular_price[1:10] = 100, 300, 230, 110, 500, 550, 200, 400, 100, 150
次の問合わせは、構成要素のタイプ BYTEINT の適用範囲の参照[1:10]で 1-D ARRAY
を返します。評価中、regular_price 配列内の指定した適用範囲[5:10]にある各構成
要素を、リレーショナル関数 ARRAY_GT を使用して sale_price 配列の対応する構成
要素と比較します。出力配列内の結果の値は、ゼロまたはまたはゼロ以外の適用範
囲内の構成要素の数、そして、配列のそれ以外のすべての構成要素については NULL
となります。
SELECT ARRAY_GT(regular_price, sale_price, 5,10)
FROM inventory;
問合わせの出力は、次の値を持つ 1-D ARRAY です。
output_array[1:10] = [ NULL, NULL, NULL, NULL, 1, 0, 0, 1, 1, 1]
次の問合わせは、item_price タイプの適用範囲の参照[1:10]で 1-D ARRAY を返しま
す。評価中、regular_price 配列内の指定した適用範囲[5:10]にある各構成要素を、
リレーショナル関数 ARRAY_GT を使用して sale_price 配列の対応する構成要素と比
較します。構成要素のタイプ BYTEINT の値(ゼロまたはゼロ以外の数)からなる結果
の ARRAY は、regular_price 配列の対応する構成要素の値を乗じたものです。
SELECT ARRAY_MUL(regular_price, ARRAY_GT(sale_price, regular_price, 5,
10))
FROM inventory;
問合わせの出力は、次の値を持つ 1-D ARRAY です。
output_array[1:10] = [ NULL, NULL, NULL, NULL, 500, 0, 0, 400, 100, 150]
次の問合わせでは、リレーショナル関数 ARRAY_LT で 1-D ARRAY sale_price の適用
範囲内にある各構成要素をリテラル値 100 と比較します。構成要素の値が 100 よ
り小さい場合、比較関数はゼロ以外の値を返し、それ以外の場合、条件が満たされ
ていない場合は 0 を、構成要素が初期化されない場合は NULL を返します。
item_price ARRAY タイプの 1-D ARRAY は、入力 1-D ARRAY の各構成要素の対応す
る値が設定されて返ります。
SELECT ARRAY_LT(sale_price,100)
FROM inventory;
問合わせの出力は、次の値を持つ 1-D ARRAY です。
output_array[1:10] = [ 1, 0 , 0, 1, 0, 0, 0, 0, 1, 1]
例: 2-D ARRAY データ型とテーブルへの問合わせ
次の 2-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE shot_ary AS VARRAY(1:50)(1:50) OF INTEGER DEFAULT NULL;
CREATE TABLE seismic_data (
SQL 関数、演算子、式および述部
181
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_ARITHMETIC_FUNCTION
id INTEGER,
shot1 shot_ary,
shot2 shot_ary);
次の問合わせは、構成要素のタイプが INTEGER の 2-D ARRAY を返します。出力配
列のサイズは、入力配列引数のサイズと同じです。評価中、shot1 配列内の位置[5]
[10]にある構成要素が値 5 と比較されます。構成要素が 5 より大きい場合、出力配
列にある対応する構成要素の値がゼロ以外の値に設定されます。その他の場合は 0
に設定されます。出力配列内のその他すべての構成要素は NULL に設定されます。
SELECT ARRAY_GT(shot1, 5, NEW arrayVec(5,5), NEW arrayVec(10,10))
FROM seismic_data;
次は、メソッドスタイルの構文を使用した同じ問合わせです。
SELECT shot1.ARRAY_GT(5, NEW arrayVec(5,5), NEW arrayVec(10,10))
FROM seismic_data;
次の問合わせでは、リレーショナル関数 ARRAY_LT で 2-D ARRAY shot1 の適用範囲
の参照[3:5][8:10]内にある各構成要素をリテラル値 0 と比較します。構成要素の値
が 0 より小さい場合、比較関数は 0 を返し、それ以外の場合ゼロ以外の値を返しま
す。shot_ary タイプの結果の配列は、shot1 配列を乗じたものです。
SELECT ARRAY_MUL(shot1, ARRAY_LT(shot1, 0, NEW arrayVec(3,8), NEW
arrayVec(5,10)))
FROM seismic_data;
ARRAY_ARITHMETIC_FUNCTION
目的
ARRAY 値に算術演算(加算、減算、乗算、除算、および剰余)を実行し、配列全体ま
たは適用範囲のいずれかを参照します。
システム関数の構文
ARRAY_ADD
( expr1, expr2
ARRAY_SUB
)
, scope_reference
ARRAY_MUL
ARRAY_DIV
ARRAY_MOD
構文
メソッドスタイルの構文
182
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_ARITHMETIC_FUNCTION
expr1.
ARRAY_ADD
( expr2
ARRAY_SUB
)
, scope_reference
ARRAY_MUL
ARRAY_DIV
ARRAY_MOD
構文要素
expr1/expr2
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
配列の構成要素のタイプは NUMERIC データ型でなければなりません。
scope_reference
ARRAY 適用範囲の参照。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
ARRAY 算術関数に対して有効な引数は、次のいずれかです。
• expr1 および expr2 は、それぞれが同じ ARRAY タイプのインスタンスです。
• expr1 は数値引数型の ARRAY 値であり、expr2 は expr1 の要素型に割り当てる
ことのできる数値です。
expr1 または expr2 のどちらかが NULL の場合、この関数は NULL を返します。
使用上の注意
算術関数 ARRAY_ADD、ARRAY_SUB、ARRAY_MUL、ARRAY_DIV、および
ARRAY_MOD の場合、ARRAY タイプでは 2 つの形式をサポートしています。
第 1 の形式では、左側と右側両方のオペランドが同じ ARRAY タイプの 2 つのイン
スタンスです。
算術演算が対になって、2 つの引数内の一致する構成要素のペアそれぞれを 1 つず
つ実行します。任意選択の引数 scope_reference が定義されている場合、操作はそ
の適用範囲内の構成要素についてのみ実行されます。scope_reference の境界外に
ある構成要素はすべて NULL に設定されます。結果は、入力 ARRAY 引数と同じデー
SQL 関数、演算子、式および述部
183
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_ARITHMETIC_FUNCTION
タ タイプの ARRAY で、カーディナリティ(取り込まれた構成要素の数)は最初の入力
ARRAY 引数と同じです。
第 2 の形式では、左側または右側のどちらか一方が数値引数タイプの ARRAY とな
り、右側は左側の構成要素のタイプに割り当てることのできる数値です。算術演算
は、算術演算子を持つ右側の値を左側の ARRAY 引数の各構成要素に適用することで
実行します。結果は、入力 ARRAY 引数と同じタイプの ARRAY で、カーディナリティ
(取り込まれた構成要素の数)は入力 ARRAY 引数と同じです。任意選択の引数
scope_reference が定義されている場合、操作はその適用範囲内の構成要素について
のみ実行されます。scope_reference の境界外にある構成要素はすべて NULL に設定
されます。
算術関数のどちらの形式でも、ARRAY 引数内に NULL 構成要素があると、結果の
ARRAY のその位置には NULL 構成要素が入ります。配列を呼び出す算術演算は、
CREATE TYPE 文内の任意選択の DEFAULT NULL 句の影響は受けません。ただし、
DEFAULT NULL 句を指定せずに作成された配列を比較するときにエラーになる確率
は高まります。
ARRAY 引数に初期化されていない状態にある構成要素が含まれている場合、エラー
が返されます。適用範囲の参照を使用して、初期化されてない構成要素が含まれて
いる ARRAY の範囲の参照を回避するか、初期化されていない構成要素を NULL に設
定します。これは、OEXTEND メソッドを使用して行なえます。「OEXTEND」を参
照してください。
結果のタイプと値
結果は、入力配列引数の最大カーディナリティと同じサイズの ARRAY で、構成要素
のタイプは expr1 と同じです。結果の配列タイプのサイズは、現在のカーディナリ
ティを指すことに注意してください。
例
例: ARRAY を使用した、1-D ARRAY データ型とテーブルへの問合わせ
次の 1-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE item_price AS DECIMAL(7,2) ARRAY[20];
CREATE TABLE inventory (itemkind INTEGER,
regular_price item_price,
sale_price_diff item_price);
sale_price_diff と regular_price という配列の構成要素の値が次のようになっている
とします。
sale_price_diff[1:20] =
184
100, 200, 120, 140, 50, 160, 45, 10, 90, 100
50, 100, 200, 90, 250, 550, 200, 200, 50, 75
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_ARITHMETIC_FUNCTION
regular_price[1:20] =
50, 90, 80, 10, 45, 30, 20, 10, 90, 100,
100, 300, 230, 110, 500, 550, 200, 400, 100, 150
次の問合わせは、構成要素のタイプが item_price の 1-D ARRAY を返します。評価
中、regular_price 配列内の指定した適用範囲にある各構成要素を、算術関数
ARRAY_SUB を使用して sale_price_diff 配列の対応する構成要素と組み合わせます。
SELECT ARRAY_SUB(regular_price, sale_price_diff, 10, 20)
FROM inventory;
問合わせは、次の値を持つ 1-D ARRAY を返します。
output_array[1:20] = [ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
NULL, NULL, 50, 200, 30, 20, 250, 0, 0, 200, 50, 75]
次の問合わせでは、1-D ARRAY sale_price_diff 内のすべての構成要素にリテラル値
2 が加算されます。
SELECT ARRAY_ADD(sale_price_diff, 2) FROM inventory;
この問合わせは、次の値を持つ 1-D ARRAY を返します。
output_array[1:20] = [ 102, 202, 122, 142, 52, 162, 47, 12, 92, 102
52, 102, 202, 92, 252, 552, 202, 202, 52, 77]
次の問合わせは、ARRAY に算術演算を実行しながらフィルタ処理条件を使用する方
法を示したものです。この例では、適用範囲[10:20]内で値が 1000 未満のすべての
構成要素に 2 を乗じます。
SELECT ARRAY_MUL(regular_price, 2, 10, 20) FROM inventory
WHERE ARRAY_COUNT_DISTINCT(ARRAY_LT(regular_price,1000,10,20),1)>1;
この問合わせは、次の値を持つ 1-D ARRAY を返します。
output_array[1:20] = [NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
NULL, NULL, 200, 600, 460, 220, 1000, 1100, 400, 800, 200, 300]
例: ARRAY を使用した、2-D ARRAY データ型とテーブルへの問合わせ
次の 2-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE shot_ary AS VARRAY(1:50)(1:50) OF INTEGER DEFAULT NULL;
CREATE TABLE seismic_data (
id INTEGER,
shot1 shot_ary,
shot2 shot_ary);
次の問合わせは、操作の結果更新された適用範囲の参照[10:20][10:20]に構成要素
を持つ shot_ary タイプの ARRAY を返します。評価中、shot1 内の指定した適用範
囲の参照にある各構成要素を、算術関数 ARRAY_ADD を使用して shot2 の対応する
構成要素と組み合わせます。
SQL 関数、演算子、式および述部
185
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_SUM
SELECT ARRAY_ADD(shot1, shot2, NEW arrayVec(10, 20),
NEW arrayVec(10,20))
FROM seismic_data;
次の問合わせでは、shot1 配列の指定した適用範囲の参照内のすべての構成要素にリ
テラル値 9 が加算されます。
SELECT ARRAY_ADD(shot1, 9, NEW arrayVec(10,10), NEW arrayVec(20,20))
FROM seismic_data;
次は、メソッドスタイルの構文を使用した同じ問合わせです。
SELECT shot1.ARRAY_ADD(9, NEW arrayVec(10,10), NEW arrayVec(20,20)) FROM
seismic_data;
次の問合わせは、n-D ARRAY に算術演算を実行しながらフィルタ処理条件を使用す
る方法を示したものです。この例では、適用範囲[10:20][10:20]内で負の数を値に持
つすべての構成要素にゼロを乗じます。
SELECT ARRAY_MUL(shot1, 0, NEW arrayVec(10,10), NEW arrayVec(20,20))
FROM seismic_data
WHERE ARRAY_COUNT_DISTINCT(ARRAY_LT(shot1, 0, NEW arrayVec(10,10),
NEW arrayVec(20,20)),0)>1;
関連トピック
詳細は、「ARRAY コンストラクタ式」を参照してください。
ARRAY_SUM
目的
array_expr 内の各構成要素の値を加算した総合計、または指定した適用範囲内の構
成要素の合計を表わす値を返します。
構文
システム関数の構文
ARRAY_SUM
( array_expr
)
scope_reference
メソッドスタイルの構文
array_expr.ARRAY_SUM
(
)
scope_reference
186
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_SUM
構文要素
array_expr
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
配列の構成要素のタイプは NUMERIC データ型でなければなりません。
scope_reference
ARRAY 適用範囲の参照。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
ARRAY_SUM は、引数として配列式を取り、配列引数内の各構成要素の値を加算し
た総合計を表わすスカラー値を返します。配列引数の構成要素のタイプは数値でな
ければなりません。適用範囲の参照を指定する場合は、合計は指定された適用範囲
内にある構成要素のみに適用されます。
影響を受ける構成要素は、条件式によるフィルタ処理はできません 。そのため、
ARRAY_SUM を呼び出す SELECT 文では、WHERE 句に配列リレーショナル式を含
めてはいけません。
配列引数に NULL 構成要素があると、その構成要素は無視され、計算には考慮され
ません。配列引数に初期化されていない状態にある構成要素が含まれている場合、
エラーが返されます。適用範囲の参照を使用して、初期化されてない構成要素を持
つ配列の範囲の参照を回避するか、初期化されていない構成要素を NULL に設定し
ます。これは、OEXTEND メソッドを使用して行なえます。「OEXTEND」を参照し
てください。
array_expr が NULL の場合、この関数は NULL を返します。
結果のタイプ
ARRAY_SUM の結果のタイプは NUMBER となります。ただし、配列引数の構成要
素のタイプが FLOAT である場合を除きます。この場合、結果のタイプは FLOAT と
なります。
SQL 関数、演算子、式および述部
187
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_SUM
例
例: ARRAY_SUM を使用した、1-D ARRAY データ型とテーブルへの問合わせ
次の 1-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE item_price AS DECIMAL(7,2) ARRAY[20];
CREATE TABLE inventory (itemkind INTEGER,
regular_price item_price,
sale_price item_price);
次の問合わせを評価するとき、regular_price 配列の各構成要素の値が加算されます。
結果の値は 2 で除算されます。
SELECT ARRAY_SUM(regular_price) / 2 FROM inventory;
次は、メソッドスタイルの構文を使用した同じ問合わせです。
SELECT regular_price.ARRAY_SUM() / 2 FROM inventory;
次の問合わせでは、ARRAY_SUM により、regular_price 配列内の指定した適用範囲
内にある各構成要素が加算されます。問合わせからは、regular_price 配列内の影響
を受ける構成要素の値を加算した総合計を表わす値が返ります。
SELECT ARRAY_SUM(regular_price, NEW arrayVec(5,10))FROM inventory;
次に、同じ問合わせを指定する別の方法を示します。
SELECT ARRAY_SUM(regular_price, 5, 10) FROM inventory;
例: ARRAY_SUM を使用した、2-D ARRAY データ型とテーブルへの問合わせ
次の 2-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE shot_ary AS INTEGER ARRAY[1:50][1:50];
CREATE TABLE seismic_data (
id INTEGER,
shot1 shot_ary,
shot2 shot_ary);
次の問合わせを評価するとき、shot1 配列内の各構成要素の値が加算されます。結果
の値は 2 で除算されます。
SELECT ARRAY_SUM(shot1) / 2 FROM seismic_data;
次の問合わせでは、ARRAY_SUM により、shot1 配列内の指定した適用範囲の参照内
にある各構成要素が加算されます。問合わせからは、shot1 配列内の影響を受ける構
成要素の値を加算した総合計を表わす値が返ります。
SELECT ARRAY_SUM(shot1, NEW arrayVec(5,5), NEW arrayVec(10,10)) FROM
seismic_data;
188
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_AVG
関連トピック
詳細は、「ARRAY コンストラクタ式」を参照してください。
ARRAY_AVG
目的
array_expr 内のすべての構成要素の値の平均値または指定された適用範囲内の構成
要素の平均値を返します。
構文
システム関数の構文
ARRAY_AVG
( array_expr
)
scope_reference
メソッドスタイルの構文
array_expr.ARRAY_AVG
(
)
scope_reference
構文要素
array_expr
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
配列の構成要素のタイプは NUMERIC データ型でなければなりません。
scope_reference
ARRAY 適用範囲の参照。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
ARRAY_AVG は、引数として配列式を取り、FLOAT タイプのスカラー値を返しま
す。この値は、配列引数内の各構成要素の値の加算を表わし、この結果を構成要素
の合計数で除算した結果を表わします。配列引数の構成要素のタイプは数値でなけ
SQL 関数、演算子、式および述部
189
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_AVG
ればなりません。適用範囲の参照を指定する場合は、関数は指定された適用範囲内
にある構成要素のみに適用されます。
影響を受ける構成要素は、条件式によるフィルタ処理はできません 。そのため、
ARRAY_AVG を呼び出す SELECT 文では、WHERE 句に配列リレーショナル式を含め
てはいけません。
配列引数に NULL 構成要素があると、その構成要素は無視され、計算には考慮され
ません。配列引数に初期化されていない状態にある構成要素が含まれている場合、
エラーが返されます。適用範囲の参照を使用して、初期化されてない構成要素を持
つ配列の範囲の参照を回避するか、初期化されていない構成要素を NULL に設定し
ます。これは、OEXTEND メソッドを使用して行なえます。「OEXTEND」を参照し
てください。
array_expr が NULL の場合、この関数は NULL を返します。
結果のタイプ
ARRAY_AVG の結果のデータ タイプは FLOAT です。
例
例: ARRAY_AVG を使用した、1-D ARRAY データ型とテーブルへの問合わせ
次の 1-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE item_price AS DECIMAL(7,2) ARRAY[20];
CREATE TABLE inventory (itemkind INTEGER,
regular_price item_price,
sale_price item_price);
次の問合わせを評価するとき、regular_price 配列の各構成要素の値が加算されます。
その後で、すべての構成要素の値の総合計を regular_price 配列内の構成要素数で除
算します。
SELECT ARRAY_AVG(regular_price) FROM inventory;
次の問合わせでは、ARRAY_AVG により、regular_price 配列内の指定した適用範囲
内にある各構成要素が加算されます。結果は、影響を受ける regular_price の構成要
素の値を加算した総合計を、指定した適用範囲を構成する要素の総合計数で除算し
たものを表わすスカラー値です。
SELECT ARRAY_AVG(regular_price, 5, 10)FROM inventory;
例: ARRAY_AVG を使用した、2-D ARRAY データ型とテーブルへの問合わせ
次の 2-D ARRAY データ タイプおよび表について考えてみましょう。
190
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_MAX
CREATE TYPE shot_ary AS INTEGER ARRAY[1:50][1:50];
CREATE TABLE seismic_data (
id INTEGER,
shot1 shot_ary,
shot2 shot_ary);
次の問合わせを評価するとき、shot1 配列内の各構成要素の値が加算されます。そ
の後で、すべての構成要素の値の総合計を shot1 配列内の構成要素数で除算します。
SELECT ARRAY_AVG(shot1) FROM seismic_data;
次の問合わせでは、ARRAY_AVG により、shot1 配列内の指定した適用範囲の参照
内にある各構成要素が加算されます。結果は、影響を受ける shot1 の構成要素の値
を加算した総合計を、指定した適用範囲を構成する要素の総合計数で除算したもの
を表わすスカラー値です。
SELECT ARRAY_AVG(shot1, NEW arrayVec(5,5), NEW arrayVec(10,10))
FROM seismic_data;
次は、メソッドスタイルの構文を使用した同じ問合わせです。
SELECT shot1.ARRAY_AVG(NEW arrayVec(5,5), NEW arrayVec(10,10))
FROM seismic_data;
ARRAY_MAX
目的
array_expr 内のすべての構成要素の値の最大値または指定された適用範囲内の構成
要素の最大値を返します。
構文
システム関数の構文
ARRAY_MAX
( array_expr
)
, scope_reference
メソッドスタイルの構文
array_expr.ARRAY_MAX
(
)
, scope_reference
構文要素
array_expr
次のいずれかである ARRAY 式。
SQL 関数、演算子、式および述部
191
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_MAX
•
•
•
•
ARRAY 列の参照
ARRAY コンストラクタ式
UDF 式
UDM 式
配列の構成要素のタイプは NUMERIC データ型でなければなりません。
scope_reference
ARRAY 適用範囲の参照。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
ARRAY_MAX は、引数として配列式を取り、配列を構成するすべての要素の最大値
を表わす構成要素の値を返します。適用範囲の参照を指定する場合は、関数は指定
された適用範囲内にある構成要素のみに適用されます。
影響を受ける構成要素は、条件式によるフィルタ処理はできません 。そのため、
ARRAY_MAX を呼び出す SELECT 文では、WHERE 句に配列リレーショナル式を含め
てはいけません。
配列引数に NULL 構成要素があると、その構成要素は無視され、計算には考慮され
ません。配列引数に初期化されていない状態にある構成要素が含まれている場合、
エラーが返されます。適用範囲の参照を使用して、初期化されてない構成要素を持
つ配列の範囲の参照を回避するか、初期化されていない構成要素を NULL に設定し
ます。これは、OEXTEND メソッドを使用して行なえます。「OEXTEND」を参照し
てください。
array_expr が NULL の場合、この関数は NULL を返します。
結果のタイプ
結果のタイプは、配列引数の構成要素のタイプと同じです。
例
例: ARRAY_MAX を使用した、1-D ARRAY データ型とテーブルへの問合わせ
次の 1-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE item_price AS DECIMAL(7,2) ARRAY[20];
CREATE TABLE inventory (itemkind INTEGER,
regular_price item_price,
sale_price item_price);
192
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_MIN
次の問合わせは、regular_price 配列内のすべての構成要素の値の最大値となる構成
要素の値を返します。
SELECT ARRAY_MAX(regular_price) FROM inventory;
次は、メソッドスタイルの構文を使用した同じ問合わせです。
SELECT regular_price.ARRAY_MAX() FROM inventory;
次の問合わせは、regular_price 配列内の指定した適用範囲内の構成要素の値の最大
値となる構成要素の値を返します。
SELECT ARRAY_MAX(regular_price, 5, 10)FROM inventory;
例: ARRAY_MAX を使用した、2-D ARRAY データ型とテーブルへの問合わせ
次の 2-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE shot_ary AS INTEGER ARRAY[1:50][1:50];
CREATE TABLE seismic_data (
id INTEGER,
shot1 shot_ary,
shot2 shot_ary);
次の問合わせは、short1 配列内のすべての構成要素の値の最大値となる構成要素の
値を返します。
SELECT ARRAY_MAX(shot1) FROM seismic_data;
次の問合わせは、shot1 配列内の指定した適用範囲内の構成要素の値の最大値とな
る構成要素の値を返します。
SELECT ARRAY_MAX(shot1, NEW arrayVec(5,5), NEW arrayVec(10,10))
FROM seismic_data;
ARRAY_MIN
目的
array_expr 内のすべての構成要素の値の最小値または指定された適用範囲内の構成
要素の最小値を返します。
構文
システム関数の構文
ARRAY_MIN
( array_expr
)
, scope_reference
メソッドスタイルの構文
SQL 関数、演算子、式および述部
193
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_MIN
array_expr.ARRAY_MIN
(
)
, scope_reference
構文要素
array_expr
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
配列の構成要素のタイプは NUMERIC データ型でなければなりません。
scope_reference
ARRAY 適用範囲の参照。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
ARRAY_MIN は、引数として配列式を取り、配列を構成するすべての要素の最小値
を表わす構成要素の値を返します。適用範囲の参照を指定する場合は、関数は指定
された適用範囲内にある構成要素のみに適用されます。
影響を受ける構成要素は、条件式によるフィルタ処理はできません 。そのため、
ARRAY_MIN を呼び出す SELECT 文では、WHERE 句に配列リレーショナル式を含め
てはいけません。
配列引数に NULL 構成要素があると、その構成要素は無視され、計算には考慮され
ません。配列引数に初期化されていない状態にある構成要素が含まれている場合、
エラーが返されます。適用範囲の参照を使用して、初期化されてない構成要素を持
つ配列の範囲の参照を回避するか、初期化されていない構成要素を NULL に設定し
ます。これは、OEXTEND メソッドを使用して行なえます。「OEXTEND」を参照し
てください。
array_expr が NULL の場合、この関数は NULL を返します。
結果のタイプ
結果のタイプは、配列引数の構成要素のタイプと同じです。
194
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_MIN
例
例: ARRAY_MIN を使用した、1-D ARRAY データ型とテーブルへの問合わせ
次の 1-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE item_price AS DECIMAL(7,2) ARRAY[20];
CREATE TABLE inventory (itemkind INTEGER,
regular_price item_price,
sale_price item_price);
次の問合わせは、regular_price 配列内のすべての構成要素の値の最小値となる構成
要素の値を返します。
SELECT ARRAY_MIN(regular_price) FROM inventory;
次の問合わせは、regular_price 配列内の指定した適用範囲内の構成要素の値の最小
値となる構成要素の値を返します。
SELECT ARRAY_MIN(regular_price, 5, 10)FROM inventory;
例: ARRAY_MIN を使用した、2-D ARRAY データ型とテーブルへの問合わせ
次の 2-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE shot_ary AS INTEGER ARRAY[1:50][1:50];
CREATE TABLE seismic_data (
id INTEGER,
shot1 shot_ary,
shot2 shot_ary);
次の問合わせは、short1 配列内のすべての構成要素の値の最小値となる構成要素の
値を返します。
SELECT ARRAY_MIN(shot1) FROM seismic_data;
次の問合わせは、shot1 配列内の指定した適用範囲内の構成要素の値の最小値とな
る構成要素の値を返します。
SELECT ARRAY_MIN(shot1, NEW arrayVec(5,5), NEW arrayVec(10,10))
FROM seismic_data;
次は、メソッドスタイルの構文を使用した同じ問合わせです。
SELECT shot1.ARRAY_MIN(NEW arrayVec(5,5), NEW arrayVec(10,10))
FROM seismic_data;
関連トピック
詳細は、「ARRAY コンストラクタ式」を参照してください。
SQL 関数、演算子、式および述部
195
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_COUNT_DISTINCT
ARRAY_COUNT_DISTINCT
目的
array_expr 内の、任意選択で指定した入力値と一致する固有(Distinct)構成要素の数
を返します。
構文
システム関数の構文
ARRAY_COUNT_DISTINCT
( array_expr
)
, scope_reference
, matching_expr
メソッドスタイルの構文
array_expr.ARRAY_COUNT_DISTINCT
(
)
scope_reference
, matching_expr
構文要素
array_expr
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
配列の構成要素のタイプは NUMERIC データ型でなければなりません。
scope_reference
ARRAY 適用範囲の参照。
matching_expr
配列内の 1 つ以上の要素と一致させる式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
ARRAY_COUNT_DISTINCT は、引数として配列式を取り、可能な 2 つの出力の 1 つ
を表わす値を返します。
• 任意選択の引数 matching_expr を指定する場合、関数は、matching_expr と値が
等しい array_expr 内の構成要素の数を返します。matching_expr が NULL の場
合、関数は NULL の構成要素の値を返します。
196
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_COUNT_DISTINCT
• 任意選択の引数 matching_expr を指定しない場合、関数は、array_expr 内の固
有(Distinct)構成要素の数を返します。配列引数に NULL 構成要素があると、その
構成要素は無視され、計算には考慮されません。
適用範囲の参照を指定する場合は、関数は指定された適用範囲内にある構成要素の
みに適用されます。ARRAY_COUNT_DISTINCT は、構成要素のタイプが数値と文字
の配列で使用できます。
配列引数に初期化されていない状態にある構成要素が含まれている場合、エラーが
返されます。適用範囲の参照を使用して、初期化されてない構成要素を持つ配列の
範囲の参照を回避するか、初期化されていない構成要素を NULL に設定します。こ
れは、OEXTEND メソッドを使用して行なえます。「OEXTEND」を参照してくださ
い。
array_expr が NULL の場合、この関数は NULL を返します。
結果のタイプ
結果の型は INTEGER です。
例
例: ARRAY_COUNT_DISTINCT を使用した、1-D ARRAY データ型とテーブルへの問合わせ
次の 1-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE item_price AS DECIMAL(7,2) ARRAY[20];
CREATE TABLE inventory (itemkind INTEGER,
regular_price item_price,
sale_price item_price);
次の問合わせで、ARRAY_COUNT_DISTINCT は regular_price 配列内の適用範囲の
参照内で 100 に等しい値を持つ構成要素の数を返します。
SELECT ARRAY_COUNT_DISTINCT(regular_price, 5, 10, 100) FROM inventory;
次は、メソッドスタイルの構文を使用した同じ問合わせです。
SELECT regular_price.ARRAY_COUNT_DISTINCT(5, 10, 100) FROM inventory;
次の問合わせは、regular_price 配列内の固有(Distinct)構成要素の数を返します。
SELECT ARRAY_COUNT_DISTINCT(regular_price)FROM inventory;
例: ARRAY_COUNT_DISTINCT を使用した、2-D ARRAY データ型とテーブルへの問合わせ
次の 2-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE shot_ary AS INTEGER ARRAY[1:50][1:50];
CREATE TABLE seismic_data (
SQL 関数、演算子、式および述部
197
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_GET
id INTEGER,
shot1 shot_ary,
shot2 shot_ary);
次の問合わせで、ARRAY_COUNT_DISTINCT は short1 配列内の指定した適用範囲内
で 100 に等しい値を持つ構成要素の数を返します。
SELECT ARRAY_COUNT_DISTINCT(shot1, NEW arrayVec(5,5), NEW
arrayVec(10,10), 100) FROM seismic_data;
ARRAY_GET
目的
指定した索引位置に対応する array_expr 内の構成要素の値を返します。
構文
システム関数の構文
ARRAY_GET
( array_expr, array_index )
メソッドスタイルの構文
array_expr.ARRAY_GET
( array_index )
構文要素
array_expr
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
array_index
次のいずれかを指定します:
• 整数値。
• 事前定義された配列タイプ ArrayVec の配列インスタンスで、境界を定義する整
数値のカンマ区切りリストを指定したもの。
• array_index の値は、array_expr の範囲内である必要があります。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
198
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_GET
使用上の注意
ARRAY_GET は、引数として配列式を取り、array_index で指定した位置に対応する
array_expr 内の構成要素の値を返します。
array_expr が 1 次元 ARRAY タイプの場合、位置決めする構成要素の索引は
INTEGER または ArrayVec 型で定義され、array_expr の定義済みの境界の範囲内に
なければなりません。
array_expr が多次元 ARRAY タイプの場合、位置決めする構成要素の索引は、事前
定義された配列タイプ ArrayVec を使用して定義されます。ArrayVec タイプの詳細
は、「ARRAY 適用範囲の参照」を参照してください。ArrayVec により定義される
次元数は、2~5 (サポートされる次元数の最大値)とし、array_expr 内の次元数に対
応しなければなりません。各次元の値はカンマで区切り、array_expr の定義済みの
境界の範囲内でなければなりません。
array_index の値が初期化されていない状態の ARRAY の構成要素を参照する場合、
エラーが返されます。初期化されてない ARRAY の構成要素の参照を回避するには、
初期化されていない構成要素を NULL に設定します。これは、OEXTEND メソッド
を使用して行なえます。「OEXTEND」を参照してください。
array_expr が NULL の場合、この関数は NULL を返します。
結果のタイプ
結果のタイプは、配列引数の構成要素のタイプと同じです。
例
例: ARRAY_GET を使用した、1-D ARRAY データ型とテーブルへの問合わせ
次の 1-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE item_price AS VARRAY(50) OF DECIMAL(7,2);
CREATE TABLE inventory (itemkind INTEGER,
regular_price item_price,
sale_price item_price);
次の問合わせでは、ARRAY_GET は、regular_price 配列の位置 40 にある構成要素
の値を返します。
SELECT ARRAY_GET(regular_price,40) FROM inventory;
例: ARRAY_GET を使用した、2-D ARRAY データ型とテーブルへの問合わせ
次の 2-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE shot_ary AS INTEGER ARRAY[1:50][1:50];
CREATE TABLE seismic_data (
SQL 関数、演算子、式および述部
199
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_COMPARE
id INTEGER,
shot1 shot_ary,
shot2 shot_ary);
次の問合わせでは、ARRAY_GET は、short1 配列の位置[5][10]にある構成要素の値
を返します。
SELECT ARRAY_GET(shot1, NEW arrayVec(5,10)) FROM seismic_data;
次は、メソッドスタイルの構文を使用した同じ問合わせです。
SELECT shot1.ARRAY_GET(NEW arrayVec(5,10)) FROM seismic_data;
ARRAY_COMPARE
目的
2 つの配列の構成要素の対の比較を実行し、1、0、または NULL という値を返し、
2 つの配列の引数が同じ構成要素の値を含んでいるかどうかを示します。
構文
システム関数の構文
ARRAY_COMPARE
( expr1, expr2
)
, scope_reference, nulls_equal_flag
メソッドスタイルの構文
expr1.ARRAY_COMPARE
( expr2
)
, scope_reference, nulls_equal_flag
構文要素
expr1 /expr2
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
scope_reference
ARRAY 適用範囲の参照。
nulls_equal_flag
NULL 要素の値の比較方法を指定するフラグ。このパラメータに対して有効な値は、
0 と 1 です。
200
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_COMPARE
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
関数は 2 つの配列の構成要素の対の比較を行ない、ANSI 規格による ARRAY 比較の
ルールに従います。
使用上の注意
ARRAY_COMPARE 関数は、2 つの配列引数の対の比較を行ない、2 つの配列式がす
べて同じ構成要素の値を含むかどうかを示すスカラー値を返します。
ARRAY_COMPARE は、次のような ANSI 配列比較のルールに従います。
1 expr1 または expr2 のどちらかが NULL と評価される場合、結果は NULL にな
ります。
2 expr1 のすべての構成要素の値が expr2 の構成要素の値と等しい場合にのみ、
expr1 および expr2 は等しくなります。
3 expr1 と expr2 両方が同じ値を持ち、配列内の同じ位置にある場合に限り、expr1
の構成要素の値は expr2 の構成要素の値と等しくなります。
4 非 NULL 構成要素が配列 A および配列 B の指定された構成要素と一致しない場
合、これは一致しないとみなされ、ARRAY_COMPARE は値 0 を返します。
5 指定した構成要素のどちらかまたは両方の値が NULL、かつ、配列内のそれ以外
のすべての構成要素が一致する場合、これは ANSI 規格に従って一致しないとみ
なされます。ANSI 規格に従えば、このケースの結果は UNKNOWN です。
Teradata では、これを NULL 結果と評価します。
上記のルール(1)または(5)を満たす場合、ARRAY_COMPARE は NULL を返します。
ルール(2)および(3)を満たす場合、ARRAY_COMPARE は 1 を返します。それ以外の
場合、ARRAY_COMPARE は 0 を返します。
任意選択の nulls_equal_flag を 1 に設定し、指定した構成要素の両方の値が NULL
の場合、これは一致するとみなされ、ANSI 規格とはずれがあります。それ以外のす
べての構成要素が一致する場合、上記のルール(2)が適用されます。
任意の引数 scope_reference を指定する場合は、関数は指定された適用範囲内にあ
る構成要素のみに適用されます。
配列引数に初期化されていない状態にある構成要素が含まれている場合、エラーが
返されます。適用範囲の参照を使用して、初期化されてない構成要素が含まれてい
る ARRAY の範囲の参照を回避するか、初期化されていない構成要素を NULL に設
定します。これは、OEXTEND メソッドを使用して行なえます。「OEXTEND」を参
照してください。
SQL 関数、演算子、式および述部
201
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_UPDATE
制約事項
ARRAY 値のリレーショナル比較はできません。ARRAY データには、いかなるリレー
ショナル比較演算子も使用できません。リレーショナル比較ができるのは、ARRAY
の個々の構成要素に限られます。
例: ARRAY_COMPARE を使用した、テーブルの問合わせ
この例では、inventory テーブルには、2 つの ARRAY 列(sale_price_june および
sale_price_july)があり、次の構成要素の値を持っています。
sale_price_june[1:10] = 50, 100, 200, 90, 250, 550, 200, 200, 50, 75
sale_price_july[1:10] = 50, 100, 200, 90, 250, 550, 200, 200, 50, 75
sale_price_june 配列内のすべての構成要素の値が sale_price_july 配列の構成要素の
値に等しいので、次の問合わせの出力は 1 です。
SELECT ARRAY_COMPARE(sale_price_june, sale_price_july)
FROM inventory;
次は、メソッドスタイルの構文を使用した同じ問合わせです。
SELECT sale_price_june.ARRAY_COMPARE(sale_price_july)
FROM inventory;
同じ配列を考えますが、構成要素の値は次のように異なっています。
sale_price_june[1:10] = 50, 100, 200, 90, 250, 550, 200, 200, 50, 75
sale_price_july[1:10] = 50, 100, 200, 90, 300, 550, 200, 200, 50, 75
位置 5 にある構成要素の値が 2 つの配列で異なるため、次の問合わせの出力は 0 で
す。
SELECT ARRAY_COMPARE(sale_price_june, sale_price_july)
FROM inventory;
次の問合わせは、位置 6~10 の構成要素の値を比較します。問合わせの出力は、両
方の配列の指定位置の構成要素の値が等しいため、1 になります。
SELECT ARRAY_COMPARE(sale_price_june, sale_price_july, 6, 10)
FROM inventory;
ARRAY_UPDATE
目的
array_expr 内の構成要素のすべてまたはサブセットを、指定した新しい値に更新し
ます。
構文
システム関数の構文
202
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_UPDATE
ARRAY_UPDATE
( array_expr, new_value
)
,
scope_reference
array_index
,
scope_reference
array_index
メソッドスタイルの構文
array_expr.ARRAY_UPDATE
( new_value
)
構文要素
array_expr
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
new_value
array_expr のエレメント タイプと同じデータ型を持つ値と評価される式です。
scope_reference
ARRAY 適用範囲の参照。
array_index
次のいずれかを指定します:
• 整数値。
• 事前定義された配列タイプ ArrayVec の配列インスタンスで、境界を定義する整
数値のカンマ区切りリストを指定したもの。
• array_index の値は、array_expr の範囲内である必要があります。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
ARRAY_UPDATE は、引数として配列式を取り、new_value で指定した値で
array_expr 内の構成要素のすべてまたはサブセットを更新します。
ARRAY_UPDATE 関数には、次に示すルールが適用されます。
• array_expr が NULL の場合、結果は NULL になります。
• new_value の値は、array_expr のエレメント タイプと同じデータ型と評価され
る必要があります。あるいは、暗黙的にエレメント タイプ ARRAY に変換できる
データ型であることが必要です。
SQL 関数、演算子、式および述部
203
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_UPDATE
• scope_reference または array_index を指定しない場合、array_expr 内のすべての
構成要素が new_value の値に更新されます。
• scope_reference を指定すると、array_expr の適用範囲の参照内の構成要素のみ
が new_value の値に更新されます。scope_reference は配列内の連続する構成要
素を参照する必要があります。
• array_index を指定すると、array_index で指定した単一の構成要素のみが、
array_expr 内の new_value の値に更新されます。
• 更新する構成要素が NULL の場合、NULL は array_expr 内の new_value の値で置
換されます。
• 1 つ以上の構成要素が変更され、更新する構成要素より前に ARRAY 値内に初期化
されていない構成要素がある場合、ARRAY_UPDATE はそれ以前の初期化されて
いない構成要素に NULL に設定します。この動作は、ARRAY 構成要素値を設定す
る通常の SQL UPDATE 文の動作と同じです。
結果のタイプと値
ARRAY_UPDATE は、新しい値に更新された指定の構成要素を使って array_expr で
指定した配列の新しいコピーを返します。
例
例: ARRAY_UPDATE を使用した、1-D ARRAY データ型とテーブルへの問合わせ
次の 1 次元の ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE phonenumbers AS CHAR(10) ARRAY[20];
CREATE TABLE employee_info (eno INTEGER, phonelist phonenumbers);
次の問合わせは、すべての構成要素が新しい値に更新された phonelist 配列の更新後
のコピーを返します。
SELECT ARRAY_UPDATE(phonelist, '9095551234')
FROM employee_info;
次の問合わせは、適用範囲の参照で指定したように、構成要素のサブセットが新し
い値に更新された phonelist 配列の更新後のコピーを返します。その結果、構成要素
2、3、および 4 は新しい値に更新されます。配列内の残りの構成要素は元の値のま
まです。
SELECT ARRAY_UPDATE(phonelist, '9095551234', 2, 4)
FROM employee_info;
次は、メソッドスタイルの構文を使用した同じ問合わせです。
SELECT phonelist.ARRAY_UPDATE('9095551234', 2, 4)
FROM employee_info;
204
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_UPDATE_STRIDE
例: ARRAY_UPDATE を使用した、2-D ARRAY データ型とテーブルへの問合わせ
次の 2-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE shot_ary AS INTEGER ARRAY[1:50][1:50];
CREATE TABLE seismic_data (
id INTEGER,
shot1 shot_ary,
shot2 shot_ary);
次の問合わせは、すべての構成要素は新しい値に更新された short1 配列の更新後の
コピーを返します。
SELECT ARRAY_UPDATE(shot1, 0)
FROM seismic_data;
次の問合わせは、適用範囲の参照で指定したように、構成要素のサブセットが新し
い値に更新された short1 配列の更新後のコピーを返します。その結果、適用範囲の
参照範囲[5:10][5:10]内にある構成要素は新しい値に更新されます。配列内の残りの
構成要素は元の値のままです。
SELECT ARRAY_UPDATE(shot1, 0, NEW arrayVec(5,5), NEW arrayVec(10,10))
FROM seismic_data;
関連トピック
詳細は、「ARRAY コンストラクタ式」を参照してください。
ARRAY_UPDATE_STRIDE
目的
array_expr 内の構成要素のすべてまたはサブセットを、指定した新しい値に更新し
ます。stride 引数は、構成要素を更新するにあたり、構成要素をいくつスキップす
るかを示します。
構文
システム関数の構文
ARRAY_ADD
( expr1, expr2
ARRAY_SUB
)
, scope_reference
ARRAY_MUL
ARRAY_DIV
ARRAY_MOD
メソッドスタイルの構文
SQL 関数、演算子、式および述部
205
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_UPDATE_STRIDE
array_expr.ARRAY_UPDATE_STRIDE
( new_value, stride
)
,
scope_reference
array_index
構文要素
array_expr
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
new_value
array_expr のエレメント タイプと同じデータ型を持つ値と評価される式です。
stride
構成要素を更新するにあたり、構成要素をスキップする数を示す符号なし整数値。
scope_reference
ARRAY 適用範囲の参照。
array_index
次のいずれかを指定します:
• 整数値。
• 事前定義された配列タイプ ArrayVec の配列インスタンスで、境界を定義する整
数値のカンマ区切りリストを指定したもの。
• array_index の値は、array_expr の範囲内である必要があります。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
ARRAY_UPDATE_STRIDE は、引数として配列式を取り、new_value で指定した値で
array_expr 内の構成要素のすべてまたはサブセットを更新します。stride 引数は、
構成要素を更新するにあたり、構成要素をいくつスキップするかを示します。
ARRAY_UPDATE_STRIDE 関数には、次に示すルールが適用されます。
• array_expr が NULL の場合、結果は NULL になります。
• new_value の値は、array_expr のエレメント タイプと同じデータ型と評価される
必要があります。あるいは、暗黙的にエレメント タイプ ARRAY に変換できるデー
タ型であることが必要です。
206
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_UPDATE_STRIDE
• scope_reference または array_index を指定しない場合、array_expr 内のすべて
の構成要素が new_value の値に更新されます。
• scope_reference を指定すると、array_expr の適用範囲の参照内の構成要素のみ
が new_value の値に更新されます。scope_reference は配列内の連続する構成要
素を参照する必要があります。
• array_index を指定する場合、array_index で指定した単一の構成要素のみが、
array_expr 内の new_value の値に更新されます。この場合、stride_value は影響
しません。
• stride_value 引数は、更新対象の構成要素の間でスキップする構成要素の数を指
定します。例えば、stride_value が 1 の場合、影響を受ける構成要素の範囲内で
1 つおきに更新されます。影響を受ける構成要素の範囲は、scope_reference が
指定されているかどうかによって異なります。多次元配列の場合、構成要素は行
優先順で格納されるので、この順序で進みながら stride_value に従ってスキップ
されます。
• 更新する構成要素が NULL の場合、NULL は array_expr 内の new_value の値で
置換されます。
• 1 つ以上の構成要素が変更され、更新する構成要素より前に ARRAY 値内に初期
化されていない構成要素がある場合、ARRAY_UPDATE_STRIDE はそれ以前の初
期化されていない構成要素に NULL に設定します。この動作は、ARRAY 構成要
素値を設定する通常の SQL UPDATE 文の動作と同じです。
• それまでに初期化されていなかった構成要素をスキップすると、NULL に更新さ
れます。
結果のタイプと値
ARRAY_UPDATE_STRIDE は、新しい値に更新された指定の構成要素を使って
array_expr で指定した配列の新しいコピーを返します。
例
例: ARRAY_UPDATE_STRIDE を使用した、1-D ARRAY データ型とテーブルへの問合わせ
次の 1 次元の ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE phonenumbers AS CHAR(10) ARRAY[20];
CREATE TABLE employee_info (eno INTEGER, phonelist phonenumbers);
次の問合わせは、構成要素が 1 つおきに新しい値に更新された phonelist 配列の更
新後のコピーを返します。
SELECT ARRAY_UPDATE_STRIDE(phonelist, '9095551234', 1)
FROM employee_info;
次の問合わせは、適用範囲の参照と STRIDE 値で指定したように、構成要素のサブ
セットが新しい値に更新された phonelist 配列の更新後のコピーを返します。その
SQL 関数、演算子、式および述部
207
第 4 章 ARRAY/VARRAY 関数および演算子
ARRAY_UPDATE_STRIDE
結果、構成要素 2 および 4 は新しい値に更新されます。配列内の残りの構成要素は
元の値のままです。
SELECT ARRAY_UPDATE_STRIDE(phonelist, '9095551234', 1, 2, 4)
FROM employee_info;
例: ARRAY_UPDATE_STRIDE を使用した、2-D ARRAY データ型とテーブルへの問合わせ
次の 2-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE shot_ary AS INTEGER ARRAY[1:50][1:50];
CREATE TABLE seismic_data (
id INTEGER,
shot1 shot_ary,
shot2 shot_ary);
次の問合わせは、構成要素が 1 つ置きに新しい値に更新された shot1 配列の更新後
のコピーを返します。
SELECT ARRAY_UPDATE_STRIDE(shot1, 0, 1)
FROM seismic_data;
次の問合わせは、適用範囲の参照と STRIDE 値で指定したように、構成要素のサブ
セットが新しい値に更新された short1 配列の更新後のコピーを返します。その結
果、適用範囲の参照範囲[1:50][1:50]内にある最初の構成要素から始めて、5 つ目ご
との構成要素が新しい値に更新されます。配列内の残りの構成要素は元の値のまま
です。
SELECT ARRAY_UPDATE_STRIDE(shot1, 0, 5, NEW arrayVec(1,1),
NEW arrayVec(50,50))
FROM seismic_data;
次は、メソッドスタイルの構文を使用した同じ問合わせです。
SELECT shot1.ARRAY_UPDATE_STRIDE (0, 5, NEW arrayVec(1,1),
NEW arrayVec(50,50))
FROM seismic_data;
関連トピック
詳細は、「ARRAY コンストラクタ式」を参照してください。
208
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
OEXISTS
OEXISTS
目的
array_expr 内の索引で指定された構成要素が値を含んでいるのか、初期化されてい
ない状態なのかを示す整数値を戻します。
構文
システム関数の構文
OEXISTS
( array_expr,
index_value
)
array_bound
TD_SYSFNLIB.
メソッドスタイルの構文
array_expr.OEXISTS
(
index_value
)
array_bound
構文要素
TD_SYSFNLIB
メソッドが格納されているデータベースの名前。
array_expr
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
index_value
符号なし整数値。
array_bound
事前定義された配列型 ArrayVec の配列インスタンスで、境界を定義する整数値の
カンマ区切りリストを指定したもの。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
OEXISTS は、引数として配列式を取り、索引で指定された構成要素は、値が入って
いるのか、初期化されていない状態なのかをチェックします。指定された構成要素
SQL 関数、演算子、式および述部
209
第 4 章 ARRAY/VARRAY 関数および演算子
OEXISTS
に非 NULL または NULL が含まれる場合、OEXISTS は 1 を返します。構成要素が初
期化されていない状態の場合、メソッドは 0 を返します。
index_value または array_bound の値が array_expr の範囲外にある場合、OEXISTS
は 0 を返します。index_value または array_bound が NULL の場合は 0 の値が返さ
れます。array_expr が NULL の場合は、関数が存在しないことを示すエラーが返さ
れます。
array_expr がすべての構成要素が初期化されていない状態にある空の配列を参照し
ている場合、OEXISTS は 0 を返します。整数の index_value 引数を指定した OEXISTS
メソッドは、1 次元 ARRAY タイプの Oracle EXISTS メソッドと互換性があります。
結果のタイプと値
OEXISTS は、1 または 0 の整数値を返します。
例
例: OEXISTS を使用した、1-D ARRAY データ型とテーブルへの問合わせ
次の 1 次元の ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE phonenumbers AS VARRAY(20) OF CHAR(10);
CREATE TABLE employee_info (eno INTEGER, phonelist phonenumbers);
テーブルには次の値が取り込まれます。
/* The first 2 elements are populated; the rest are uninitialized. */
INSERT INTO employee_info VALUES (1,
phonenumbers('1112223333', '6195551234'));
/* Empty ARRAY instance */
INSERT INTO employee_info VALUES (2,
phonenumbers());
/* Update the empty ARRAY instance such that element 3 is set to a value;
then elements 1 and 2 are set to NULL, the rest are uninitialized. */
UPDATE employee_info
SET phonelist[3] = '8584850000'
WHERE id = 2;
次の問合わせは、phonelist 配列の構成要素 2 に値が含まれているかどうかを確認し
ます。
SELECT eno, phonelist.OEXISTS(2)
FROM employee_info;
問合わせの結果を次に示します。
ENO
---
210
phonelist.OEXISTS(2)
--------------------
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
OEXISTS
1
2
1
1
(element 2 contains a value that is non-NULL)
(element 2 contains a NULL)
次の問合わせは、phonelist 配列の構成要素 3 に値が含まれているかどうかを確認し
ます。
SELECT eno, phonelist.OEXISTS(3)
FROM employee_info;
問合わせの結果を次に示します。
ENO
--1
2
phonelist.OEXISTS(3)
-------------------0
(element 3 is in an uninitialized state)
1
(element 3 contains a value that is non-NULL)
次は、関数スタイルの構文を使用した同じ問合わせです。
SELECT eno, OEXISTS(phonelist, 3)
FROM employee_info;
例: OEXISTS を使用した、2-D ARRAY データ型とテーブルへの問合わせ
次の 2-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE shot_ary AS VARRAY(1:50)(1:50) OF INTEGER;
CREATE TABLE seismic_table (
id INTEGER,
shots shot_ary);
テーブルには次の値が取り込まれます。
/* The first 2 elements are populated; the rest are uninitialized. */
INSERT INTO seismic_table VALUES (1, shot_ary(11, 12));
/* Empty ARRAY instance */
INSERT INTO seismic_table VALUES (2, shot_ary());
/* Update the empty ARRAY instance such that element [1][3] is set to a
value; then elements [1][1] and [1][2] are set to NULL, the rest are
uninitialized */
UPDATE seismic_table
SET shots[1][3] = 1133
WHERE id = 2;
次の問合わせは、shots 配列の構成要素[1][2]に値が含まれているかどうかを確認し
ます。
SELECT id, shots.OEXISTS(NEW arrayVec(1, 2))
FROM seismic_table;
問合わせの結果を次に示します。
SQL 関数、演算子、式および述部
211
第 4 章 ARRAY/VARRAY 関数および演算子
OCOUNTOCOUNT
ID
-1
2
shots.OEXISTS(new arrayVec(1, 2))
--------------------------------1
(element [1][2] contains a value that is non-NULL)
1
(element [1][2] contains a NULL)
次の問合わせは、shots 配列の構成要素[1][3]に値が含まれているかどうかを確認し
ます。
SELECT id, shots.OEXISTS(NEW arrayVec(1, 3))
FROM seismic_table;
問合わせの結果を次に示します。
ID
-1
2
NULL)
shots.OEXISTS(NEW arrayVec(1, 3))
--------------------------------0
(element [1][3] is in an uninitialized state)
1
(element [1][3] contains a value that is non-
関連トピック
詳細は、「ARRAY コンストラクタ式」を参照してください。
OCOUNTOCOUNT
目的
NULL または非 NULL 値のいずれかを含む array_expr 内の構成要素の数を返します。
構文
システム関数の構文
OCOUNT
( array_expr )
TD_SYSFNLIB.
メソッドスタイルの構文
array_expr.OCOUNT
( )
構文要素
TD_SYSFNLIB
メソッドが格納されているデータベースの名前。
212
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
OCOUNTOCOUNT
array_expr
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
OCOUNT は、引数として配列式を取り、非 NULL または NULL である値を含む構成
要素の数を返します。初期化されていない状態にある構成要素はカウントされませ
ん。配列が空の(配列のすべての構成要素が初期化されていない状態にある)場合、
OCOUNT は値 0 を返します。
array_expr が NULL の場合は、エラーが返されます。
OCOUNT メソッドは、1 次元 ARRAY タイプの Oracle COUNT メソッドと互換性が
あります。ただし、Teradata 構文では空の括弧が必要とされる点は、Oracle 構文と
は異なります。
結果のタイプ
OCOUNT は符号無し整数値を返します。
例
例: OCOUNT を使用した、1-D ARRAY データ型とテーブルへの問合わせ
次の 1 次元の ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE phonenumbers AS VARRAY(20) OF CHAR(10);
CREATE TABLE employee_info (eno INTEGER, phonelist phonenumbers);
テーブルには次の値が取り込まれます。
/* The first 2 elements are populated; the rest are uninitialized. */
INSERT INTO employee_info VALUES (1,
phonenumbers('1112223333', '6195551234'));
/* Empty ARRAY instance */
INSERT INTO employee_info VALUES (2,
phonenumbers());
/* Update the empty ARRAY instance such that element 3 is set to a
SQL 関数、演算子、式および述部
213
第 4 章 ARRAY/VARRAY 関数および演算子
OCOUNTOCOUNT
value; then elements 1 and 2 are set to NULL, the rest are uninitialized.
*/
UPDATE employee_info
SET phonelist[3] = '8584850000'
WHERE id = 2;
次の問合わせは、NULL または非 NULL 値を含む phonelist 配列内の要素の数を返し
ます。
SELECT eno, phonelist.OCOUNT()
FROM employee_info;
問合わせの結果を次に示します。
ENO
--1
2
non-NULL)
phonelist.OCOUNT()
-----------------2
(the first 2 elements have values that are non-NULL)
3
(the first 3 elements have NULL or values that are
例: OCOUNT を使用した、2-D ARRAY データ型とテーブルへの問合わせ
次の 2-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE shot_ary AS VARRAY(1:50)(1:50) OF INTEGER;
CREATE TABLE seismic_table (
id INTEGER,
shots shot_ary);
テーブルには次の値が取り込まれます。
/* The first 2 elements are populated; the rest are uninitialized. */
INSERT INTO seismic_table VALUES (1, shot_ary(11, 12));
/* Empty ARRAY instance */
INSERT INTO seismic_table VALUES (2, shot_ary());
/* Update the empty ARRAY instance such that element [1][3] is set to a
value; then elements [1][1] and [1][2] are set to NULL, the rest are
uninitialized */
UPDATE seismic_table
SET shots[1][3] = 1133
WHERE id = 2;
次の問合わせは、NULL または非 NULL 値を含む shots 配列内の要素の数を返します。
SELECT id, shots.OCOUNT()
FROM seismic_table;
問合わせの結果を次に示します。
214
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
OLIMITOLIMIT
ID
-1
2
non-NULL)
shots.OCOUNT()
-------------2
(the first 2 elements contain values that are non-NULL)
3
(the first 3 elements contain NULL or values that are
次は、関数スタイルの構文を使用した同じ問合わせです。
SELECT id, OCOUNT(shots)
FROM seismic_table;
関連トピック
詳細は、「ARRAY コンストラクタ式」を参照してください。
OLIMITOLIMIT
目的
array_expr 内で取り得る最大の添え字値を、符号なし整数値または事前定義された
ARRAY タイプ ArrayVec の新しいインスタンスとして返します。
構文
システム関数の構文
OLIMIT
( array_expr )
TD_SYSFNLIB.
メソッドスタイルの構文
array_expr.OLIMIT
( )
構文要素
TD_SYSFNLIB
メソッドが格納されているデータベースの名前。
array_expr
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
SQL 関数、演算子、式および述部
215
第 4 章 ARRAY/VARRAY 関数および演算子
OLIMITOLIMIT
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
OLIMIT は、引数として配列式を取り、その ARRAY タイプで取り得る最大の添字値
を返します。array_expr が 1 次元 ARRAY タイプの場合、OLIMIT は符号なし
INTEGER 値を返します。array_expr が多次元 ARRAY タイプの場合、OLIMIT は、添
字情報も含めて、事前定義された ARRAY タイプ ArrayVec の新しいインスタンスを
返します。
array_expr が NULL の場合は、エラーが返されます。
OLIMIT メソッドは、1 次元 ARRAY タイプの Oracle LIMIT メソッドと互換性があり
ます。ただし、Teradata 構文では空の括弧が必要とされる点は、Oracle 構文とは異
なります。
結果のタイプ
OLIMIT は、符号なし整数値または事前定義された ARRAY タイプ ArrayVec の新し
いインスタンスを返します。
例
例: OLIMIT を使用した、1-D ARRAY データ型とテーブルへの問合わせ
次の 1 次元の ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE phonenumbers AS VARRAY(20) OF CHAR(10);
CREATE TABLE employee_info (eno INTEGER, phonelist phonenumbers);
テーブルには次の値が取り込まれます。
/* The first 2 elements are populated; the rest are uninitialized. */
INSERT INTO employee_info VALUES (1,
phonenumbers('1112223333', '6195551234'));
/* Empty ARRAY instance */
INSERT INTO employee_info VALUES (2,
phonenumbers());
次の問合わせは、phonelist 配列で取り得る最大の添字値を返します。
SELECT eno, phonelist.OLIMIT()
FROM employee_info;
問合わせの結果を次に示します。
216
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
OFIRST
ENO
--1
2
phonelist.OLIMIT()
-----------------20
20
次は、関数スタイルの構文を使用した同じ問合わせです。
SELECT eno, OLIMIT(phonelist)
FROM employee_info;
例: OLIMIT を使用した、2-D ARRAY データ型とテーブルへの問合わせ
次の 2-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE shot_ary AS VARRAY(1:50)(1:50) OF INTEGER;
CREATE TABLE seismic_table (
id INTEGER,
shots shot_ary);
テーブルには次の値が取り込まれます。
/* The first 2 elements are populated; the rest are uninitialized. */
INSERT INTO seismic_table VALUES (1, shot_ary(11, 12));
/* Empty ARRAY instance */
INSERT INTO seismic_table VALUES (2, shot_ary());
次の問合わせは、shots 配列で取り得る最大の添字値を返します。
SELECT id, shots.OLIMIT()
FROM seismic_table;
問合わせの結果を次に示します。
ID
-1
2
shots.OLIMIT()
-------------NEW arrayVec(50,50)
NEW arrayVec(50,50)
関連トピック
詳細は、「ARRAY コンストラクタ式」を参照してください。
OFIRST
目的
array_expr 内で最小の添え字値を、符号なし整数値または事前定義された ARRAY
タイプ型 ArrayVec の新しいインスタンスとして返します。
SQL 関数、演算子、式および述部
217
第 4 章 ARRAY/VARRAY 関数および演算子
OFIRST
構文
システム関数の構文
OFIRST
( array_expr )
TD_SYSFNLIB.
メソッドスタイルの構文
array_expr.OFIRST
( )
構文要素
TD_SYSFNLIB
メソッドが格納されているデータベースの名前。
array_expr
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
OFIRST は、引数として配列式を取り、その ARRAY タイプで最小の添字値を返しま
す。array_expr が 1 次元 ARRAY タイプの場合、OFIRST は符号なし整数値を返しま
す。array_expr が多次元 ARRAY タイプの場合、OFIRST は、配列内で最初の構成要
素の添字情報も含めて、事前定義された ARRAY タイプ ArrayVec の新しいインスタ
ンスを返します。配列が空の(配列のすべての構成要素が初期化されていない状態に
ある)場合、OFIRST は NULL を返します。
array_expr が NULL の場合は、エラーが返されます。
OFIRST メソッドは、1 次元 ARRAY タイプの Oracle FIRST メソッドと互換性があり
ます。ただし、Teradata 構文では空の括弧が必要とされる点は、Oracle 構文とは異
なります。
結果のタイプ
OFIRST は、符号なし整数値または事前定義された ARRAY タイプ ArrayVec の新し
いインスタンスを返します。
218
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
OFIRST
例
例: OFIRST を使用した、1-D ARRAY データ型とテーブルへの問合わせ
次の 1 次元の ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE phonenumbers AS VARRAY(20) OF CHAR(10);
CREATE TABLE employee_info (eno INTEGER, phonelist phonenumbers);
テーブルには次の値が取り込まれます。
/* The first 2 elements are populated; the rest are uninitialized. */
INSERT INTO employee_info VALUES (1,
phonenumbers('1112223333', '6195551234'));
/* Empty ARRAY instance */
INSERT INTO employee_info VALUES (2,
phonenumbers());
次の問合わせは、phonelist 配列で最小の添字値を返します。
SELECT eno, phonelist.OFIRST()
FROM employee_info;
問合わせの結果を次に示します。
ENO
--1
2
phonelist.OFIRST()
-----------------1
1
例: OFIRST を使用した、2-D ARRAY データ型とテーブルへの問合わせ
次の 2-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE shot_ary AS VARRAY(1:50)(1:50) OF INTEGER;
CREATE TABLE seismic_table (
id INTEGER,
shots shot_ary);
テーブルには次の値が取り込まれます。
/* The first 2 elements are populated; the rest are uninitialized. */
INSERT INTO seismic_table VALUES (1, shot_ary(11, 12));
/* Empty ARRAY instance */
INSERT INTO seismic_table VALUES (2, shot_ary());
次の問合わせは、shots 配列で最小の添字値を返します。
SELECT id, shots.OFIRST()
FROM seismic_table;
SQL 関数、演算子、式および述部
219
第 4 章 ARRAY/VARRAY 関数および演算子
OLASTOLAST
問合わせの結果を次に示します。
ID
-1
2
shots.OFIRST()
-------------NEW arrayVec(1,1)
NEW arrayVec(1,1)
次は、関数スタイルの構文を使用した同じ問合わせです。
SELECT id, OFIRST(shots)
FROM seismic_table;
関連トピック
詳細は、「ARRAY コンストラクタ式」を参照してください。
OLASTOLAST
目的
array_expr 内に取り込まれた構成要素の最大の添字値を返します。
構文
システム関数の構文
OLAST
( array_expr )
TD_SYSFNLIB.
メソッドスタイルの構文
array_expr.OLAST
( )
構文要素
TD_SYSFNLIB
メソッドが格納されているデータベースの名前。
array_expr
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
220
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
OLASTOLAST
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
OLAST は、引数として配列式を取り、その ARRAY タイプに取り込まれた構成要素
の最大の添字値を返します。これは、OLIMIT メソッドから返される取り得る最大
の添字値とは異なります。array_expr が 1 次元 ARRAY タイプの場合、OLAST は符
号なし INTEGER 値を返します。array_expr が多次元 ARRAY タイプの場合、OLAST
は、添字情報も含めて、事前定義された ARRAY タイプ ArrayVec の新しいインスタ
ンスを返します。配列が空の(配列のすべての構成要素が初期化されていない状態に
ある)場合、OLAST は NULL を返します。
array_expr が NULL の場合は、エラーが返されます。
OLAST メソッドは、1 次元 ARRAY タイプの Oracle LAST メソッドと互換性があり
ます。ただし、Teradata 構文では空の括弧が必要とされる点は、Oracle 構文とは異
なります。
結果のタイプ
OLAST は、符号なし整数値または事前定義された ARRAY タイプ ArrayVec の新し
いインスタンスを返します。
例
例: OLAST を使用した、1-D ARRAY データ型とテーブルへの問合わせ
次の 1 次元の ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE phonenumbers AS VARRAY(20) OF CHAR(10);
CREATE TABLE employee_info (eno INTEGER, phonelist phonenumbers);
テーブルには次の値が取り込まれます。
/* The first 2 elements are populated; the rest are uninitialized. */
INSERT INTO employee_info VALUES (1,
phonenumbers('1112223333', '6195551234'));
/* Empty ARRAY instance */
INSERT INTO employee_info VALUES (2,
phonenumbers());
/* Update empty ARRAY instance such that element 3 is set to a value;
Then elements 1 and 2 are set to NULL, the rest are uninitialized */
UPDATE employee_info
SET phonelist[3] = '8584850000'
WHERE id = 2;
SQL 関数、演算子、式および述部
221
第 4 章 ARRAY/VARRAY 関数および演算子
OLASTOLAST
次の問合わせは、phonelist 配列に取り込まれた構成要素の最大の添字値を返します。
SELECT eno, phonelist.OLAST()
FROM employee_info;
問合わせの結果を次に示します。
ENO
--1
2
phonelist.OLAST()
----------------2
3
次は、関数スタイルの構文を使用した同じ問合わせです。
SELECT eno, OLAST(phonelist)
FROM employee_info;
例: OLAST を使用した、2-D ARRAY データ型とテーブルへの問合わせ
次の 2-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE shot_ary AS VARRAY(1:50)(1:50) OF INTEGER;
CREATE TABLE seismic_table (
id INTEGER,
shots shot_ary);
テーブルには次の値が取り込まれます。
/* The first 2 elements are populated; the rest are uninitialized. */
INSERT INTO seismic_table VALUES (1, shot_ary(11, 12));
/* Empty ARRAY instance */
INSERT INTO seismic_table VALUES (2, shot_ary());
/* Update empty ARRAY instance such that element [1][3] is set to a
value; Then elements [1][1] and [1][2] are set to NULL, the rest are
uninitialized */
UPDATE seismic_table
SET shots[1][3] = 1133
WHERE id = 2;
次の問合わせは、shots 配列に取り込まれた構成要素の最大の添字値を返します。
SELECT id, shots.OLAST()
FROM seismic_table;
問合わせの結果を次に示します。
ID
-1
2
222
shots.OLAST()
-----------------NEW arrayVec(1,2)
NEW arrayVec(1,3)
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
OPRIOR
関連トピック
詳細は、「ARRAY コンストラクタ式」を参照してください。
OPRIOR
目的
array_expr に対して指定された構成要素が現在取り込まれている場合、それより前
の構成要素の添字を返します。
構文
システム関数の構文
OPRIOR
( array_expr,
integer_value
)
array_bound
TD_SYSFNLIB.
メソッドスタイルの構文
array_expr.OPRIOR
(
integer_value
)
array_bound
構文要素
TD_SYSFNLIB
メソッドが格納されているデータベースの名前。
array_expr
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
integer_value
符号なし整数値。
array_bound
事前定義された配列型 ArrayVec の配列インスタンスで、境界を定義する整数値の
カンマ区切りリストを指定したもの。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
SQL 関数、演算子、式および述部
223
第 4 章 ARRAY/VARRAY 関数および演算子
OPRIOR
使用上の注意
OPRIOR は、引数として配列式を取り、integer_value または array_bound で指定さ
れた構成要素が現在取り込まれている場合、それより前の構成要素の添字を返しま
す。その配列の OFIRST 値以下の構成要素の添字を指定すると、NULL が返されま
す。integer_value または array_bound が NULL の場合は、エラーが返されます。
array_expr が 1 次元 ARRAY タイプの場合、OPRIOR は符号なし INTEGER 値を返し
ます。array_expr が多次元 ARRAY タイプの場合、OPRIOR は、添字情報も含めて、
事前定義された ARRAY タイプ ArrayVec の新しいインスタンスを返します。配列が
空の(配列のすべての構成要素が初期化されていない状態にある)場合、OPRIOR は
NULL を返します。
array_expr が NULL の場合は、エラーが返されます。
整数の引数を 1 つ指定した OPRIOR メソッドは、1 次元 ARRAY タイプの Oracle
PRIOR メソッドと互換性があります。
結果のタイプ
OPRIOR は、符号なし整数値または事前定義された ARRAY タイプ ArrayVec の新し
いインスタンスを返します。
例
例: OPRIOR を使用した、1-D ARRAY データ型とテーブルへの問合わせ
次の 1 次元の ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE phonenumbers AS VARRAY(20) OF CHAR(10);
CREATE TABLE employee_info (eno INTEGER, phonelist phonenumbers);
テーブルには次の値が取り込まれます。
/* The first 2 elements are populated; the rest are uninitialized. */
INSERT INTO employee_info VALUES (1,
phonenumbers('1112223333', '6195551234'));
/* Empty ARRAY instance */
INSERT INTO employee_info VALUES (2,
phonenumbers());
/* Update empty ARRAY instance such that element 3 is set to a value;
Then elements 1 and 2 are set to NULL, the rest are uninitialized */
UPDATE employee_info
SET phonelist[3] = '8584850000'
WHERE id = 2;
次の問合わせは、phonelist 配列の構成要素 2 より前の構成要素の添字値を返します。
224
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
OPRIOR
SELECT eno, phonelist.OPRIOR(2)
FROM employee_info;
問合わせの結果を次に示します。
ENO
--1
2
phonelist.OPRIOR(2)
------------------1
1
次は、関数スタイルの構文を使用した同じ問合わせです。
SELECT eno, OPRIOR(phonelist, 2)
FROM employee_info;
例: OPRIOR を使用した、2-D ARRAY データ型とテーブルへの問合わせ
次の 2-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE shot_ary AS VARRAY(1:50)(1:50) OF INTEGER;
CREATE TABLE seismic_table (
id INTEGER,
shots shot_ary);
テーブルには次の値が取り込まれます。
/* The first 2 elements are populated; the rest are uninitialized. */
INSERT INTO seismic_table VALUES (1, shot_ary(11, 12));
/* Empty ARRAY instance */
INSERT INTO seismic_table VALUES (2, shot_ary());
/* Update empty ARRAY instance such that element [1][3] is set to a
value; Then elements [1][1] and [1][2] are set to NULL, the rest are
uninitialized */
UPDATE seismic_table
SET shots[1][3] = 1133
WHERE id = 2;
次の問合わせは、shots 配列の構成要素[1][2]より前の構成要素の添字値を返します。
SELECT id, shots.OPRIOR(NEW arrayVec(1, 2))
FROM seismic_table;
問合わせの結果を次に示します。
ID
-1
2
SQL 関数、演算子、式および述部
shots.OPRIOR(NEW arrayVec(1, 2))
-------------------------------NEW arrayVec(1,1)
NEW arrayVec(1,1)
225
第 4 章 ARRAY/VARRAY 関数および演算子
ONEXT
関連トピック
詳細は、「ARRAY コンストラクタ式」を参照してください。
ONEXT
目的
array_expr に対して指定された構成要素が現在取り込まれている場合、それより後
の構成要素の添字を返します。
構文
システム関数の構文
ONEXT
( array_expr,
integer_value
)
array_bound
TD_SYSFNLIB.
メソッドスタイルの構文
array_expr.ONEXT
(
integer_value
)
array_bound
構文要素
TD_SYSFNLIB
メソッドが格納されているデータベースの名前。
array_expr
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
詳細については、「ARRAY_Constructor_Expression」を参照してください。
integer_value
符号なし整数値。
array_bound
事前定義された配列型 ArrayVec の配列インスタンスで、境界を定義する整数値のカ
ンマ区切りリストを指定したもの。
詳細については、「ARRAY 適用範囲の参照」を参照してください。
226
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ONEXT
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
ONEXT は、引数として配列式を取り、integer_value または array_bound で指定さ
れた構成要素が現在取り込まれている場合、それより後の構成要素の添字を返しま
す。その配列の OLAST 値より大きい構成要素の添字を指定すると、NULL が返され
ます。integer_value または array_bound が NULL の場合は、エラーが返されます。
array_expr が 1 次元 ARRAY タイプの場合、ONEXT は符号なし INTEGER 値を返し
ます。array_expr が多次元 ARRAY タイプの場合、ONEXT は、添字情報も含めて、
事前定義された ARRAY タイプ ArrayVec の新しいインスタンスを返します。配列が
空の(配列のすべての構成要素が初期化されていない状態にある)場合、ONEXT は
NULL を返します。
array_expr が NULL の場合は、エラーが返されます。
整数の引数を 1 つ指定した ONEXT メソッドは、1 次元 ARRAY タイプの Oracle
NEXT メソッドと互換性があります。
結果のタイプ
ONEXT は、符号なし整数値または事前定義された ARRAY タイプ ArrayVec の新し
いインスタンスを返します。
例
例: ONEXT を使用した、1-D ARRAY データ型とテーブルへの問合わせ
次の 1 次元の ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE phonenumbers AS VARRAY(20) OF CHAR(10);
CREATE TABLE employee_info (eno INTEGER, phonelist phonenumbers);
テーブルには次の値が取り込まれます。
/* The first 2 elements are populated; the rest are uninitialized. */
INSERT INTO employee_info VALUES (1,
phonenumbers('1112223333', '6195551234'));
/* Empty ARRAY instance */
INSERT INTO employee_info VALUES (2,
phonenumbers());
/* Update empty ARRAY instance such that element 3 is set to a value;
Then elements 1 and 2 are set to NULL, the rest are uninitialized */
UPDATE employee_info
SQL 関数、演算子、式および述部
227
第 4 章 ARRAY/VARRAY 関数および演算子
ONEXT
SET phonelist[3] = '8584850000'
WHERE id = 2;
次の問合わせは、phonelist 配列の構成要素 2 より後の構成要素の添字値を返します。
SELECT eno, phonelist.ONEXT(2)
FROM employee_info;
問合わせの結果を次に示します。
ENO
--1
2
phonelist.ONEXT(2)
-----------------?
(the element following element 2 is unpopulated)
3
例: ONEXT を使用した、2-D ARRAY データ型とテーブルへの問合わせ
次の 2-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE shot_ary AS VARRAY(1:50)(1:50) OF INTEGER;
CREATE TABLE seismic_table (
id INTEGER,
shots shot_ary);
テーブルには次の値が取り込まれます。
/* The first 2 elements are populated; the rest are uninitialized. */
INSERT INTO seismic_table VALUES (1, shot_ary(11, 12));
/* Empty ARRAY instance */
INSERT INTO seismic_table VALUES (2, shot_ary());
/* Update empty ARRAY instance such that element [1][3] is set to a
value; Then elements [1][1] and [1][2] are set to NULL, the rest are
uninitialized */
UPDATE seismic_table
SET shots[1][3] = 1133
WHERE id = 2;
次の問合わせは、shots 配列の構成要素[1][2]より後の構成要素の添字値を返します。
SELECT id, shots.ONEXT(NEW arrayVec(1, 2))
FROM seismic_table;
問合わせの結果を次に示します。
ID
-1
2
shots.ONEXT(NEW arrayVec(1, 2))
------------------------------?
(The element following element [1][2] is unpopulated)
NEW arrayVec(1,3)
次は、関数スタイルの構文を使用した同じ問合わせです。
228
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
OEXTEND
SELECT id, ONEXT(shots, NEW arrayVec(1, 2))
FROM seismic_table;
OEXTEND
目的
array_expr 内に 1 つ以上の新しい構成要素用の領域を割り当てます。
構文
システム関数の構文
OEXTEND
( array_expr
)
, num_spaces
TD_SYSFNLIB.
,
index_value
array_bound
メソッドスタイルの構文
array_expr.OEXTEND
(
)
num_spaces
,
index_value
array_bound
構文要素
TD_SYSFNLIB
メソッドが格納されているデータベースの名前。
array_expr
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
num_spaces
array_expr.に追加する NULL 構成要素の数を表わす任意選択の符号なし整数値。
index_value
array_expr 内の構成要素に対する索引として使用する任意選択の符号なし整数値。
array_bound
事前定義された配列型 ArrayVec の配列インスタンスで、境界を定義する整数値の
カンマ区切りリストを指定したもの。
SQL 関数、演算子、式および述部
229
第 4 章 ARRAY/VARRAY 関数および演算子
OEXTEND
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
OEXTEND は、引数として配列式を取り、配列に 1 つ以上の新しい構成要素用の領
域を割り当てます。
指定内容
メソッドの動作
OEXTEND()
ARRAY 値に 1 つの NULL 構成要素を追加します。
多次元(n-D)ARRAY の場合、これは行優先順で行な
われます。
OEXTEND(num_spaces)
ARRAY 値に n 個の NULL 構成要素を追加します。
このとき、n = num_spaces になります。n-D
ARRAY の場合、これは行優先順で行なわれます。
OEXTEND(num_spaces,
index_value)
ARRAY 値に index_value または array_bound に
よって索引作成された n 個の構成要素のコピーを
追加します。このとき、n = num_spaces になりま
す。n-D ARRAY の場合、これは行優先順で行なわ
れます。
または
OEXTEND(num_spaces,
array_bound)
整数タイプの引数を指定しない、1 つ指定、または 2 つ指定した OEXTEND メソッ
ドは、1 次元 ARRAY タイプの Oracle EXTEND メソッドと互換性があります。ただ
し、OEXTEND が引数なしで呼び出される場合に空の括弧が必要とされる点は、Oracle
構文とは異なります。
次の場合に、OEXTEND はエラーを返します。
• array_expr が NULL の場合。
• index _value または array_bound のいずれかが NULL の場合。
• OEXTEND により追加された構成要素数が、配列の最大サイズを越える場合。
num_spaces が NULL の場合、エラーは発生しませんが、OEXTEND は何のアクショ
ンも実行しません。
結果のタイプ
OEXTEND は、配列引数の新しい変更後のコピーを返します。
例
例: OEXTEND を使用した、1-D ARRAY データ型とテーブルへの問合わせ
次の 1 次元の ARRAY データ タイプおよび表について考えてみましょう。
230
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
OEXTEND
CREATE TYPE phonenumbers AS VARRAY(20) OF CHAR(10);
CREATE TABLE employee_info (eno INTEGER, phonelist phonenumbers);
テーブルには次の値が取り込まれます。
/* The first 2 elements are populated; the rest are uninitialized. */
INSERT INTO employee_info VALUES (1,
phonenumbers('1112223333', '6195551234'));
/* Empty ARRAY instance */
INSERT INTO employee_info VALUES (2,
phonenumbers());
/* Update empty ARRAY instance such that element 3 is set to a value;
Then elements 1 and 2 are set to NULL, the rest are uninitialized */
UPDATE employee_info
SET phonelist[3] = '8584850000'
WHERE id = 2;
次の問合わせは、単一の NULL 構成要素で phonelist 配列を拡張します。
SELECT eno, phonelist.OEXTEND()
FROM employee_info;
問合わせの結果を次に示します。
ENO
--1
2
phonelist.OEXTEND()
------------------('1112223333', '6195551234',NULL)
(NULL,NULL,'8584850000',NULL)
次の問合わせは、3 つの NULL 構成要素で phonelist 配列を拡張します。
SELECT eno, phonelist.OEXTEND(3)
FROM employee_info;
問合わせの結果を次に示します。
ENO
--1
2
phonelist.OEXTEND(3)
-------------------('1112223333', '6195551234',NULL,NULL,NULL)
(NULL,NULL,'8584850000',NULL,NULL,NULL)
次の問合わせは、構成要素 1 を 2 つコピーして、phonelist 配列を拡張します。
SELECT eno, phonelist.OEXTEND(2,1)
FROM employee_info
WHERE eno = 1;
問合わせの結果を次に示します。
SQL 関数、演算子、式および述部
231
第 4 章 ARRAY/VARRAY 関数および演算子
OEXTEND
ENO
--1
phonelist.OEXTEND(2,1)
---------------------('1112223333', '6195551234', '1112223333', '1112223333')
次は、関数スタイルの構文を使用した同じ問合わせです。
SELECT eno, OEXTEND(phonelist,2,1)
FROM employee_info
WHERE eno = 1;
例: OEXTEND を使用して、構成された ARRAY の最後に NULL 要素を入れる
次の例は、OEXTEND メソッドを使って、構成された ARRAY の最後に NULL 構成要
素を入れ、それらの構成要素が初期化されていない状態でなくなるようにする方法
を示しています。これは、ARRAY を他のシステム関数や演算子の引数として使用で
きる場合に便利です。
CREATE TYPE myarray AS VARRAY(5) OF INTEGER;
CREATE TABLE mytab (id INTEGER, ary myarray);
/* Populate the first 3 elements. The last 2 elements are uninitialized.
*/
INSERT INTO mytab VALUES (1, NEW myarray(1,2,3));
/* Fill the last 2 elements with NULLs. */
UPDATE mytab
SET ary = ary.OEXTEND(2)
WHERE id = 1;
SELECT ary FROM mytab;
問合わせの結果を次に示します。
(1,2,3,NULL,NULL)
例: OEXTEND を使用した、2-D ARRAY データ型とテーブルへの問合わせ
次の 2-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE shot_ary AS VARRAY(1:50)(1:50) OF INTEGER;
CREATE TABLE seismic_table (
id INTEGER,
shots shot_ary);
テーブルには次の値が取り込まれます。
/* The first 2 elements are populated; the rest are uninitialized. */
INSERT INTO seismic_table VALUES (1, shot_ary(11, 12));
/* Empty ARRAY instance */
INSERT INTO seismic_table VALUES (2, shot_ary());
/* Update empty ARRAY instance such that element [1][3] is set to a
value; Then elements [1][1] and [1][2] are set to NULL, the rest are
232
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
OEXTEND
uninitialized */
UPDATE seismic_table
SET shots[1][3] = 1133
WHERE id = 2;
次の問合わせは、単一の NULL 構成要素で shots 配列を拡張します。
SELECT id, shots.OEXTEND()
FROM seismic_table;
問合わせの結果を次に示します。
ID
-1
2
shots.OEXTEND()
--------------(11,12,NULL)
(NULL,NULL,1133,NULL)
次の問合わせは、3 つの NULL 構成要素で shots 配列を拡張します。
SELECT id, shots.OEXTEND(3)
FROM seismic_table;
問合わせの結果を次に示します。
ID
-1
2
shots.OEXTEND(3)
---------------(11,12,NULL,NULL,NULL)
(NULL,NULL,1133,NULL,NULL,NULL)
次の問合わせは、構成要素[1][1]を 2 つコピーして shots 配列を拡張します。
SELECT id, shots.OEXTEND(2, NEW arrayVec(1,1))
FROM seismic_table
WHERE id = 1;
問合わせの結果を次に示します。
ID
-1
shots.OEXTEND(2, NEW arrayVec(1,1))
----------------------------------(11,12,11,11)
関連トピック
詳細は、以下を参照してください。
• 「ARRAY 適用範囲の参照」
• 「ARRAY コンストラクタ式」
SQL 関数、演算子、式および述部
233
第 4 章 ARRAY/VARRAY 関数および演算子
OTRIM
OTRIM
目的
取り込まれた構成要素を array_expr の最後から 1 つ以上削除します。
構文
システム関数の構文
OTRIM
( array_expr
TD_SYSFNLIB.
)
, integer_value
メソッドスタイルの構文
構文要素
TD_SYSFNLIB
メソッドが格納されているデータベースの名前。
array_expr
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
• UDF 式
• UDM 式
integer_value
任意選択の符号なし INTEGER 値で、配列から削除する取り込まれた要素の数を示し
ます。デフォルトは 1 です。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
OTRIM は、引数として配列式を取り、取り込まれている 1 つ以上の構成要素をその
配列値の最後から削除します。integer_value を指定しない場合、OTRIM は配列値の
最後から取り込まれている構成要素を 1 つ削除します。指定する場合は、OTRIM は
配列値の最後から取り込まれている構成要素を integer_value で指定した数を削除し
ます。多次元 ARRAY タイプの場合、これは行優先順で行なわれます。OTRIM は、
結果として配列値の新しい変更後のコピーを返します。
234
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
OTRIM
array_expr が NULL の場合は、エラーが返されます。integer_value が NULL の場
合、エラーは発生しませんが、OTRIM は何のアクションも実行しません。OTRIM
により削除された構成要素数がその配列の OCOUNT の現在の値より大きい場合、
エラーが返されます。
OTRIM メソッドは、1 次元 ARRAY タイプの Oracle TRIM メソッドと互換性があり
ます。integer_value が指定されていない場合、Teradata 構文では空の括弧が必要と
される点は、Oracle 構文とは異なります。
結果のタイプ
OTRIM は、配列引数の新しい変更後のコピーを返します。
例
例: OTRIM を使用した、1-D ARRAY データ型とテーブルへの問合わせ
次の 1 次元の ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE phonenumbers AS VARRAY(20) OF CHAR(10);
CREATE TABLE employee_info (eno INTEGER, phonelist phonenumbers);
テーブルには次の値が取り込まれます。
/* The first 2 elements are populated; the rest are uninitialized. */
INSERT INTO employee_info VALUES (1,
phonenumbers('1112223333', '6195551234'));
/* Empty ARRAY instance */
INSERT INTO employee_info VALUES (2,
phonenumbers());
/* Update empty ARRAY instance such that element 3 is set to a value;
Then elements 1 and 2 are set to NULL, the rest are uninitialized */
UPDATE employee_info
SET phonelist[3] = '8584850000'
WHERE id = 2;
次の問合わせは、取り込まれている最後の構成要素を phonelist 配列から削除します。
SELECT eno, phonelist.OTRIM()
FROM employee_info;
問合わせの結果を次に示します。
ENO
--1
2
SQL 関数、演算子、式および述部
phonelist.OTRIM()
----------------('1112223333')
(NULL,NULL)
235
第 4 章 ARRAY/VARRAY 関数および演算子
OTRIM
次の問合わせは、取り込まれている最後の構成要素を 2 つ、phonelist 配列から削除
します。
SELECT eno, phonelist.OTRIM(2)
FROM employee_info;
問合わせの結果を次に示します。
ENO
--1
2
phonelist.OTRIM(2)
-----------------()
(the only 2 populated elements were removed so we
now have an empty array value)
(NULL)
例: OTRIM を使用した、2-D ARRAY データ型とテーブルへの問合わせ
次の 2-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE shot_ary AS VARRAY(1:50)(1:50) OF INTEGER;
CREATE TABLE seismic_table (
id INTEGER,
shots shot_ary);
テーブルには次の値が取り込まれます。
/* The first 2 elements are populated; the rest are uninitialized. */
INSERT INTO seismic_table VALUES (1, shot_ary(11, 12));
/* Empty ARRAY instance */
INSERT INTO seismic_table VALUES (2, shot_ary());
/* Update empty ARRAY instance such that element [1][3] is set to a
value; Then elements [1][1] and [1][2] are set to NULL, the rest are
uninitialized */
UPDATE seismic_table
SET shots[1][3] = 1133
WHERE id = 2;
次の問合わせは、取り込まれている最後の構成要素を shots 配列から削除します。
SELECT id, shots.OTRIM()
FROM seismic_table
WHERE id = 1;
問合わせの結果を次に示します。
ID
-1
shots.OTRIM()
------------(11)
次の問合わせは、取り込まれている最後の構成要素を 2 つ、shots 配列から削除しま
す。
236
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ODELETEODELETE
SELECT id, shots.OTRIM(2)
FROM seismic_table;
問合わせの結果を次に示します。
ID
-1
2
shots.OTRIM(2)
-------------()
(the only 2 populated elements were removed so we now
have an empty array value)
(NULL)
次は、関数スタイルの構文を使用した同じ問合わせです。
SELECT id, OTRIM(shots, 2)
FROM seismic_table;
関連トピック
詳細は、「ARRAY コンストラクタ式」を参照してください。
ODELETEODELETE
目的
array_expr からすべての構成要素を削除します。
構文
システム関数の構文
ODELETE
( array_expr )
TD_SYSFNLIB.
メソッドスタイルの構文
array_expr.ODELETE
( )
構文要素
TD_SYSFNLIB
メソッドが格納されているデータベースの名前。
array_expr
次のいずれかである ARRAY 式。
• ARRAY 列の参照
• ARRAY コンストラクタ式
SQL 関数、演算子、式および述部
237
第 4 章 ARRAY/VARRAY 関数および演算子
ODELETEODELETE
• UDF 式
• UDM 式
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
ODELETE は、引数として配列式を取り、取り込まれている、すべての構成要素をそ
の配列値から削除します。ODELETE は、結果として配列値の新しい変更後のコピー
を返します。
array_expr が NULL の場合は、エラーが返されます。
ODELETE メソッドは、1 次元 ARRAY タイプの Oracle DELETE メソッドと互換性が
あります。ただし、Teradata 構文では空の括弧が必要とされる点は、Oracle 構文と
は異なります。
結果のタイプ
ODELETE は、配列引数の新しい変更後のコピーを返します。
例
例: ODELETE を使用した、1-D ARRAY データ型とテーブルへの問合わせ
次の 1 次元の ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE phonenumbers AS VARRAY(20) OF CHAR(10);
CREATE TABLE employee_info (eno INTEGER, phonelist phonenumbers);
テーブルには次の値が取り込まれます。
/* The first 2 elements are populated; the rest are uninitialized. */
INSERT INTO employee_info VALUES (1,
phonenumbers('1112223333', '6195551234'));
/* Empty ARRAY instance */
INSERT INTO employee_info VALUES (2,
phonenumbers());
/* Update empty ARRAY instance such that element 3 is set to a value;
Then elements 1 and 2 are set to NULL, the rest are uninitialized */
UPDATE employee_info
SET phonelist[3] = '8584850000'
WHERE id = 2;
238
SQL 関数、演算子、式および述部
第 4 章 ARRAY/VARRAY 関数および演算子
ODELETEODELETE
次の問合わせは、取り込まれているすべての構成要素を phonelist 配列から削除し、
すべての構成要素が初期化されていない状態になります。
SELECT eno, phonelist.ODELETE()
FROM employee_info;
問合わせの結果を次に示します。
ENO
--1
2
phonelist.ODELETE()
------------------()
()
次は、関数スタイルの構文を使用した同じ問合わせです。
SELECT eno, ODELETE(phonelist)
FROM employee_info;
例: ODELETE を使用した、2-D ARRAY データ型とテーブルへの問合わせ
次の 2-D ARRAY データ タイプおよび表について考えてみましょう。
CREATE TYPE shot_ary AS VARRAY(1:50)(1:50) OF INTEGER;
CREATE TABLE seismic_table (
id INTEGER,
shots shot_ary);
テーブルには次の値が取り込まれます。
/* The first 2 elements are populated; the rest are uninitialized. */
INSERT INTO seismic_table VALUES (1, shot_ary(11, 12));
/* Empty ARRAY instance */
INSERT INTO seismic_table VALUES (2, shot_ary());
/* Update empty ARRAY instance such that element [1][3] is set to a
value; Then elements [1][1] and [1][2] are set to NULL, the rest are
uninitialized */
UPDATE seismic_table
SET shots[1][3] = 1133
WHERE id = 2;
次の問合わせは、取り込まれているすべての構成要素を shots 配列から削除し、配
列のすべての構成要素が初期化されていない状態になります。
SELECT id, shots.ODELETE()
FROM seismic_table;
問合わせの結果を次に示します。
ID
--
SQL 関数、演算子、式および述部
shots.ODELETE()
---------------
239
第 4 章 ARRAY/VARRAY 関数および演算子
ODELETEODELETE
1
2
()
()
関連トピック
詳細は、「ARRAY コンストラクタ式」を参照してください。
240
SQL 関数、演算子、式および述部
第5章
属性関数
概要
この章では、SQL 属性関数について説明します。
属性関数は、オペランドに関する記述情報を戻します。DEFAULT 関数を除いて、オ
ペランドは列参照である必要はありません。数学的に評価されない一般的な式であっ
てもかまいません。
要求の中で属性関数を使うと、応答では、検索条件にかなった各データ行ごとに 1
つの行が戻されます。
これらの関数のうちのいくつかは、ANSI SQL に対する拡張機能です。
データ タイプ属性のリストは、< SQL データ型とリテラル、B035-1143>の「デー
タ タイプ句」を参照してください。
各属性関数について、この後の項目で 1 つずつ説明します。
Teradata 属性関数に相当する ANSI の属性関数
Teradata 属性関数のいくつかは、ANSI SQL:2011 規格の拡張機能です。
ANSI との互換性を維持するために、ANSI の等価関数があれば、Teradata 属性関数
ではなく、それを使用してください。
変更する Teradata 関数
新規アプリケーションで使用する ANSI 関数
CHARACTERS
CHARS
CHAR
CHARACTER_LENGTH
MCHARACTERS†
† この関数の記述はなくなりました。この関数の使用は推奨されません。KANJI1 のサポー
トが停止された後はサポートされなくなるためです。
以下の Teradata 関数には、ANSI の等価関数がありません。
• BYTES
• FORMAT
• TYPE
SQL 関数、演算子、式および述部
241
第 5 章 属性関数
BYTES
BYTES
目的
指定のバイト文字列に含まれているバイト数を戻します。
構文
BYTE
( byte_expression (
BYTES
構文要素
byte_expression
バイト数を戻すバイト文字列。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
byte_expression のデータ型は、以下のものに限られます。
• BYTE、VARBYTE、および BLOB
• 事前定義されたバイト タイプへの暗黙 CAST を持つ UDT
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 構文規則および例、B035-1144>を参照してください。
BYTES を含め、システム演算子および関数用の UDT の暗黙の型変換は、ANSI SQL
標準の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レコードの
DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。
長さには後続ゼロが含まれる
後続ダブル ゼロ バイトもバイトとしてみなされるので、固定長列の値の長さは、常
にその列に定義されている長さと等しくなります。
可変長列の値の長さは、常にその値に含まれているバイト数(後続ダブル ゼロ バイ
トも含む)と等しくなります。
データ値のバイト カウントに後続ブランクを含めないようにするには、BYTES への
引数に TRIM 関数を使用します。たとえば、
242
SQL 関数、演算子、式および述部
第 5 章 属性関数
CHARACTER LENGTH
SELECT BYTES( TRIM( TRAILING FROM byte_col ) ) FROM table1;
例: BYTE を使用した、社員証のバイト数の取得
以下の文では、BYTES 関数を BadgePic 列(タイプは VARBYTE(32000))に適用し、
社員証の写真のバイト数を取得します。
SELECT BadgePic, BYTES(BadgePic)
FROM Employee;
結果は、以下のとおりです。
BadgePic
-------------20003BA0
9A3243F805
EEFF08C3441900
Bytes(BadgePic)
--------------4
5
7
関連トピック
詳細は、以下を参照してください。
• 「データ型の変換」
• ユーティリティ 、B035-1102
• 「TRIM」
CHARACTER LENGTH
目的
論理文字数またはバイト数として文字列の長さを戻します。
構文
CHARACTER_LENGTH
CHAR_LENGTH
(string_expression)
構文要素
string_expression
長さを戻す文字列式。
SQL 関数、演算子、式および述部
243
第 5 章 属性関数
CHARACTER LENGTH
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
使用上の注意
CHARACTER_LENGTH は、Teradata の CHARACTERS 関数の ANSI 版です。ANSI
SQL:2011 に適合させるには、CHARACTERS の代わりに CHARACTER_LENGTH を使
用します。
MCHARACTERS の代わりに CHARACTER_LENGTH を使用してください。(このマニュ
アルでの MCHARACTERS の記述はなくなりました。この関数の使用は推奨されませ
ん。KANJI1 のサポートが停止された後はサポートされなくなるためです。)
引数のタイプ
string_expression の型は、CHARACTER、VARCHAR、または CLOB でなければなり
ません。文字以外のデータ型の場合は、エラーが戻されます。
Teradata Database はデフォルトで、UDT と、事前定義文字列タイプの間でキャスト
を行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行ないます。
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。
CHARACTER_LENGTH を含め、システム演算子および関数用の UDT の暗黙の型変換
は、ANSI SQL 標準の Teradata 拡張機能です。この拡張を無効にするには、DBS 制
御レコードの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。
結果
KANJI1 以外のすべてのサーバー文字セットの場合、CHARACTER_LENGTH は、
string_expression の長さを文字数として戻します。
string_expression 引数が NULL の場合、結果は NULL になります。
KANJI1 の場合は以下の結果が得られます。
クライアント文字セット
CHARACTER_LENGTH が戻す値
KanjiEBCDIC
バイト数による string_expression の長さ。
1 バイト文字とマルチバイト文字の混合値が予想されます。
シフトアウト/シフトイン文字が存在すれば、それも結果の
カウントに含まれます。
KanjiEUC
KanjiShift-JIS
244
クライアント セッション文字セットに基づく、論理文字数
による string_expression の長さ。
SQL 関数、演算子、式および述部
第 5 章 属性関数
CHARACTER LENGTH
クライアント文字セット
CHARACTER_LENGTH が戻す値
1 バイト文字とマルチバイト文字の混合値が予想されます。
ASCII EBCDIC
バイト数による string_expression の長さ。
注:
Teradata の国際化計画に従って、KANJI1 のサポートはサポート外になりました。
このサポートは、近い将来に廃止される予定です。KANJI1 はデフォルトの文字セッ
トとして許可されません。システムはデフォルトの KANJI1 文字セットを UNICODE
文字セットに変更します。KANJI1 の新規オブジェクトの作成は、高度に制限され
ています。KANJI1 を使用する問合わせやアプリケーションの多くは、従来通り動
作しますが、KANJI1 を使用するサイトはできるだけ早く別の文字セットに変換す
る必要があります。詳細については、<国際文字セットのサポート、B035-1125>の
KANJI1 文字セットを参照してください。
後続埋め込み文字も文字としてみなされるので、CHARACTER 列の値の長さは、常
にその列に定義されている長さと等しくなります。
VARCHAR または CLOB 列の値の長さは、常にその値に含まれている文字の数(後続
埋め込み文字も含む)と等しくなります。
後続の埋め込み文字の抑止
データ値の文字カウントから後続の埋め込み文字を抑止するには、
CHARACTER_LENGTH への引数に TRIM 関数を使用します。たとえば、
SELECT CHARACTER_LENGTH( TRIM( TRAILING FROM Name ) )
FROM Employee;
例
以下の文は、各社員名の文字数を調べるために、CHARACTER_LENGTH 関数を
VARCHAR(30) CHARACTER SET LATIN タイプの Name 列に適用します。
SELECT Name, CHARACTER_LENGTH(Name)
FROM Employee;
結果は以下のようになります(区切り文字のブランクも文字とみなされます)。
Name
-------Smith T
Newman P
Omura H
.
SQL 関数、演算子、式および述部
Character_Length(Name)
---------------------7
8
7
.
245
第 5 章 属性関数
DEFAULT
セット 1 の例: KanjiEBCDIC
サーバー文字セット
例
CHARACTER_LENGTH が戻す値
GRAPHIC
ABC
3
KANJI1
De<MNP >
10
<><>
4
サーバー文字セット
例
CHARACTER_LENGTH が戻す値
KANJI1
<><>
10
D eF
3
UNICODE
ABC
3
GRAPHIC
ABC
3
サーバー文字セット
例
CHARACTER_LENGTH が戻す値
KANJI1
ss3 C ss3 D
2
セット 2: KanjiShift-JIS
セット 3: KanjiEUC
GRAPHIC
UNICODE
LATIN
2
<><>
0
dA ss2 B ss3 E
4
ABC
3
関連トピック
詳細は、以下を参照してください。
• 「データ型の変換」。
• CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>
を参照してください。
• ユーティリティ 、B035-1102。
• <国際文字セットのサポート、B035-1125>の「KANJI1 文字セット」。
DEFAULT
目的
指定された列または派生した列の現在のデフォルト値を返します。
246
SQL 関数、演算子、式および述部
第 5 章 属性関数
DEFAULT
構文
DEFAULT
( column_name )
構文要素
column_name
基本テーブル、ビュー、キュー テーブル、または派生テーブルの列の名前。
列名は、修飾されていてもいなくてもかまいません。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠していますが、非 ANSI の Teradata Database 拡
張機能が含まれています。
結果のタイプと属性
次の表に、DEFAULT(x)の結果タイプ、形式、およびタイトルを示します。
データ タイプ
書式
タイトル
指定された列のデータ タイプ
指定された列の形式
Default(x)
データ タイプのデフォルトの書式の詳細については、< SQL データ型とリテラル、
B035-1143>の「データ タイプの書式および書式句」を参照してください。
結果値
DEFAULT 関数は、指定された列または派生した列(列名が省略された場合)のデフォ
ルト値を返します。
指定された列または派生した列がビュー列または派生したテーブルの列である場合
は、DEFAULT 関数は基礎となるテーブル列のデフォルト値を戻します。
たとえば、デフォルト値が CURRENT_TIME または USER の場合のように、列のデ
フォルト値がシステム変数に評価されると 、DEFAULT 関数は文が実行されたときに
システム変数の値を返します 。
DEFAULT は次のいずれかの条件が真の場合に NULL を返します。
•
•
•
•
指定された列または派生した列が DEFAULT NULL 句を使用して定義されている
指定された列または派生した列に明示的なデフォルト値がない
指定された列または派生した列のデータ タイプが UDT である
指定された列または派生した列が、明示的なデフォルト値を持たない単一の基礎
となるテーブルの列から派生したビュー列の名前である
例については、「ビューの列名の指定」を参照してください。
SQL 関数、演算子、式および述部
247
第 5 章 属性関数
DEFAULT
• たとえば、ビュー列がリテラル式から派生した場合などのように、指定された列
または派生した列が、単一の基礎となるテーブルの列から派生したものではない
ビュー列の名前である
列名の省略
INSERT、UPDATE、または MERGE 文の特定の条件下、あるいは比較演算子が含ま
れた述部の句では、列名を省略した DEFAULT の形式を使用できます。列名を省略し
た DEFAULT の形式は式の一部にはできません。
DEFAULT 関数で列名が指定されないとき、Teradata Database は列を文脈に基づい
て派生します。たとえば、以下のテーブル定義があるとします。
CREATE TABLE Manager
(Emp_ID
INTEGER
,Dept_No
INTEGER DEFAULT 99
);
たとえば次の INSERT 文では、列名のない DEFAULT を使用して、Dept_No 列にデ
フォルト値を挿入しています。
INSERT INTO Manager VALUES (103499, DEFAULT);
列名を指定しないで DEFAULT 関数を使用する場合、Teradata Database が列の文脈
を派生できないとエラーが発生します。
比較演算子が含まれた述部の句で DEFAULT 関数を使用するときに列名を省略する例
については、「例: 述部での DEFAULT の使用」を参照してください。
INSERT、UPDATE、および MERGE 文で DEFAULT 関数を使用する場合の詳細は、<
SQL データ操作言語、B035-1146>を参照してください。
修飾された列名の使用
テーブルの名前を含む限定された列名を指定する場合、FROM 句のない SELECT 文
で DEFAULT を使用できます。たとえば、次の文を使用して、Manager テーブルの
Dept_No 列のデフォルト値を取得できます。
SELECT DEFAULT(Manager.Dept_No);
制約事項
DEFAULT 関数は、PPI を定義するための区分化式として使用することはできません。
エラー条件
DEFAULT 関数は次のいずれかの条件の場合にエラーになることがあります。
248
SQL 関数、演算子、式および述部
第 5 章 属性関数
DEFAULT
• 列名が省略されているために、Teradata Database が列の文脈を派生できない
• DEFAULT 関数が、PPI を定義するための区分化式に使用されている
• 列名が省略されており、列名なしでは DEFAULT 関数をサポートしていない式に
DEFAULT 関数が使用されている
• DEFAULT 関数が、結果タイプに互換性がない式に使用されている
たとえば、次のテーブル定義の場合を考えてみましょう。
CREATE TABLE Parts_Table
(Part_Code
INTEGER DEFAULT 9999
,Part_Name
CHAR(20)
);
次の文の結果はエラーになります。これは、DEFAULT 関数の結果タイプが、結
果が比較される列と互換性がないからです。
SELECT * FROM Parts_Table WHERE Part_Name = DEFAULT(Part_Code);
例
例: 特定の条件下でのデフォルト値の挿入
次の Employee テーブル定義を考えます。
CREATE TABLE Employee
(Emp_ID
INTEGER
,Last_Name
VARCHAR(30)
,First_Name VARCHAR(30)
,Dept_No
INTEGER DEFAULT 99
);
たとえば次の式では、入力された値が負の場合に、Dept_No 列にデフォルト値を挿
入するために DEFAULT 関数を使用しています。
USING (id INTEGER, n1 VARCHAR(30), n2 VARCHAR(30), dept INTEGER)
INSERT INTO Employee VALUES
(:id
,:n1
,:n2
,CASE WHEN (:dept < 0) THEN DEFAULT(Dept_No) ELSE :dept END
);
例: 述部での DEFAULT の使用
次の文では、DEFAULT 関数を使用して Dept_No 列の値と Dept_No 列のデフォルト
値を比較しています。比較操作には、単一の列参照が含まれるため、列名が省略さ
れていても、Teradata Database は DEFAULT 関数の列の文脈を派生できます。
SELECT * FROM Employee WHERE Dept_No < DEFAULT;
SQL 関数、演算子、式および述部
249
第 5 章 属性関数
DEFAULT
DEFAULT 関数が NULL と評価されると、述部は不明になり、WHERE 条件は FALSE
になります。
例: ビューの列名の指定
次の定義のある DBC.HostsInfo システム ビューについて考慮します。
REPLACE VIEW DBC.HostsInfo (LogicalHostId, HostName, DefaultCharSet)
AS SELECT
LogicalHostId
,HostName
,DefaultCharSet
FROM DBC.Hosts WITH CHECK OPTION;
基礎となるテーブルの DBC.Hosts には、次の定義があります。
CREATE SET TABLE DBC.Hosts, FALLBACK, NO BEFORE JOURNAL,
NO AFTER JOURNAL, CHECKSUM = DEFAULT
(LogicalHostId SMALLINT FORMAT 'ZZZ9' NOT NULL
,HostName VARCHAR(128) CHARACTER SET UNICODE NOT CASESPECIFIC NOT
NULL
,DefaultCharSet VARCHAR(128) CHARACTER SET UNICODE NOT CASESPECIFIC
NOT NULL)
UNIQUE PRIMARY INDEX (LogicalHostId)
UNIQUE INDEX (HostName);
次の文では、DEFAULT 関数に DBC.HostsInfo.HostName ビュー列名を使用していま
す。
SELECT DISTINCT DEFAULT(HostName) FROM DBC.HostsInfo;
DEFAULT 関数の結果は NULL になります。これは、HostName ビュー列が、明示的
なデフォルト値のないテーブル列から派生しているからです 。
関連トピック
詳細情報:
• 述部の使用については、「論理述語」を参照してください。
• 述部の比較演算については、「比較演算子と関数」を参照してください。
• DEFAULT 値が制御する句については、< SQL データ型とリテラル、B035-1143>
を参照してください。
• INSERT、UPDATE、および MERGE 文については、< SQL データ操作言語、
B035-1146>を参照してください。
250
SQL 関数、演算子、式および述部
第 5 章 属性関数
FORMAT
FORMAT
目的
指定の式に宣言されている書式を戻します。
構文
FORMAT
( expression )
構文要素
expression
形式が報告される式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果のタイプと属性
FORMAT は 30 文字までの CHAR(n)文字列を返します。次の表に、FORMAT の結果
タイプ、文字セット、書式、およびタイトルを示します。
データ タイプ
書式
タイトル
CHAR(n) CHARACTER SET UNICODE
X(30)
Format(named_expression
)
例: Salary 列のフォーマットの要求
以下の文は、Employee テーブルの Salary 列の書式を要求します。
SELECT FORMAT(Employee.Salary);
結果は、以下のようになります。
Format(Salary)
-----------------------------ZZZ,ZZ9.99
関連トピック
詳細については、< SQL データ型とリテラル、B035-1143>の「データ型の書式お
よび書式句」を参照してください。
SQL 関数、演算子、式および述部
251
第 5 章 属性関数
OCTET LENGTH
OCTET LENGTH
目的
指定の文字セット(エクスポート幅の値も考慮する)に変換した場合の
string_expression の長さをオクテット単位で戻します。
構文
OCTET_LENGTH
(
string_expression
)
, character_set_name
構文要素
string_expression
オクテット単位の数が必要な文字列。
character_set_name
結果を戻す文字セット。character_set_name を指定しない場合は、セッション文字
セットが使用されます。
character_string_expression 引数が NULL の場合、結果は NULL になります。
Teradata 提供の文字セットのリストについては、「使用上の注意」のテーブルを参
照してください。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
引数のタイプ
string_expression のデータ型は、以下のいずれかでなければなりません。
• CHARACTER または VARCHAR
• 事前定義された文字タイプへの暗黙 CAST を持つ UDT
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。
OCTET_LENGTH を含め、システム演算子および関数用の UDT の暗黙の型変換
は、ANSI SQL 標準の Teradata 拡張機能です。この拡張を無効にするには、DBS
制御レコードの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定し
ます。
string_expression 引数が NULL の場合、結果は NULL になります。
252
SQL 関数、演算子、式および述部
第 5 章 属性関数
OCTET LENGTH
使用上の注意
シフトアウト/シフトイン文字や後続 GRAPHIC 埋め込み文字も結果のカウントに含
まれます。
OCTET_LENGTH は、Teradata モードでも ANSI モードでも同じように動作します。
string_expression が次の場
合:
結果
KANJI1 タイプ
結果は、character_set_name に依存しません。
CHARACTER 以外のデータ
エラーが生成されます。
OCTET_LENGTH はエクスポート幅の値を考慮します。エクスポート幅の詳細は<SQL
データ定義言語 - 構文規則および例、B035-1144>の「CREATE USER」を参照して
ください。
以下の表は、Teradata に用意されているクライアント文字セットをまとめたもので
す。これらの文字セットはシステムに付属していますが 、システム管理者が個別に
導入しないと使用可能になりません。
サイトによっては、 サイト定義の文字セットがあるかもしれません。それぞれのサ
イトで使用できる文字セットの完全リストについては、システム管理者に確認して
ください。
ビルトインで見つかった文字セット:
•
•
•
•
ASCII
EBCDIC
UTF8
UTF16
DBC.CharTranslationsV で見つかった文字セット:
•
•
•
•
•
•
•
•
•
•
•
•
•
•
EBCDIC037_0E
EBCDIC273_0E
EBCDIC277_0E
HANGULEBCDIC933_1II
HANGULKSC5601_2R4
KANJIEBCDIC5026_0I
KANJIEBCDIC5035_0I
KANJIEUC_0U
KANJISJIS_0S
KATAKANAEBCDIC
LATIN1252_0A
LATIN1_0A
LATIN9_0A
SCHEBCDIC935_2IJ
SQL 関数、演算子、式および述部
253
第 5 章 属性関数
OCTET LENGTH
• SCHGB2312_1T0
• TCHBIG5_1R0
• TCHEBCDIC937_3IB
Windows コード ページと互換性のあるセッション文字セットとともに、
DBC.CharTranslationsV で見つかった文字セット:
•
•
•
•
•
•
•
•
•
•
•
•
ARABIC1256_6A0
CYRILLIC1251_2A0
HANGUL949_7R0
HEBREW1255_5A0
KANJI932_1S0
LATIN1250_1A0
LATIN1252_0A
LATIN1254_7A0
LATIN1258_8A0
SCHINESE936_6R0
TCHINESE950_8R0
THAI874_4A0
例: OCTET_LENGTH からの出力
OCTET_LENGTH の出力例を以下の表に示します。
クライアント文字
セット
サーバー文字セット string_expression
結果
EBCDIC
LATIN
abcdefgh
8
ASCII
KANJI1
abcdefgh
8
KanjiEBCDIC
KANJI1
AB<CDE >P
11
KanjiEBCDIC
GRAPHIC
MNOP
8 (レコード モード)
10 (フィールド モー
ド)
KanjiEUC
KANJISJIS
dA ss2 B ss3 E
8
KanjiShift-JIS
KANJISJIS
D eF
5
KanjiShift-JIS
UNICODE
ABC
6
関連トピック
詳細は、以下を参照してください。
• 概要
• ユーティリティ 、B035-1102。
254
SQL 関数、演算子、式および述部
第 5 章 属性関数
TITLE
• CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>
を参照してください。
TITLE
目的
表示結果または印刷結果の見出しに現われる式のタイトルを戻します。
構文
( expression )
TITLE
構文要素
expression
タイトルを戻す式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果のタイプと属性
TITLE は 60 文字までの CHAR(n)文字列を返します。次の表に、TITLE の結果タイ
プ、文字セット、書式、およびタイトルを示します。
データ タイプ
書式
タイトル
CHAR(n) CHARACTER SET UNICODE
X(60)
Title(named_expression)
使用上の注意
表示結果または印刷結果の見出しを列名(デフォルトの見出し)と異なるものに変更
する場合、TITLE 句を使用してください。
例: Salary 列のタイトルの要求
以下の文は、Employee テーブルの Salary 列のタイトルを要求します。
SELECT TITLE(Employee.Salary);
結果は、以下のようになります。
SQL 関数、演算子、式および述部
255
第 5 章 属性関数
TYPE
Title(Salary)
-----------------------------------------------------------Salary
関連トピック
詳細は、以下を参照してください。
• < SQL データ型とリテラル、B035-1143>の「データ型の書式および書式句」
• SQL データ型とリテラル、B035-1143.
TYPE
目的
式に定義されているデータ タイプを戻します。
構文
( expression )
TYPE
構文要素
expression
データ型を戻す式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果のタイプと属性
TYPE は、式のデータ タイプの名前を含む CHAR(n)文字列を戻します。
引数が関数または演算の場合、TYPE は、関数または演算の結果タイプを示す文字列
を戻します。演算または関数の結果タイプの規則については、該当する関数または
演算の資料を参照してください。
次の表に、TYPE の結果タイプ、文字セット、書式、およびタイトルを示します。
256
データ タイプ
書式
タイトル
CHAR(n) CHARACTER SET LATIN
X(39)
Type(named_expression)
SQL 関数、演算子、式および述部
第 5 章 属性関数
TYPE
サポートされるデータ型のリストについては、<SQL データ タイプおよびリテラル
>を参照してください。地理空間タイプについては、<SQL 地理空間タイプ>を参照
してください。
文字タイプの引数
文字タイプの引数のサーバー文字セットがユーザーのデフォルト サーバー文字セッ
トと異なる場合、結果の文字セットには CHARACTER SET 句と、引数のサーバー文
字セットの名前が含まれることになります。
例
例 1: ユーザーのデフォルトのサーバー文字セットが LATIN である場合
次のテーブル定義の Name 列を考慮します。
CREATE TABLE Employee
(EmployeeID INTEGER
,Name
CHARACTER(30) CHARACTER SET LATIN
,Salary
DECIMAL(8,2));
ユーザーのデフォルト サーバー文字セットが LATIN の場合、TYPE が戻す Name 列
に関する文字列には CHARACTER SET 句が含まれていません。
SELECT TYPE(Employee.Name);
Type(Name)
---------CHAR(30)
例 2: ユーザーのデフォルトのサーバー文字セットが LATIN だが、Name 列のサーバー文字
セットが UNICODE である場合
ユーザーのデフォルト サーバー文字セットが LATIN であっても、Name 列のサー
バー文字セットが UNICODE である場合、結果の列には CHARACTER SET 句が入り
ます。
CREATE TABLE Employee
(EmployeeID INTEGER
,Name VARCHAR(30) CHARACTER SET UNICODE
,Salary
DECIMAL(8,2));
SELECT TYPE(Employee.Name);
Type(Name)
--------------------------------VARCHAR(30) CHARACTER SET UNICODE
例 3: Name 列と Salary 列の型を返す
次の文は Name 列と Salary 列のタイプを戻します。
SQL 関数、演算子、式および述部
257
第 5 章 属性関数
TYPE
SELECT TYPE(Employee.Name), TYPE(Employee.Salary);
Type(Name)
Type(Salary)
----------- -----------VARCHAR(30) DECIMAL(8,2)
例 4: TYPE を使用して、2 つの列のデータ型を要求する
TYPE を使って、それぞれ GRAPHIC と LONG VARCHAR CHARACTER SET GRAPHIC
として定義されている 2 つの列のデータ型を要求する場合、結果は以下のようにな
ります。
TYPE(GColName)
----------------------------CHAR(4) CHARACTER SET GRAPHIC
TYPE(LVGColName)
-----------------------------------VARCHAR(32000) CHARACTER SET GRAPHIC
LONG VARCHAR CHARACTER SET GRAPHIC 列の場合、返される長さは最大長の
32000 です。
例 5: TYPE 関数の使用
以下の TYPE 関数について考えてみましょう。
SELECT TYPE(SUBSTR(Employee.Name,3,2));
SUBSTR の結果タイプはセッション モードに応じて異なります。
セッションが ANSI モードに設定されている場合、戻される結果は次のようになりま
す。
Type(Substr(Name,3,2))
---------------------VARCHAR(30)
セッションが Teradata モードに設定されている場合、戻される結果は次のようにな
ります。
Type(Substr(Name,3,2))
---------------------VARCHAR(2)
例 6: BLOB 列への TYPE 関数の適用
次のテーブル定義を考えます。
CREATE TABLE images
(imageid INTEGER
,imagedesc VA
RCHAR(50)
,image BLOB(2K))
UNIQUE PRIMARY INDEX (imageid);
次の文は、TYPE 関数を BLOB 列に適用します。
SELECT TYPE(images.image) FROM images;
結果は以下のようになります。
258
SQL 関数、演算子、式および述部
第 5 章 属性関数
TYPE
Type(image)
----------BLOB(2048)
結果が通常の整数長になることと、CREATE TABLE 文の中で BLOB 列を定義するた
めに使用した K オプションを使用していないことに注意してください。
関連トピック
詳細は、以下を参照してください。
• <SQL 地理空間タイプ>。
• <SQL データ タイプおよびリテラル>。
SQL 関数、演算子、式および述部
259
第 5 章 属性関数
TYPE
260
SQL 関数、演算子、式および述部
第6章
ビット/バイト操作関数
概要
この章では、バイト/ビット操作の演算をサポートする関数について説明します。
前提条件
この章で取り上げるバイト/ビット操作関数は、埋め込みサービス システム関数で
す。埋め込みサービス関数の有効化と呼び出しについて、詳細は埋め込みサービス
システム関数 を参照してください。
ビットおよびバイトの番号付けモデル
次の図は、この章で説明するバイト/ビット操作関数で採用している、ビットおよび
バイトの論理的な番号付けモデルです。
このモデルは、ビッグ エンディアンまたはリトル エンディアンとは無関係なもの
です。数値データ型に使用する番号方式は、バイト列に使用する番号方式と同じで
す。これにより、目的に適ったビット マスクの作成が容易になります。
バイト/ビット操作関数を使用するときには、数値データ タイプと BYTE データ タ
イプを下図のように思い描きながら、どのようなマスク(bit_mask_arg)を対象デー
タ(target_arg)に適用するかについて考えてください。
BYTEINT
msb
MSB
lsb
LSB
BYTE 1
Bit 7
...
: most and least significant bits
: Most and Least Significant Bytes
: Computer Science binary representation
Bit 0
: Bit Numbering
例: BYTEINT 値
BYTEINT 値が 40、バイナリ表現で 00101000 の場合:
SQL 関数、演算子、式および述部
261
第 6 章 ビット/バイト操作関数
概要
msb
MSB
lsb
LSB
00101000
Bit 7
...
Bit 0
SMALLINT
msb
MSB
lsb
LSB
BYTE 1
Bit 15
: most and least significant bits
: Most and Least Significant Bytes
BYTE 2
...
: Computer Science binary representation
Bit 0
: Bit Numbering
例: SMALLINT 値
SMALLINT 値が 10,280、バイナリ表現で 0010100000101000 の場合:
msb
MSB
lsb
LSB
00101000
00101000
Bit 15
...
Bit 0
INTEGER
msb
MSB
lsb
LSB
BYTE 1 BYTE 2 BYTE 3 BYTE 4
: Computer Science binary representation
Bit 31
: Bit Numbering
...
Bit 0
例: 整数値
INTEGER 値が 673,720,360、バイナリ表現で 00101000 00101000 00101000
00101000 の場合:
msb
MSB
lsb
LSB
00101000
Bit 32
00101000
00101000
00101000
...
Bit 0
BIGINT
msb
MSB
lsb
LSB
BYTE 1
Bit 7
262
...
: most and least significant bits
: Most and Least Significant Bytes
: Computer Science binary representation
Bit 0
: Bit Numbering
SQL 関数、演算子、式および述部
第 6 章 ビット/バイト操作関数
概要
例: BIGINT 値
BIGINT 値が 2,893,606,913,523,066,920、バイナリ表現で?00101000 00101000
00101000 00101000 00101000 00101000 00101000 00101000 の場合:
msb
MSB
lsb
LSB
00101000
Bit 7
...
Bit 0
BYTE および VARBYTE
例: VARBYTE 値
VARBYTE(8)、8 バイトの場合:
msb
MSB
lsb
LSB
BYTE 1 BYTE 2 BYTE 3 BYTE 4 BYTE 5 BYTE 6 BYTE 7 BYTE 8
Bit 63
...
Bit 0
例: 3 バイトの VARBYTE 値
VARBYTE(8)、3 バイトの場合:
msb
MSB
lsb
LSB
BYTE 1 BYTE 2 BYTE 3
Bit 23
...
Bit 0
// Bit Numbering
例: VARBYTE 値
BYTE(4)の例:
lsb
LSB
msb
MSB
BYTE 1 BYTE 2 BYTE 3 BYTE 4
Bit 31
...
Bit 0
16 進数バイト リテラル
バイト/ビット体系の関数では、16 進数バイト リテラルを次に示すように解釈しま
す。
2 バイト 16 進数バイト リテラル: '00FF'XB
SQL 関数、演算子、式および述部
263
第 6 章 ビット/バイト操作関数
概要
msb
MSB
lsb
LSB
00
FF
Bit 15
...
Bit 0
4 バイト 16 進数バイト リテラル:'01020304'XB
msb
MSB
01
lsb
LSB
02
Bit 31
03
...
04
Bit 0
16 進数バイト リテラルは、偶数個の 16 進数字によって表記されます。数字の数が
奇数の場合、16 進数リテラルの右側に 0 が付加されます。たとえば、
3 バイト 16 進数バイト リテラル'112233'XB は、4 バイト 16 進数バイト リテラル
では'11223300'XB になります。
msb
MSB
11
Bit 31
lsb
LSB
22
33
...
00
Bit 0
詳細については、< SQL データ型とリテラル、B035-1143>の「16 進数バイト リテ
ラル」を参照してください。
長さの等しくない引数に対するビット/バイト演算の実行
このトピックの説明は、BITOR 関数、BITXOR 関数および BITAND 関数にのみ適用
されます。
長さが異なる引数 target_arg と bit_mask_arg が上記の関数に渡された場合:
• 引数 target_arg と bit_mask_arg を、それぞれの最下位のバイトまたはビットで
整列する。
• 短い方の引数には、長い方の引数と同じサイズになるまで、左側に 0 を埋め込む。
Teradata Database は、右側ではなく左側に埋め込みを実行します。このように
すると、バイト列のサイズが変更される度に、ビット マスクとして利用する 16
進数バイト リテラルを変更する必要がなくなります。
例: INTEGER 型に対する BITAND 演算の問合わせ
次の問合わせでは、INTEGER 型と 1 バイトの 16 進数バイト リテラルに対して
BITAND 演算を実行します。
SELECT BITAND(287454020, 'FFFF'XB);
INTEGER 値の 287,454,020 は、16 進数値では 0x11223344 になり、そのビット番
号表現は次のようになります。
264
SQL 関数、演算子、式および述部
第 6 章 ビット/バイト操作関数
概要
msb
MSB
lsb
LSB
11
22
Bit 31
33
...
44
Bit 0
16 進数バイト リテラル 0xFFFF は、ビット番号表現では、次のようになります。
msb
MSB
lsb
LSB
FF
Bit 15
FF
...
Bit 0
BITAND 演算を処理するために、2 つの引数は、それぞれの最下位バイトまたはビッ
トで整列されます。
MSB
LSB
11
22
Bit 31
33
...
MSB
44
Bit 0
LSB
FF
Bit 15
FF
...
Bit 0
短い方の 16 進数バイト リテラル 0xFFFF には、INTEGER 値 287,454,020 と同じ長
さになるまで、左側に 0 が埋め込まれます。
MSB
11
LSB
22
Bit 31
33
...
Bit 0
MSB
00
44
LSB
00
Bit 31
FF
...
FF
Bit 0
両方のオペランドが同じサイズになったときに、BITAND 演算が実行され、次に示
す結果が生成されます。
MSB
00
LSB
00
Bit 31
SQL 関数、演算子、式および述部
33
...
44
Bit 0
265
第 6 章 ビット/バイト操作関数
BITAND
BITAND
目的
2 つの入力引数を基に、対応するビットの論理積演算を実行します。
構文
BITAND
( target_arg, bit_mask_arg )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
target_arg
数値または可変長バイト式。
bit_mask_arg
固定長バイト値、可変長バイト値、または数値式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
説明
この関数は、同じ長さの 2 つのビット パターンを受け取り、対応するビットのペア
ごとに論理積演算を実行します。同じ位置のビットがどちらも 1 の場合、結果は 1
になります。それ以外の場合の結果は、0 になります。入力引数のどちらかが NULL
の場合、この関数は NULL を返します。
引数 target_arg と bit_mask_arg の長さが異なる場合、これらの引数は次に示すよう
に処理されます。
• 引数 target_arg と bit_mask_arg を、それぞれの最下位のバイトまたはビットで
整列する。
• 短い方の引数には、長い方の引数と同じサイズになるまで、左側に 0 を埋め込む。
引数のタイプと規則
BITAND は、オーバーロード スカラー関数です。target_arg パラメータのデータ型
は、以下のいずれかになります。
266
SQL 関数、演算子、式および述部
第 6 章 ビット/バイト操作関数
BITAND
•
•
•
•
•
BYTEINT
SMALLINT
INTEGER
BIGINT
VARBYTE(n)
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
VARBYTE(n)
VARBYTE(n)
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
この関数に渡す式は、上記に明示したデータ タイプと一致するか、UDF に適用され
る暗黙のデータ タイプ変換規則を使用して、上記のタイプに変換できる必要があり
ます。たとえば、BITAND(BYTEINT, INTEGER)は、暗黙的に BITAND(INTEGER,
INTEGER)に変換できるため許容されます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って上記に明示したデー
タ タイプのいずれかに変換できない引数がある場合は、その引数を明示的にキャス
トする必要があります。詳細については、<SQL 外部ルーチン プログラミング、
B035-1147>の「互換データ型」と「オーバーロード関数のパラメータ型」を参照
してください。
いずれかの引数が、上記に明示したデータ タイプに変換できない場合は、実行依頼
された DML UDF 式と一致する関数が存在しないことを示すエラーが返されます。
結果のタイプと属性
結果のデータ型は、次の表に示すように、この関数に渡した入力引数 target_arg の
データ型によって異なります。
SQL 関数、演算子、式および述部
267
第 6 章 ビット/バイト操作関数
BITNOT
target_arg のデータ型
結果のタイプ
デフォルト書式となる結果の書式
BYTEINT
BYTEINT
BYTEINT
SMALLINT
SMALLINT
SMALLINT
INTEGER
INTEGER
INTEGER
BIGINT
BIGINT
BIGINT
VARBYTE(n)
VARBYTE(n)
VARBYTE(n)
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
BITAND のデフォルト タイトルは、BITAND(target_arg、bit_mask_arg)です。
例: BITAND 関数での問合わせ
次の問合わせの入力引数 23 は、データ タイプが BYTEINT であり、バイナリ表現は
00010111 になります。入力引数 20 は、データ タイプが BYTEINT であり、バイナ
リ表現は 00010100 になります。2 つの引数のビット単位の積の結果は、BYTEINT
値の 20 (つまり、バイナリの 00010100)になります。この値が、問合わせから返さ
れます。
SELECT BITAND(23,20);
関連トピック
詳細は、以下を参照してください。
• <SQL 外部ルーチン プログラミング、B035-1147>の「関数名のオーバーロード」
• SQL データ型とリテラル、B035-1143。
• target_arg および bit_mask_arg の詳細については、「長さの等しくない引数に対
するビット/バイト演算の実行」を参照してください。
BITNOT
目的
入力引数のバイナリ表現に対して、ビット単位の補数演算を実行します。
構文
BITNOT
( target_arg )
TD_SYSFNLIB.
268
SQL 関数、演算子、式および述部
第 6 章 ビット/バイト操作関数
BITNOT
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
target_arg
数値または可変長バイト式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
説明
ビット単位の否定である補数は、ビットごとの論理否定を実行する単項演算です。
この演算により、指定したバイナリ値自体の補数を生成します。引数の各桁が 0 な
らば 1 になり、1 ならば 0 になります。target_arg が NULL の場合、BITNOT は
NULL を返します。
引数のタイプと規則
BITNOT は、オーバーロード スカラー関数です。この関数は以下に示すパラメータ
のデータ タイプで定義されます。
•
•
•
•
•
BYTEINT
SMALLINT
INTEGER
BIGINT
VARBYTE(n)
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
この関数に渡す式は、上記に明示したデータ タイプと一致するか、UDF に適用され
る暗黙のデータ タイプ変換規則を使用して、上記のタイプに変換できる必要があり
ます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って上記に明示したデー
タ タイプのいずれかに変換できない引数は、明示的にキャストする必要がありま
す。詳細については、<SQL 外部ルーチン プログラミング、B035-1147>の「互換
データ型」と「オーバーロード関数のパラメータ型」を参照してください。
上記に明示したデータ タイプのいずれかに引数が変換できない場合は、実行依頼さ
れた DML UDF 式と一致する関数が存在しないことを示すエラーが返されます。
SQL 関数、演算子、式および述部
269
第 6 章 ビット/バイト操作関数
BITOR
オーバーロード関数の詳細については、<SQL 外部ルーチン プログラミング、
B035-1147>の「関数名のオーバーロード」を参照してください。
結果のタイプと属性
結果のデータ型は、次の表に示すように、この関数に渡した入力引数 target_arg の
データ型によって異なります。
target_arg のデータ型
結果のタイプ
デフォルト書式となる結果の書式
BYTEINT
BYTEINT
BYTEINT
SMALLINT
SMALLINT
SMALLINT
INTEGER
INTEGER
INTEGER
BIGINT
BIGINT
BIGINT
VARBYTE(n)
VARBYTE(n)
VARBYTE(n)
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
BITNOT のデフォルト タイトルは、BITNOT(target_arg)です。
デフォルトのデータ タイプ書式については、< SQL データ型とリテラル、B035-1143>
を参照してください。
例: BITNOT 関数での問合わせ
次の問合わせの入力引数 2 は、データ タイプが BYTEINT であり、バイナリ表現は
00000010 になります。この値に対して BITNOT 演算を実行すると、結果は
BYTEINT 値の-3 (バイナリでは、11111101)になります。
SELECT BITNOT(2);
BITOR
目的
2 つの入力引数を基に、対応するビットの論理和演算を実行します。
構文
BITOR
( target_arg, bit_mask_arg )
TD_SYSFNLIB.
270
SQL 関数、演算子、式および述部
第 6 章 ビット/バイト操作関数
BITOR
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
target_arg
数値または可変長バイト式。
bit_mask_arg
固定長バイト値、可変長バイト値、または数値式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
説明
この関数は、同じ長さの 2 つのビット パターンを受け取り、次の表に示すように、
対応するビットのペアごとに論理和演算を実行します。
IF...
結果
入力引数を基にしたビットのどち 1
らかが 1
入力引数を基にしたビットの両方 0
が0
入力引数のいずれかが NULL
NULL
引数 target_arg と bit_mask_arg の長さが異なる場合、これらの引数は次に示すよ
うに処理されます。
• 引数 target_arg と bit_mask_arg を、それぞれの最下位のバイトまたはビットで
整列する。
• 短い方の引数には、長い方の引数と同じサイズになるまで、左側に 0 を埋め込む。
詳細については、「長さの等しくない引数に対するビット/バイト演算の実行」を参
照してください。
引数のタイプと規則
BITOR はオーバーロード スカラー関数です。target_arg パラメータのデータ型は、
以下のいずれかになります。
• BYTEINT
• SMALLINT
SQL 関数、演算子、式および述部
271
第 6 章 ビット/バイト操作関数
BITOR
• INTEGER
• BIGINT
• VARBYTE(n)
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
VARBYTE(n)
VARBYTE(n)
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
この関数に渡す式は、上記に明示したデータ タイプと一致するか、UDF に適用され
る暗黙のデータ タイプ変換規則を使用して、上記のタイプに変換できる必要があり
ます。たとえば、BITOR(BYTEINT, INTEGER)は、暗黙的に
BITOR(INTEGER,INTEGER)に変換できるため許容されます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って上記に明示したデー
タ タイプのいずれかに変換できない引数がある場合は、その引数を明示的にキャス
トする必要があります。詳細については、<SQL 外部ルーチン プログラミング 、
B035-1147>の「互換データ型」と「オーバーロード関数のパラメータ型」を参照し
てください。
いずれかの引数が、上記に明示したデータ タイプに変換できない場合は、実行依頼
された DML UDF 式と一致する関数が存在しないことを示すエラーが返されます。
オーバーロード関数の詳細については、<SQL 外部ルーチン プログラミング、
B035-1147>の「関数名のオーバーロード」を参照してください。
結果のタイプと属性
結果のデータ型は、次の表に示すように、この関数に渡した入力引数 target_arg の
データ型によって異なります。
272
SQL 関数、演算子、式および述部
第 6 章 ビット/バイト操作関数
BITXOR
target_arg のデータ型
結果のタイプ
デフォルト書式となる結果の書式
BYTEINT
BYTEINT
BYTEINT
SMALLINT
SMALLINT
SMALLINT
INTEGER
INTEGER
INTEGER
BIGINT
BIGINT
BIGINT
VARBYTE(n)
VARBYTE(n)
VARBYTE(n)
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
BITOR のデフォルト タイトルは、BITOR(target_arg, bit_mask_arg)です。
デフォルトのデータ タイプ書式については、< SQL データ型とリテラル、
B035-1143>を参照してください。
例: BITOR 関数での問合わせ
次の問合わせの入力引数 23 は、データ タイプが BYTEINT であり、バイナリ表現
は 00010111 になります。入力引数 45 は、データ タイプが BYTEINT であり、バ
イナリ表現は 00101101 になります。2 つの引数のビット単位の和の結果は、
BYTEINT 値の 63 (つまり、バイナリの 00111111)になります。この値が、問合わ
せから返されます。
SELECT BITOR(23,45);
BITXOR
目的
2 つの入力引数のバイナリ表現に対して、ビット単位の排他和を実行します。
構文
BITXOR
( target_arg, bit_mask_arg )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
target_arg
数値または可変長バイト式。
SQL 関数、演算子、式および述部
273
第 6 章 ビット/バイト操作関数
BITXOR
bit_mask_arg
固定長バイト値、可変長バイト値、または数値式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
説明
ビット単位の排他和は、同じ長さの 2 つのビット パターンを受け取り、対応する
ビットのペアごとに排他的論理和を実行します。実行結果は、各位置の 2 つのビッ
トが異なる場合は 1、2 つのビットが同じ場合は 0 になります。どちらかの入力引
数が NULL の場合、この関数は NULL を返します。
引数 target_arg と bit_mask_arg の長さが異なる場合、これらの引数は次に示すよう
に処理されます。
• 引数 target_arg と bit_mask_arg を、それぞれの最下位のバイトまたはビットで
整列する。
• 短い方の引数には、長い方の引数と同じサイズになるまで、左側に 0 を埋め込む。
引数のタイプと規則
BITXOR はオーバーロード スカラー関数です。target_arg パラメータのデータ型は、
以下のいずれかになります。
•
•
•
•
•
BYTEINT
SMALLINT
INTEGER
BIGINT
VARBYTE(n)
bit_mask_arg パラメータのデータ型は、target_arg パラメータのデータ型に応じて
多様に変化します。次に示す入力の組み合わせ(target_arg, bit_mask_arg)が許容され
ています。
274
target_arg 型
bit_mask_arg 型
BYTEINT
BYTE(1)
BYTEINT
BYTEINT
SMALLINT
BYTE(2)
SMALLINT
SMALLINT
INTEGER
BYTE(4)
SQL 関数、演算子、式および述部
第 6 章 ビット/バイト操作関数
BITXOR
target_arg 型
bit_mask_arg 型
INTEGER
INTEGER
BIGINT
BYTE(8)
BIGINT
BIGINT
VARBYTE(n)
VARBYTE(n)
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
この関数に渡す式は、上記に明示したデータ タイプと一致するか、UDF に適用され
る暗黙のデータ タイプ変換規則を使用して、上記のタイプに変換できる必要があり
ます。たとえば、BITXOR(BYTEINT, INTEGER)は、暗黙的に
BITXOR(INTEGER,INTEGER)に変換できるため許容されます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って上記に明示したデー
タ タイプのいずれかに変換できない引数がある場合は、その引数を明示的にキャス
トする必要があります。
いずれかの引数が、上記に明示したデータ タイプに変換できない場合は、実行依頼
された DML UDF 式と一致する関数が存在しないことを示すエラーが返されます。
結果のタイプと属性
結果のデータ型は、次の表に示すように、この関数に渡した入力引数 target_arg の
データ型によって異なります。
target_arg のデータ型
結果のタイプ
デフォルト書式となる結果の書式
BYTEINT
BYTEINT
BYTEINT
SMALLINT
SMALLINT
SMALLINT
INTEGER
INTEGER
INTEGER
BIGINT
BIGINT
BIGINT
VARBYTE(n)
VARBYTE(n)
VARBYTE(n)
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
BITXOR のデフォルト タイトルは、BITXOR(target_arg, bit_mask_arg)です。
例: BITXOR 関数での問合わせ
次の問合わせの入力引数 12 は、データ タイプが BYTEINT であり、バイナリ表現
は 00001100 になります。入力引数 45 は、データ タイプが BYTEINT であり、バ
イナリ表現は 00101101 になります。2 つの引数のビット単位の排他和の結果は、
SQL 関数、演算子、式および述部
275
第 6 章 ビット/バイト操作関数
COUNTSET
BYTEINT 値の 33 (つまり、バイナリの 00100001)になります。この値が、問合わ
せから返されます。
SELECT BITXOR(12,45);
関連トピック
詳細は、以下を参照してください。
• 「長さの等しくない引数に対するビット/バイト演算の実行」。
• SQL データ型とリテラル、B035-1143。
• UDF の暗黙のタイプ変換規則の詳細については、<SQL 外部ルーチン プログラミ
ング、B035-1147>の「互換データ型」と「オーバーロード関数のパラメータ型」
を参照してください。
• オーバーロード関数の詳細については、<SQL 外部ルーチン プログラミング、
B035-1147>の「関数名のオーバーロード」を参照してください。
COUNTSET
目的
target_arg 式内のバイナリのビット数を戻します。カウントされるビットは、
target_value_arg の値に応じて 1 に設定されるか、0 に設定されます。
構文
COUNTSET
( target_arg
TD_SYSFNLIB.
)
, target_value_arg
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
target_arg
数値または可変長バイト式。
target_value_arg
整数値。許容される値は 0 または 1 のみです。target_value_arg が指定されていな
い場合、デフォルトは 1 になります。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
276
SQL 関数、演算子、式および述部
第 6 章 ビット/バイト操作関数
COUNTSET
説明
COUNTSET は、入力式 target_arg を受け取り、その式内のビット数をカウントしま
す。カウントされるビットは、target_value_arg の値に応じて、1 に設定されるか、
0 に設定されます。
target_value_arg パラメータは、0 または 1 の値のみを受け入れます。
target_value_arg の値が指定されていないと、デフォルトの値 1 が使用され、
COUNTSET は、1 に設定されているビット値をカウントします。
いずれかの入力引数が NULL の場合、この関数は NULL を返します。
引数のタイプと規則
COUNTSET は、オーバーロード スカラー関数です。この関数は、以下に示す入力
パラメータのデータ型の組み合わせ(target_arg [,target_value_arg])に応じて定義さ
れます。
target_arg 型
target_value_arg 型(任意選択)
BYTEINT
INTEGER
SMALLINT
INTEGER
INTEGER
INTEGER
BIGINT
INTEGER
VARBYTE(n)
INTEGER
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
この関数に渡す式は、上記に明示したデータ タイプと一致するか、UDF に適用され
る暗黙のデータ タイプ変換規則を使用して、上記のタイプに変換できる必要があり
ます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って上記に明示したデー
タ タイプのいずれかに変換できない引数がある場合は、その引数を明示的にキャス
トする必要があります。
いずれかの引数が、上記に明示したデータ タイプに変換できない場合は、実行依頼
された DML UDF 式と一致する関数が存在しないことを示すエラーが返されます。
結果のタイプと属性
結果のデータ タイプは INTEGER です。
結果の書式は INTEGER のデフォルト書式です。
COUNTSET のデフォルト タイトルは、COUNTSET(target_arg [, target_value_arg])
です。
SQL 関数、演算子、式および述部
277
第 6 章 ビット/バイト操作関数
GETBIT
例: COUNTSET 関数での問合わせ
次の問合わせでは、入力引数 23 を受け取ります。この値のデータ型は BYTEINT で
あり、バイナリ表現は 00010111 になります。target_value_arg が指定されていな
いため、デフォルトの値 1 が使用されます。そのため、この関数は、1 に設定され
ているビット値の数をカウントすることになります。 問合わせの結果は、INTEGER
値の 4 になります。
SELECT COUNTSET(23);
関連トピック
詳細は、以下を参照してください。
• オーバーロード関数の詳細については、<SQL 外部ルーチン プログラミング、
B035-1147>の「関数名のオーバーロード」を参照してください。
• デフォルトのデータ タイプ書式については、< SQL データ型とリテラル、
B035-1143>を参照してください。
GETBIT
目的
target_arg バイト式から、target_bit_arg で指定したビットの値を返します。
構文
GETBIT
( target_arg, target_bit_arg )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
target_arg
数値または可変長バイト式。
target_bit_arg
INTEGER 式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
278
SQL 関数、演算子、式および述部
第 6 章 ビット/バイト操作関数
GETBIT
説明
GETBIT は、target_bit_arg で指定したビットを、target_arg バイト式から取得し、
そのビットの値を示す 0 または 1 を返します。
target_bit_arg の入力値の範囲は、0 (ビット 0 が最下位ビット)から、
(sizeof(target_arg) - 1)まで許容されます。
target_bit_arg が負であるか、範囲外である(つまり、target_arg のサイズを超過し
ている)場合は、エラーが返されます。
どちらかの入力引数が NULL の場合、この関数は NULL を返します。
引数のタイプと規則
GETBIT は、オーバーロード スカラー関数です。この関数は、以下に示す入力パラ
メータのデータ型の組み合わせ(target_arg, target_bit_arg)に応じて定義されます。
target_arg 型
target_bit_arg 型
BYTEINT
INTEGER
SMALLINT
INTEGER
INTEGER
INTEGER
BIGINT
INTEGER
VARBYTE(n)
INTEGER
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
この関数に渡す式は、上記に明示したデータ タイプと一致するか、UDF に適用され
る暗黙のデータ タイプ変換規則を使用して、上記のタイプに変換できる必要があり
ます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って上記に明示したデー
タ タイプのいずれかに変換できない引数がある場合は、その引数を明示的にキャス
トする必要があります。
いずれかの引数が、上記に明示したデータ タイプに変換できない場合は、実行依頼
された DML UDF 式と一致する関数が存在しないことを示すエラーが返されます。
結果のタイプと属性
GETBIT は、0 か 1 の BYTEINT 値を返します。この値は、target_arg バイト式の
target_bit_arg の位置にあるビットの値を反映します。
結果の書式は BYTEINT のデフォルト書式です。
GETBIT のデフォルト タイトルは、GETBIT( target_arg, target_bit_arg)です。
SQL 関数、演算子、式および述部
279
第 6 章 ビット/バイト操作関数
ROTATELEFT
例: GETBIT 関数での問合わせ
次の問合わせでは、入力引数 23 の 3 番目のビットの値を取得します。この入力引
数のデータ タイプは BYTEINT であり、バイナリ表現は 00010111 になります。問
合わせの結果は BYTEINT 値の 1、またはバイナリの 00000001 になります。
SELECT GETBIT(23,2);
関連トピック
詳細は、以下を参照してください。
• オーバーロード関数の詳細については、<SQL 外部ルーチン プログラミング、
B035-1147>の「関数名のオーバーロード」を参照してください。
• デフォルトのデータ タイプ書式については、< SQL データ型とリテラル、
B035-1143>を参照してください。
ROTATELEFT
目的
num_bits_arg で指定したビット数だけ右方向に回転させた target_arg 式を返しま
す。最上位ビットは左方向に回り込みます。
構文
ROTATELEFT
( target_arg, num_bits_arg )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
target_arg
数値または可変長バイト式。
num_bits_arg
回転させるビット位置の数を示す INTEGER 式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
280
SQL 関数、演算子、式および述部
第 6 章 ビット/バイト操作関数
ROTATELEFT
説明
IF...
関数の動作
num_bits_arg が 0 と等しい場合 未変更の target_arg が返されます。
num_bits_arg が負の場合
ビットが、左ではなく右方向に回転されます。
target_arg および(また
NULL を返します。
は)num_bits_arg が NULL の場合
num_bits_arg が target_arg のサ (num_bits_arg MOD sizeof(target_arg))の数だけビットが
イズより大きい場合
回転されます。
回転操作の適用範囲は、target_arg 式のサイズに制限さ
れます。
注: 整数型の値(BYTEINT、SMALLINT、INTEGER または BIGINT)に対する操作では、
最上位にビットを回転させると、その整数は結果的に負になります。これは、
Teradata Database の INTEGER 型は、すべて符号付き整数だからです。
引数のタイプと規則
ROTATELEFT はオーバーロード スカラー関数です。この関数は、以下に示す入力パ
ラメータのデータ型の組み合わせ(target_arg, num_bits_arg)に応じて定義されます。
target_arg 型
num_bits_arg 型
BYTEINT
INTEGER
SMALLINT
INTEGER
INTEGER
INTEGER
BIGINT
INTEGER
VARBYTE(n)
INTEGER
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
この関数に渡す式は、上記に明示したデータ タイプと一致するか、UDF に適用され
る暗黙のデータ タイプ変換規則を使用して、上記のタイプに変換できる必要があり
ます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って上記に明示したデー
タ タイプのいずれかに変換できない引数がある場合は、その引数を明示的にキャス
トする必要があります。
いずれかの引数が、上記に明示したデータ タイプに変換できない場合は、実行依頼
された DML UDF 式と一致する関数が存在しないことを示すエラーが返されます。
SQL 関数、演算子、式および述部
281
第 6 章 ビット/バイト操作関数
ROTATELEFT
結果のタイプと属性
結果のデータ型は、次の表に示すように、この関数に渡した入力引数 target_arg の
データ型によって異なります。
target_arg のデータ型
結果のタイプ
デフォルト書式となる結果の書式
BYTEINT
BYTEINT
BYTEINT
SMALLINT
SMALLINT
SMALLINT
INTEGER
INTEGER
INTEGER
BIGINT
BIGINT
BIGINT
VARBYTE(n)
VARBYTE(n)
VARBYTE(n)
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
ROTATELEFT のデフォルト タイトルは、ROTATELEFT(target_arg, num_bits_arg)で
す。
例
例: ROTATELEFT 関数で入力引数 16 を問合わせる
次の問合わせの入力引数 16 は、データ タイプが BYTEINT であり、バイナリ表現は
00010000 になります。この値が、左方向に 2 ビット回転されると、結果のバイナ
リは 01000000 になります。この値を、BYTEINT 値に変換すると 64 になります。
問合わせは、この値を返します。
SELECT ROTATELEFT(16,2);
例: ROTATELEFT 関数で入力引数 64 を問合わせる
次の問合わせの入力引数 64 は、データ タイプが BYTEINT であり、バイナリ表現は
01000000 になります。この値が、左方向に 3 ビット回転されると、結果のバイナ
リは 00000010 になります。この値を、BYTEINT 値に変換すると 2 になります。
問合わせは、この値を返します。
SELECT ROTATELEFT(64,3);
関連トピック
詳細は、以下を参照してください。
• オーバーロード関数の詳細については、<SQL 外部ルーチン プログラミング、
B035-1147>の「関数名のオーバーロード」を参照してください。
• UDF の暗黙のタイプ変換規則の詳細については、<SQL 外部ルーチン プログラミ
ング、B035-1147>の「互換データ型」と「オーバーロード関数のパラメータ型」
を参照してください。
282
SQL 関数、演算子、式および述部
第 6 章 ビット/バイト操作関数
ROTATERIGHT
ROTATERIGHT
目的
num_bits_arg で指定したビット数だけ右方向に回転させた target_arg 式を返しま
す。最下位ビットは左方向に回り込みます。
構文
ROTATERIGHT
( target_arg, num_bits_arg )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
target_arg
数値または可変長バイト式。
num_bits_arg
回転させるビット位置の数を示す INTEGER 式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
説明
IF...
関数の動作
num_bits_arg が 0 と等しい場合 未変更の target_arg が返されます。
num_bits_arg が負の場合
ビットが、右ではなく左方向に回転されます。
target_arg および(また
NULL を返します。
は)num_bits_arg が NULL の場合
num_bits_arg is larger than the
size of target_arg
(num_bits_arg MOD sizeof(target_arg))の数だけビットが
回転されます。
回転操作の適用範囲は、target_arg 式のサイズに制限さ
れます。
注: 整数型の値(BYTEINT、SMALLINT、INTEGER または BIGINT)に対する操作では、
最上位にビットを回転させると、その整数は結果的に負になります。これは、
Teradata Database の INTEGER 型は、すべて符号付き整数だからです。
SQL 関数、演算子、式および述部
283
第 6 章 ビット/バイト操作関数
ROTATERIGHT
引数のタイプと規則
ROTATERIGHT はオーバーロード スカラー関数です。この関数は、以下に示す入力
パラメータのデータ型の組み合わせ(target_arg, num_bits_arg)に応じて定義されます。
target_arg 型
num_bits_arg 型
BYTEINT
INTEGER
SMALLINT
INTEGER
INTEGER
INTEGER
BIGINT
INTEGER
VARBYTE(n)
INTEGER
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
この関数に渡す式は、上記に明示したデータ タイプと一致するか、UDF に適用され
る暗黙のデータ タイプ変換規則を使用して、上記のタイプに変換できる必要があり
ます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って上記に明示したデー
タ タイプのいずれかに変換できない引数がある場合は、その引数を明示的にキャス
トする必要があります。
いずれかの引数が、上記に明示したデータ タイプに変換できない場合は、実行依頼
された DML UDF 式と一致する関数が存在しないことを示すエラーが返されます。
結果のタイプと属性
結果のデータ型は、次の表に示すように、この関数に渡した入力引数 target_arg の
データ型によって異なります。
target_arg のデータ型
結果のタイプ
デフォルト書式となる結果の書式
BYTEINT
BYTEINT
BYTEINT
SMALLINT
SMALLINT
SMALLINT
INTEGER
INTEGER
INTEGER
BIGINT
BIGINT
BIGINT
VARBYTE(n)
VARBYTE(n)
VARBYTE(n)
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
ROTATERIGHT のデフォルト タイトルは、ROTATERIGHT(target_arg, num_bits_arg)
です。
284
SQL 関数、演算子、式および述部
第 6 章 ビット/バイト操作関数
SETBIT
デフォルトのデータ タイプ書式については、< SQL データ型とリテラル、
B035-1143>を参照してください。
例
例: ROTATERIGHT 関数で入力引数 32 を問合わせる
次の問合わせの入力引数 32 は、データ タイプが BYTEINT であり、バイナリ表現
は 00100000 になります。この値が、右方向に 2 ビット回転されると、結果のバイ
ナリは 00001000 になります。この値を、BYTEINT 値に変換すると 8 になります。
問合わせは、この値を返します。
SELECT ROTATERIGHT(32,2);
例: ROTATERIGHT 関数で入力引数 4 を問合わせる
次の問合わせの入力引数 4 は、データ タイプが BYTEINT であり、バイナリ表現は
00000100 になります。 この値が、右方向に 4 ビット回転されると、結果のバイ
ナリは 01000000 になります。この値を、BYTEINT 値に変換すると 64 になりま
す。問合わせは、この値を返します。
SELECT ROTATERIGHT(4,4);
関連トピック
詳細は、以下を参照してください。
• オーバーロード関数の詳細については、<SQL 外部ルーチン プログラミング、
B035-1147>の「関数名のオーバーロード」を参照してください。
• SQL データ型とリテラル、B035-1143。
• UDF の暗黙のタイプ変換規則の詳細については、<SQL 外部ルーチン プログラミ
ング、B035-1147>の「互換データ型」と「オーバーロード関数のパラメータ型」
を参照してください。
SETBIT
目的
target_bit_arg で指定したビットの値を、target_arg バイト式内の target_value_arg
の値に設定します。
構文
SETBIT
TD_SYSFNLIB.
SQL 関数、演算子、式および述部
( target_arg, target_bit_arg
)
, target_value_arg
285
第 6 章 ビット/バイト操作関数
SETBIT
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
target_arg
数値または可変長バイト式。
target_bit_arg
INTEGER 式。
target_value_arg
整数値。許容される値は 0 または 1 のみです。target_value_arg が指定されていな
い場合、デフォルトは 1 になります。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
説明
SETBIT は、入力の target_arg を受け取り、target_bit_arg で指定したビットの値を、
target_value_arg 引数の内容に応じて 0 または 1 に設定します。
target_value_arg パラメータは、0 または 1 の値のみを受け入れます。
target_value_arg の値を指定しないと、デフォルト値の 1 が使用されます。
target_bit_arg の入力値の範囲は、0 (ビット 0 が最下位ビット)から、
(sizeof(target_arg) - 1)まで許容されます。
target_bit_arg が負であるか、範囲外である(つまり、target_arg のサイズを超過して
いる)場合は、エラーが返されます。
いずれかの入力引数が NULL の場合、この関数は NULL を返します。
引数のタイプと規則
SETBIT は、オーバーロード スカラー関数です。この関数は、以下に示す入力パラ
メータのデータ型の組み合わせ(target_arg, target_bit_arg [,target_value_arg])に応じ
て定義されます。
286
target_arg 型
target_bit_arg 型
target_value_arg 型(任意選択)
BYTEINT
INTEGER
INTEGER
SMALLINT
INTEGER
INTEGER
SQL 関数、演算子、式および述部
第 6 章 ビット/バイト操作関数
SETBIT
target_arg 型
target_bit_arg 型
target_value_arg 型(任意選択)
INTEGER
INTEGER
INTEGER
BIGINT
INTEGER
INTEGER
VARBYTE(n)
INTEGER
INTEGER
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
この関数に渡す式は、上記に明示したデータ タイプと一致するか、UDF に適用され
る暗黙のデータ タイプ変換規則を使用して、上記のタイプに変換できる必要があり
ます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って上記に明示したデー
タ タイプのいずれかに変換できない引数がある場合は、その引数を明示的にキャス
トする必要があります。
いずれかの引数が、上記に明示したデータ タイプに変換できない場合は、実行依頼
された DML UDF 式と一致する関数が存在しないことを示すエラーが返されます。
結果のタイプと属性
結果のデータ型は、次の表に示すように、この関数に渡した入力引数 target_arg の
データ型によって異なります。
target_arg のデータ型
結果のタイプ
デフォルト書式となる結果の書式
BYTEINT
BYTEINT
BYTEINT
SMALLINT
SMALLINT
SMALLINT
INTEGER
INTEGER
INTEGER
BIGINT
BIGINT
BIGINT
VARBYTE(n )
VARBYTE(n )
VARBYTE(n )
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
SETBIT のデフォルト タイトルは、SETBIT( target_arg,
target_bit_arg[,target_value_arg ])です。
例
例: SETBIT 関数での問合わせ
次の問合わせでは、入力引数 23 を受け取ります。この入力引数のデータ タイプは
BYTEINT であり、バイナリ表現は 00010111 になります。その後で、3 番目のビッ
トの値を 1 に設定します。問合わせの結果は BYTEINT 値の 23 になり、バイナリで
は 00010111 になります。
SQL 関数、演算子、式および述部
287
第 6 章 ビット/バイト操作関数
SHIFTLEFT
SELECT SETBIT(23,2);
例: ROTATERIGHT 関数で入力引数 23 を問合わせる
次の問合わせでは、入力引数 23 を受け取ります。この入力引数のデータ タイプは
BYTEINT であり、バイナリ表現は 00010111 になります。その後で、3 番目のビッ
トの値を 0 に設定します。問合わせの結果は BYTEINT 値の 19 になり、バイナリで
は 00010011 になります。
SELECT SETBIT(23,2,0);
関連トピック
詳細は、以下を参照してください。
• オーバーロード関数の詳細については、<SQL 外部ルーチン プログラミング、
B035-1147>の「関数名のオーバーロード」を参照してください。
• SQL データ型とリテラル、B035-1143。
• UDF の暗黙のタイプ変換規則の詳細については、<SQL 外部ルーチン プログラミ
ング、B035-1147>の「互換データ型」と「オーバーロード関数のパラメータ型」
を参照してください。
SHIFTLEFT
目的
指定したビット数(num_bits_arg)だけ左方向に桁送りされた、target_arg 式が返され
ます。最上位のビットは失われ、最下位のビットに 0 が補填されます。
構文
SHIFTRIGHT
( target_arg, num_bits_arg )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
target_arg
数値または可変長バイト式。
num_bits_arg
桁送りするビット位置の数を示す INTEGER 式。
288
SQL 関数、演算子、式および述部
第 6 章 ビット/バイト操作関数
SHIFTLEFT
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
説明
IF...
関数の動作
num_bits_arg が 0 と等しい場合 未変更の target_arg が返されます。
num_bits_arg が負の場合
ビットが、左ではなく右方向に桁送りされます。
target_arg および(また
NULL を返します。
は)num_bits_arg が NULL の場合
num_bits_arg is larger than the
size of target_arg
エラーが返されます。
桁送り操作の適用範囲は、target_arg 式のサイズに制限
されます。target_arg の範囲を超える桁送りを指定する
と、SQL エラーが発生します。
注: 整数型の値(BYTEINT、SMALLINT、INTEGER または BIGINT)に対する操作では、
最上位にビットを桁送りすると、その整数は結果的に負になります。これは、
Teradata Database の INTEGER 型は、すべて符号付き整数だからです。
引数のタイプと規則
SHIFTLEFT はオーバーロード スカラー関数です。この関数は、以下に示す入力パラ
メータのデータ型の組み合わせ(target_arg, num_bits_arg)に応じて定義されます。
target_arg 型
num_bits_arg 型
BYTEINT
INTEGER
SMALLINT
INTEGER
INTEGER
INTEGER
BIGINT
INTEGER
VARBYTE(n)
INTEGER
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
この関数に渡す式は、上記に明示したデータ タイプと一致するか、UDF に適用され
る暗黙のデータ タイプ変換規則を使用して、上記のタイプに変換できる必要があり
ます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って上記に明示したデー
タ タイプのいずれかに変換できない引数がある場合は、その引数を明示的にキャス
トする必要があります。
SQL 関数、演算子、式および述部
289
第 6 章 ビット/バイト操作関数
SHIFTLEFT
いずれかの引数が、上記に明示したデータ タイプに変換できない場合は、実行依頼
された DML UDF 式と一致する関数が存在しないことを示すエラーが返されます。
結果のタイプと属性
結果のデータ型は、次の表に示すように、この関数に渡した入力引数 target_arg の
データ型によって異なります。
target_arg のデータ型
結果のタイプ
デフォルト書式となる結果の書式
BYTEINT
BYTEINT
BYTEINT
SMALLINT
SMALLINT
SMALLINT
INTEGER
INTEGER
INTEGER
BIGINT
BIGINT
BIGINT
VARBYTE(n)
VARBYTE(n)
VARBYTE(n)
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
SHIFTLEFT のデフォルト タイトルは、SHIFTLEFT(target_arg, num_bits_arg)です。
例: SHIFTLEFT 関数での問合わせ
次の問合わせの入力引数 3 は、データ タイプが BYTEINT であり、バイナリ表現は
00000011 になります。 この値が、左方向に 2 ビット桁送りされると、結果のバイ
ナリは 00001100 になります。この値を、BYTEINT 値に変換すると 12 になりま
す。問合わせは、この値を返します。
SELECT SHIFTLEFT(3,2);
関連トピック
詳細は、以下を参照してください。
• オーバーロード関数の詳細については、<SQL 外部ルーチン プログラミング、
B035-1147>の「関数名のオーバーロード」を参照してください。
• UDF の暗黙のタイプ変換規則の詳細については、<SQL 外部ルーチン プログラミ
ング、B035-1147>の「互換データ型」と「オーバーロード関数のパラメータ型」
を参照してください。
290
SQL 関数、演算子、式および述部
第 6 章 ビット/バイト操作関数
SHIFTRIGHT
SHIFTRIGHT
目的
指定したビット数(num_bits_arg)だけ右方向に桁送りされた、target_arg 式が返さ
れます。最下位のビットは失われ、最上位のビットに 0 が補填されます。
構文
SHIFTRIGHT
( target_arg, num_bits_arg )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
target_arg
数値または可変長バイト式。
num_bits_arg
桁送りするビット位置の数を示す INTEGER 式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
説明
IF...
関数の動作
num_bits_arg が 0 と等しい場合 未変更の target_arg が返されます。
num_bits_arg が負の場合
ビットが、右ではなく左方向に桁送りされます。
target_arg および(また
NULL を返します。
は)num_bits_arg が NULL の場合
num_bits_arg is larger than the
size of target_arg
エラーが返されます。
桁送り操作の適用範囲は、target_arg 式のサイズに制限
されます。target_arg の範囲を超える桁送りを指定する
と、SQL エラーが発生します。
注: 整数型の値(BYTEINT、SMALLINT、INTEGER または BIGINT)に対する操作では、
最上位のビットを送り出すと、その整数は結果的に負になります。これは、Teradata
Database の INTEGER 型は、すべて符号付き整数だからです。
SQL 関数、演算子、式および述部
291
第 6 章 ビット/バイト操作関数
SHIFTRIGHT
引数のタイプと規則
SHIFTRIGHT はオーバーロード スカラー関数です。この関数は、以下に示す入力パ
ラメータのデータ型の組み合わせ(target_arg, num_bits_arg)に応じて定義されます。
target_arg 型
num_bits_arg 型
BYTEINT
INTEGER
SMALLINT
INTEGER
INTEGER
INTEGER
BIGINT
INTEGER
VARBYTE(n)
INTEGER
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
この関数に渡す式は、上記に明示したデータ タイプと一致するか、UDF に適用され
る暗黙のデータ タイプ変換規則を使用して、上記のタイプに変換できる必要があり
ます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って上記に明示したデー
タ タイプのいずれかに変換できない引数がある場合は、その引数を明示的にキャス
トする必要があります。
いずれかの引数が、上記に明示したデータ タイプに変換できない場合は、実行依頼
された DML UDF 式と一致する関数が存在しないことを示すエラーが返されます。
結果のタイプと属性
結果のデータ型は、次の表に示すように、この関数に渡した入力引数 target_arg の
データ型によって異なります。
target_arg のデータ型
結果のタイプ
デフォルト書式となる結果の書式
BYTEINT
BYTEINT
BYTEINT
SMALLINT
SMALLINT
SMALLINT
INTEGER
INTEGER
INTEGER
BIGINT
BIGINT
BIGINT
VARBYTE(n)
VARBYTE(n)
VARBYTE(n)
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
SHIFTRIGHT のデフォルト タイトルは、SHIFTRIGHT(target_arg, num_bits_arg)です。
292
SQL 関数、演算子、式および述部
第 6 章 ビット/バイト操作関数
SUBBITSTR
例: SHIFTRIGHT 関数での問合わせ
次の問合わせの入力引数 3 は、データ タイプが BYTEINT であり、バイナリ表現は
00000011 になります。この値が、右方向に 2 ビット桁送りされると、結果のバイ
ナリは 00000000 になります。この値を、BYTEINT 値に変換すると 0 になります。
問合わせは、この値を返します。
SELECT SHIFTRIGHT(3,2);
関連トピック
詳細は、以下を参照してください。
• オーバーロード関数の詳細については、<SQL 外部ルーチン プログラミング、
B035-1147>の「関数名のオーバーロード」を参照してください。
• SQL データ型とリテラル、B035-1143。
• UDF の暗黙のタイプ変換規則の詳細については、<SQL 外部ルーチン プログラミ
ング、B035-1147>の「互換データ型」と「オーバーロード関数のパラメータ型」
を参照してください。
SUBBITSTR
目的
target_arg 入力式から、指定したビット位置に基づいて、サブビット列を抽出します。
構文
SUBBITSTR
( target_arg, position_arg, num_bits_arg )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
target_arg
数値または可変長バイト式。
position_arg
抽出するサブビット列の開始位置を示す INTEGER 式。
SQL 関数、演算子、式および述部
293
第 6 章 ビット/バイト操作関数
SUBBITSTR
num_bits_arg
抽出するサブビット列の長さを示す INTEGER 式。これにより、関数が返すビット数
を指定します。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
説明
SUBBITSTR は、target_arg 文字列式から、position_arg で指定したビット位置以降
のサブビット列を抽出します。データ型ごとのビット位置の範囲については、「ビッ
トおよびバイトの番号付けモデル」を参照してください。
抽出するサブビット列の長さを num_bits_arg の値で指定し、この関数が返すべき
ビット数を示します。この関数から返される値は VARBYTE 列なので、返されるビッ
ト数は、要求したビット数より大きなバイト境界に丸められることがあります。
返されるビットは右寄せにされ、余剰なビット(要求したビット数を超えた分)には 0
が補填されます。
position_arg が負であるか、範囲外である(つまり、target_arg のサイズを超過して
いる)場合は、エラーが返されます。
num_bits_arg が負の場合や、開始位置の position_arg を計算に入れると残りのビッ
ト数を超えてしまう場合は、エラーが返されます。
いずれかの入力引数が NULL の場合、この関数は NULL を返します。
引数のタイプと規則
SUBBITSTR はオーバーロード スカラー関数です。この関数は、以下に示す入力パラ
メータのデータ型の組み合わせ(target_arg, position_arg, num_bits_arg)に応じて定
義されます。
target_arg 型
position_arg 型
num_bits_arg 型
BYTEINT
INTEGER
INTEGER
SMALLINT
INTEGER
INTEGER
INTEGER
INTEGER
INTEGER
BIGINT
INTEGER
INTEGER
VARBYTE(n)
INTEGER
INTEGER
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
294
SQL 関数、演算子、式および述部
第 6 章 ビット/バイト操作関数
SUBBITSTR
この関数に渡す式は、上記に明示したデータ タイプと一致するか、UDF に適用され
る暗黙のデータ タイプ変換規則を使用して、上記のタイプに変換できる必要があり
ます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って上記に明示したデー
タ タイプのいずれかに変換できない引数がある場合は、その引数を明示的にキャス
トする必要があります。
いずれかの引数が、上記に明示したデータ タイプに変換できない場合は、実行依頼
された DML UDF 式と一致する関数が存在しないことを示すエラーが返されます。
結果のタイプと属性
結果のデータ タイプは VARBYTE 列です。VARBYTE 列のサイズ(バイト数)は、
target_arg 入力引数のデータ型と、要求したビット数に応じて変化します。
以下に例を示します。
target_arg のデータ型
結果のタイプ
デフォルト書式となる結果の書式
BYTEINT
VARBYTE(1)
VARBYTE(1)
SMALLINT
VARBYTE(2)
VARBYTE(2)
INTEGER
VARBYTE(4)
VARBYTE(4)
BIGINT
VARBYTE(8)
VARBYTE(8)
VARBYTE(n)
VARBYTE(m)
VARBYTE(m)
この m は、要求された
ビット数が収まる最小の
バイト数になります。
VARBYTE の(n)に対する最大対応サイズは、8192 バイトです。
SUBBITSTR のデフォルト タイトルは、SUBBITSTR(target_arg, position_arg,
num_bits_arg)です。
例: SUBBITSTR 関数での問合わせ
次の問合わせでは、入力引数 20 を受け取ります。この入力引数のデータ タイプは
BYTEINT であり、バイナリ表現は 00010100 になります。その後で、3 番目のビッ
トから始まる 3 ビットを返すように要求します。返される 3 ビットの 101 は、0 で
充填されたバイト内に右寄せで配置されます。問合わせの結果は、値 5 になり、バ
イナリでは 00000101 になります。結果のデータ タイプは、VARBYTE(1)になりま
す。
SELECT SUBBITSTR(20,2,3);
SQL 関数、演算子、式および述部
295
第 6 章 ビット/バイト操作関数
TO_BYTE
関連トピック
詳細は、以下を参照してください。
• オーバーロード関数の詳細については、<SQL 外部ルーチン プログラミング、
B035-1147>の「関数名のオーバーロード」を参照してください。
• UDF の暗黙のタイプ変換規則の詳細については、<SQL 外部ルーチン プログラミ
ング、B035-1147>の「互換データ型」と「オーバーロード関数のパラメータ型」
を参照してください。
TO_BYTE
目的
入力値(数値)のデータ型を Teradata Database サーバーのバイト表現(バイト値)に変
換します。
構文
TO_BYTE
( target_arg )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
target_arg
変換される数値式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
説明
この関数が返すバイト数は、target_arg 値のデータ型によって変化します。
target_arg が NULL の場合、この関数は NULL を返します。
引数のタイプと規則
TO_BYTE はオーバーロード スカラー関数です。この関数は以下に示すパラメータの
データ タイプで定義されます。
296
SQL 関数、演算子、式および述部
第 6 章 ビット/バイト操作関数
TO_BYTE
•
•
•
•
BYTEINT
SMALLINT
INTEGER
BIGINT
この関数に渡す式は、上記に明示したデータ タイプと一致するか、UDF に適用され
る暗黙のデータ タイプ変換規則を使用して、上記のタイプに変換できる必要があり
ます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って上記に明示したデー
タ タイプのいずれかに変換できない引数は、明示的にキャストする必要があります。
上記に明示したデータ タイプのいずれかに引数が変換できない場合は、実行依頼さ
れた DML UDF 式と一致する関数が存在しないことを示すエラーが返されます。
結果のタイプと属性
結果のデータ タイプは、BYTE 値になります(固定バイト データ タイプ)。返される
バイト列のサイズは、次の表に示すように、target_arg 入力引数によって多様に変
化します。
target_arg のデータ型
結果のタイプ
デフォルト書式となる結果の書式
BYTEINT
BYTE(1)
BYTE(1)
SMALLINT
BYTE(2)
BYTE(2)
INTEGER
BYTE(4)
BYTE(4)
BIGINT
BYTE(8)
BYTE(8)
TO_BYTE のデフォルト タイトルは、TO_BYTE(target_arg))です。
例: TO_BYTE 関数での問合わせ
次の問合わせの入力引数 23 は、データ タイプが BYTEINT であり、バイナリ表現
は 00010111 になります。この値に対して TO_BYTE 演算を実行すると、結果とし
て値 00010111 が BYTE(17)のデータ タイプで返されます。
SELECT TO_BYTE(23);
関連トピック
詳細は、以下を参照してください。
• 整数値のサーバー表現については、 SQL データ型とリテラル、B035-1143 を参
照してください。
SQL 関数、演算子、式および述部
297
第 6 章 ビット/バイト操作関数
TO_BYTE
• オーバーロード関数の詳細については、<SQL 外部ルーチン プログラミング、
B035-1147>の「関数名のオーバーロード」を参照してください。
• UDF の暗黙のタイプ変換規則の詳細については、<SQL 外部ルーチン プログラミ
ング、B035-1147>の「互換データ型」と「オーバーロード関数のパラメータ型」
を参照してください。
298
SQL 関数、演算子、式および述部
第7章
組み込み関数
概要
ニラディック(引数を持たない)であるビルトイン関数は、システムに関するさまざ
まな情報を返します。組み込み関数は、特殊レジスターと呼ばれることもあります。
組み込み関数は、リテラルを使用できる場所であれば、どこでも使用できます。
組み込み関数を含んだ SELECT 文がテーブル名を参照する場合、問合わせの結果に
は、検索条件にかなったテーブルの各行ごとに 1 つの行が含まれます。
ACCOUNT
目的
現在のユーザーのアカウント文字列を戻します。
構文
ACCOUNT
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果のタイプと属性
ACCOUNT のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ
書式
タイトル
VARCHAR(30) CHARACTER SET UNICODE
X(30)
Account
SQL 関数、演算子、式および述部
299
第 7 章 組み込み関数
CURRENT_DATE
使用上の注意
SET SESSION ACCOUNT 文によって現在のアカウント文字列が変更されている場合
は、ACCOUNT 関数によって、要求レベルに基づく新しいアカウント文字列が戻さ
れます。つまり、セッション全体か、個別要求か、というレベルです。
例: ユーザーのアカウント文字列の要求
次の文は、現在のユーザーのアカウント文字列を要求します。
SELECT ACCOUNT;
システム応答は 、以下のようになります。
Account
-----------------------------$M_D2102
CURRENT_DATE
目的
現在日付を戻します。
構文
CURRENT_DATE
AT
LOCAL
expression
TIME ZONE
time_zone_string
構文要素
AT LOCAL
DBS 制御フラグ TimeDateWZControl が有効な場合は、セッションの時間とセッショ
ンのタイムゾーンを基にして構築された値が返されます。
TimeDateWZControl が無効な場合は、Teradata Database サーバー ローカルの時間
値とセッションのタイムゾーンを基にして構成された値が返されます。
AT [TIME ZONE] expression
式で定義されたタイムゾーンの変位を使用します。
expression のデータ タイプは INTERVAL HOUR(2) TO MINUTE か、暗黙的に
INTERVAL HOUR(2) TO MINUTE に変換できるデータ タイプでなければなりません。
300
SQL 関数、演算子、式および述部
第 7 章 組み込み関数
CURRENT_DATE
AT [TIME ZONE] time_zone_string
time_zone_string は、タイムゾーン変位を決定します。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠していますが、非 ANSI の Teradata Database 拡
張機能が含まれています。
使用上の注意
CURRENT_DATE は、要求が開始された時点での日付を返します。要求が終了する
までに、CURRENT_DATE が複数回呼び出された場合でも、同じ日付が返されます。
返される日付が、要求の継続中に変更されることはありません。
AT 句なしで CURRENT_DATE を指定した場合や、CURRENT_DATE AT LOCAL を指
定した場合、返される値は、DBS 制御フラグ TimeDateWZControl の設定に応じて、
次に示すように変化します。
• TimeDateWZControl フラグが有効な場合、CURRENT_DATE は、セッションの時
間とセッションのタイムゾーンを基にして構築された日付を返します。
• TimeDateWZControl フラグが無効な場合、CURRENT_DATE は、Teradata
Database サーバーのローカルな時間値と、セッションのタイムゾーンを基にし
て構築された日付を返します。
詳細は、<ユーティリティ 、B035-1102>の「DBS 制御(dbscontrol)」を参照してく
ださい。
CURRENT_DATE は、夏時間(DST)の開始と終了を考慮に入れて調整された値を返し
ます。ただし、この調整が実行されるのは、次の場合に限られます。
• CURRENT_DATE が AT [TIME ZONE] time_zone_string とともに指定されていて、
time_zone_string が、個別の DST と標準タイムゾーン変位に対応している。
• CURRENT_DATE が AT LOCAL とともに指定されているか、AT 句なしで指定され
ていて、セッションのタイムゾーンが、個別の DST と標準のタイムゾーン変位
に対応しているタイムゾーン文字列で定義されている。
結果のタイプと属性
CURRENT_DATE の、結果のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ 書式
タイトル
DATE
DATE
SQL 関数、演算子、式および述部
DATE データ タイプのデフォルト書式(Dateform モードが
IntegerDate に設定されている場合)。
301
第 7 章 組み込み関数
CURRENT_DATE
データ タイプ 書式
タイトル
デフォルト書式の詳細については、< SQL データ型とリテ
ラル、B035-1143>の「データ タイプの書式および書式句」
を参照してください。
CURRENT_DATE を変換するには、Teradata の明示変換構文または ANSI CAST 構文
を使用します。
CURRENT_DATE と DATE
CURRENT_DATE は、Teradata 関数である DATE と同様の機能を持っており、ANSI
準拠の構文を使用します。Teradata の DATE 関数の詳細については、「DATE」を参
照してください。
例
例: INTERVAL -'08:00' HOUR TO MINUTE の現在の日付を返す
この例では、DATE 値のデフォルト フォーマットが'yy/mm/dd'だと仮定しています。
次の文を考えます。
SET TIME ZONE INTERVAL
SELECT CURRENT_DATE AT
SELECT CURRENT_DATE AT
SELECT CURRENT_DATE AT
SELECT CURRENT_DATE AT
SELECT CURRENT_DATE AT
SELECT CURRENT_DATE AT
SELECT CURRENT_DATE AT
SELECT CURRENT_DATE AT
SELECT CURRENT_DATE AT
SELECT CURRENT_DATE AT
SELECT CURRENT_DATE AT
'01:00' HOUR TO MINUTE;
TIME ZONE INTERVAL -'08:00' HOUR TO MINUTE;
INTERVAL -'08:00' HOUR TO MINUTE;
TIME ZONE INTERVAL -'08' HOUR;
INTERVAL -'08' HOUR;
TIME ZONE '-08:00';
'-08:00';
TIME ZONE '-8';
'-8';
TIME ZONE -8;
-8;
-8.0;
上記の SELECT 文は、タイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE を基
にして現在の日付を返します。現在のタイムスタンプが TIMESTAMP '2008-06-01
06:30:00.000000+00:00' (UTC)だとすると、上記の SELECT 文は日付として
'08/05/31'を返します。
SELECT 文が AT 句なしで指定されるか、AT LOCAL 句とともに指定されていて、DBS
制御フラグ TimeDateWZControl が有効な場合、この文は現在の日付として
'08/06/01'を返します。この日付は、現行セッションの時間とタイムゾーン変位
INTERVAL '01:00' HOUR TO MINUTE に基づいています。たとえば、
SELECT CURRENT_DATE;
SELECT CURRENT_DATE AT LOCAL;
302
SQL 関数、演算子、式および述部
第 7 章 組み込み関数
CURRENT_DATE
返される日付には、夏時間の開始や終了を考慮した調整が行なわれません。
例: INTERVAL -'09:00' HOUR TO MINUTE の現在の日付を返す
この例では、DATE 値のデフォルト フォーマットが'yy/mm/dd'だと仮定していま
す。次の文を考えます。
SET TIME ZONE INTERVAL '01:00' HOUR TO MINUTE;
SELECT CURRENT_DATE AT INTERVAL '09:00' HOUR TO MINUTE;
上記の SELECT 文は、タイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE を基
にして現在の日付を返します。現在のタイムスタンプが TIMESTAMP '2008-06-01
19:30:00.000000+00:00' (UTC)だとすると、上記の SELECT 文は日付として
'08/06/02'を返します。
SELECT 文が AT 句なしで指定されるか、AT LOCAL 句とともに指定されていて、
DBS 制御フラグ TimeDateWZControl が有効な場合、この文は現在の日付として
'08/06/01'を返します。この日付は、現行セッションの時間とタイムゾーン変位
INTERVAL '01:00' HOUR TO MINUTE に基づいています。
返される日付には、夏時間の開始や終了を考慮した調整が行なわれません。
例: INTERVAL -'05:45' HOUR TO MINUTE の現在の日付を返す
この例では、DATE 値のデフォルト フォーマットが'yy/mm/dd'だと仮定していま
す。次の文を考えます。
SET TIME ZONE INTERVAL '10:00' HOUR TO MINUTE;
SELECT CURRENT_DATE AT '05:45';
SELECT CURRENT_DATE AT 5.75;
上記の SELECT 文は、タイムゾーン変位 INTERVAL '05:45' HOUR TO MINUTE を基
にして現在の日付を返します。現在のタイムスタンプが TIMESTAMP '2008-06-01
17:30:00.000000+00:00' (UTC)だとすると、上記の SELECT 文は日付として
'08/06/01'を返します。
SELECT 文が AT 句なしで指定されるか、AT LOCAL 句とともに指定されていて、
DBS 制御フラグ TimeDateWZControl が有効な場合、この文は現在の日付として
'08/06/02'を返します。この日付は、現行セッションの時間とタイムゾーン変位
INTERVAL '10:00' HOUR TO MINUTE に基づいています。
返される日付には、夏時間の開始や終了を考慮した調整が行なわれません。
例: タイムゾーン文字列'America Pacific'の現在の日付を返す
次の問合わせは、タイムゾーン文字列'America Pacific'を基にしたタイムゾーン変位
での、現在の日付を返します。Teradata Database は、タイムゾーン文字列と、
CURRENT_TIMESTAMP AT '00:00'(UTC)を基にしてタイムゾーン変位を決定します。
返される日付は、夏時間の開始と終了を考慮に入れて自動的に調整されます。
SQL 関数、演算子、式および述部
303
第 7 章 組み込み関数
CURRENT_ROLE
SELECT CURRENT_DATE AT TIME ZONE 'America Pacific';
SELECT CURRENT_DATE AT 'America Pacific';
例: デフォルトの出力フォーマットの変更
CURRENT_DATE の結果のデフォルト出力書式を変更するには、Teradata 明示変換
構文を使用して、FORMAT 句を指定します。たとえば、次の文で現在の日付を要求
し、デフォルトとは異なる書式を指定するとします。
SELECT CURRENT_DATE (FORMAT 'MMMBDD,BYYYY');
結果は以下のようになります。
Date
-----------May 31, 2007
関連トピック
詳細は、以下を参照してください。
• デフォルトのデータ タイプの書式と FORMAT 句の詳細については、< SQL デー
タ型とリテラル、B035-1143>の「データ タイプの書式および書式句」を参照し
てください。
• Teradata 明示変換構文を使用してデフォルトの出力書式を変更する例について
は、例: デフォルトの出力フォーマットの変更を参照してください。
• タイムゾーン文字列の詳細については、AT LOCAL および AT TIME ZONE タイム
ゾーン指定子を参照してください。
CURRENT_ROLE
目的
現在許可されているユーザーの現在のロールを戻します。
構文
CURRENT_ROLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
304
SQL 関数、演算子、式および述部
第 7 章 組み込み関数
CURRENT_ROLE
結果のタイプと属性
CURRENT_ROLE のデータ タイプ、書式、およびタイトルは、次のとおりです。
データ タイプ
書式
タイトル
VARCHAR(30) CHARACTER SET UNICODE
X(30)
Current_Role
結果値
プロキシ接続経由で Teradata Database にアクセスしているのではない場合、
CURRENT_ROLE 関数は、ROLE ビルトイン関数と全く同じくセッションの現在の
ロールを返します。これは、セッション ユーザーの現在のロールです。詳細は、
「ROLE」を参照してください。
プロキシ接続経由で Teradata Database にアクセスしている場合、CURRENT_ROLE
は、次の表に示すようにプロキシ ユーザーの現在のロールを返します。
セッションの現在のロール
結果のタイプ
PROXYROLE で設定したロール
ロールの名前。
デフォルト
プロキシ ユーザーの CONNECT THROUGH 権
限にプロキシ ロールが 1 つある場合、結果値
はそのロール名になります。
プロキシ ユーザーの CONNECT THROUGH 権
限にプロキシ ロールが複数ある場合、結果値
は ALL になります。
PROXYROLE=ALL
ALL
PROXYROLE=NONE または NULL
NULL
使用上の注意
CURRENT_ROLE は、FastLoad および MultiLoad ユーティリティではサポートされ
ません。
例: CURRENT_ROLE の選択
以下の文を使って、現在許可されているユーザーの現在のロールを識別できます。
SELECT CURRENT_ROLE;
次のような応答が表示されます。
Current_Role
-----------------------------Buyers_role
SQL 関数、演算子、式および述部
305
第 7 章 組み込み関数
CURRENT_TIME
CURRENT_TIME
目的
現在の時間を返します。
構文
CURRENT_TIME
(fractional_precision )
AT
LOCAL
expression
TIME ZONE
time_zone_string
構文要素
fractional_precision
返される値の精度範囲。有効な範囲は、0~6 です。デフォルトは 0 です。
AT LOCAL
DBS 制御フラグ TimeDateWZControl が有効な場合は、セッションの時間とセッショ
ンのタイムゾーンを基にして構築された値が返されます。
TimeDateWZControl が無効な場合は、Teradata Database サーバー ローカルの時間
値とセッションのタイムゾーンを基にして構成された値が返されます。
AT [TIME ZONE] expression
式で定義されたタイムゾーンの変位を使用します。
expression のデータ タイプは INTERVAL HOUR(2) TO MINUTE か、暗黙的に
INTERVAL HOUR(2) TO MINUTE に変換できるデータ タイプでなければなりません。
AT [TIME ZONE] time_zone_string
time_zone_string は、タイムゾーン変位を決定します。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠していますが、非 ANSI の Teradata Database 拡張
機能が含まれています。
使用上の注意
CURRENT_TIME は、要求が開始された時点での現在の時間を返します。要求が終了
するまでに、CURRENT_TIME が複数回呼び出された場合でも、同じ時間が返されま
す。返される時間が、要求の継続中に変更されることはありません。
306
SQL 関数、演算子、式および述部
第 7 章 組み込み関数
CURRENT_TIME
AT 句なしで CURRENT_TIME を指定した場合や、CURRENT_TIME AT LOCAL を指
定した場合、返される値は、DBS 制御フラグ TimeDateWZControl の設定に応じて、
次に示すように変化します。
• TimeDateWZControl フラグが有効な場合、CURRENT_TIME は、セッションの時
間とセッションのタイムゾーンを基にして構築された時間を返します。
• TimeDateWZControl フラグが無効な場合、CURRENT_TIME は、Teradata
Database サーバーのローカルな時間値と、セッションのタイムゾーンを基にし
て構築された時間を返します。
CURRENT_TIME は、夏時間(DST)の開始と終了を考慮に入れて調整された値を返し
ます。ただし、この調整が実行されるのは、次の場合に限られます。
• CURRENT_TIME が AT [TIME ZONE] time_zone_string とともに指定されていて、
time_zone_string が、個別の DST と標準タイムゾーン変位に対応している。
• CURRENT_TIME が AT LOCAL とともに指定されているか、AT 句なしで指定され
ていて、セッションのタイムゾーンが、個別の DST と標準のタイムゾーン変位
に対応しているタイムゾーン文字列で定義されている。
注: ストアド プロシージャで CURRENT_TIME を使用する場合、DBS 制御フィール
ドの System TimeZone Hour または System TimeZone Minute を変更するときには、
常にそのプロシージャを再コンパイルする必要があります。タイムゾーン文字列が
tdlocaledef ユーティリティを使用して設定されている場合は 、ストアド プロシー
ジャを再コンパイルする必要はありません。
結果のタイプと属性
CURRENT_TIME の、結果のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ
書式
TIME WITH TIME ZONE
TIME WITH TIME ZONE データ タイプ Current Time
のデフォルト書式。
(fractional_precision)
タイトル
CURRENT_TIME を変換するには、Teradata の明示変換構文または ANSI CAST 構文
を使用します。
精度
CURRENT_TIME の結果の秒精度は秒の 100 分の 1 に制限されます。
CURRENT_TIME は、秒の小数点以下 2 桁の有効数字よりも右側の部分については
ゼロを戻します。
CURRENT_TIME のフィールド
CURRENT_TIME のフィールドは、以下のとおりです。
• HOUR
SQL 関数、演算子、式および述部
307
第 7 章 組み込み関数
CURRENT_TIME
•
•
•
•
MINUTE
SECOND
TIMEZONE_HOUR
TIMEZONE_MINUTE
CURRENT_TIME と TIME
CURRENT_TIME は、Teradata 関数である TIME と同様の機能を持っており、ANSI
準拠の構文を使用します。Teradata の TIME 関数の詳細については、TIME を参照し
てください。
例
例: 現在の時間の要求
DBS 制御フラグ TimeDateWZControl が有効な場合、次に示す文は、現在のセッショ
ンの時間とタイムゾーンを基にした、現在の時間を要求します。
SELECT CURRENT_TIME;
SELECT CURRENT_TIME AT LOCAL;
結果は以下のようになります。
Current Time(0)
--------------15:53:34+00:00
セッションのタイムゾーンが、個別の DST と標準タイムゾーン変位に対応する、タ
イムゾーン文字列で定義されている場合は、夏時間の開始と終了を考慮に入れて自
動的に調整された時間が戻されます。それ以外の場合は、夏時間についての調整は
実行されません。
例: タイムゾーン文字列を使用した現在の時間の要求
次の問合わせは、タイムゾーン文字列'America Pacific'を基にしたタイムゾーン変位
での、現在の時間を返します。返される時間は、夏時間の開始と終了を考慮に入れ
て自動的に調整されます。
SELECT CURRENT_TIME AT TIME ZONE 'America Pacific';
SELECT CURRENT_TIME AT 'America Pacific';
例: デフォルトの出力フォーマットの変更
CURRENT_TIME の結果のデフォルト出力書式を変更するには、Teradata 明示変換構
文を使用して、FORMAT 句を指定します。たとえば、次の文で現在 時間を要求し、
デフォルトとは異なる書式を指定するとします。
SELECT CURRENT_TIME (FORMAT 'HH:MIBT');
308
SQL 関数、演算子、式および述部
第 7 章 組み込み関数
CURRENT_TIMESTAMP
結果は次のようになります。
Current Time(0)
--------------02:29 PM
関連トピック
詳細は、以下を参照してください。
• 詳細は、AT LOCAL および AT TIME ZONE タイムゾーン指定子を参照してくださ
い。
• デフォルトのデータ タイプの書式と FORMAT 句の詳細については、< SQL デー
タ型とリテラル、B035-1143>の「データ タイプの書式および書式句」を参照し
てください。
• Teradata 明示変換構文を使用してデフォルトの出力書式を変更する例について
は、例: デフォルトの出力フォーマットの変更を参照してください。
• 詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>の「CREATE
PROCEDURE (SQL 形式)」および<ユーティリティ 、B035-1102>の「DBS 制御
(dbscontrol)」を参照してください。
CURRENT_TIMESTAMP
目的
現在のタイムスタンプを返します。
構文
CURRENT_TIMESTAMP
(fractional_precision )
AT
LOCAL
expression
TIME ZONE
time_zone_string
構文要素
fractional_precision
返される値の精度範囲。有効な範囲は、0~6 です。デフォルトは 0 です。
AT LOCAL
DBS 制御フラグ TimeDateWZControl が有効な場合は、セッションの時間とセッショ
ンのタイムゾーンを基にして構築された値が返されます。
SQL 関数、演算子、式および述部
309
第 7 章 組み込み関数
CURRENT_TIMESTAMP
TimeDateWZControl が無効な場合は、Teradata Database サーバー ローカルの時間
値とセッションのタイムゾーンを基にして構成された値が返されます。
AT [TIME ZONE] expression
式で定義されたタイムゾーンの変位を使用します。
expression のデータ タイプは INTERVAL HOUR(2) TO MINUTE か、暗黙的に
INTERVAL HOUR(2) TO MINUTE に変換できるデータ タイプでなければなりません。
AT [TIME ZONE] time_zone_string
time_zone_string は、タイムゾーン変位を決定します。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠していますが、非 ANSI の Teradata Database 拡張
機能が含まれています。
使用上の注意
CURRENT_TIMESTAMP は、要求が開始された時点での現在のタイムスタンプを返
します。要求が終了するまでに、CURRENT_TIMESTAMP が複数回呼び出された場
合でも、同じタイムスタンプが返されます。返されるタイムスタンプが、要求の継
続中に変更されることはありません。
AT 句なしで CURRENT_TIMESTAMP を指定した場合や、CURRENT_TIMESTAMP AT
LOCAL を指定した場合、返される値は、DBS 制御フラグ TimeDateWZControl の設
定に応じて、次に示すように変化します。
• TimeDateWZControl フラグが有効な場合、CURRENT_TIMESTAMP は、セッショ
ンの時間とセッションのタイムゾーンを基にして構築されたタイムスタンプを返
します。
• TimeDateWZControl フラグが無効な場合、CURRENT_TIMESTAMP は、Teradata
Database サーバーのローカルな時間値と、セッションのタイムゾーンを基にして
構築されたタイムスタンプを返します。
CURRENT_TIMESTAMP は、夏時間(DST)の開始と終了を考慮に入れて調整された値
を返します。ただし、この調整が実行されるのは、次の場合に限られます。
• CURRENT_TIMESTAMP が AT [TIME ZONE] time_zone_string とともに指定され
ていて、time_zone_string が、個別の DST と標準タイムゾーン変位に対応してい
る。
• CURRENT_TIMESTAMP が AT LOCAL とともに指定されているか、AT 句なしで指
定されていて、セッションのタイムゾーンが、個別の DST と標準のタイムゾーン
変位に対応しているタイムゾーン文字列で定義されている。
注: ストアド プロシージャで CURRENT_TIMESTAMP を使用する場合、DBS 制御
フィールドの System TimeZone Hour または System TimeZone Minute を変更する
ときには、常にそのプロシージャを再コンパイルする必要があります。タイムゾー
310
SQL 関数、演算子、式および述部
第 7 章 組み込み関数
CURRENT_TIMESTAMP
ン文字列が tdlocaledef ユーティリティを使用して設定されている場合は 、ストア
ド プロシージャを再コンパイルする必要はありません。
結果のタイプと属性
CURRENT_TIMESTAMP の、結果のデータ タイプ、書式、およびタイトルは次のと
おりです。
データ タイプ
書式
タイトル
TIMESTAMP WITH
TIME ZONE
TIMESTAMP WITH TIME ZONE データ タイプ Current TimeStamp
のデフォルト書式。
(fractional_precisio
n)
デフォルト書式の詳細については、< SQL デー
タ型とリテラル、B035-1143>の「データ タ
イプの書式および書式句」を参照してくださ
い。
CURRENT_TIMESTAMP を変換するには、Teradata の明示変換構文または ANSI
CAST 構文を使用します。Teradata 明示変換構文を使用してデフォルトの出力書式
を変更する例については、「例: デフォルトの出力書式の変更」を参照してください。
精度
CURRENT_TIMESTAMP の結果の秒精度は秒の 100 分の 1 に制限されます。
CURRENT_TIMESTAMP は、秒の小数点以下 2 桁の有効数字よりも右側の部分につ
いてはゼロを戻します。
CURRENT_TIMESTAMP のフィールド
CURRENT_TIMESTAMP のフィールドは、以下のとおりです。
•
•
•
•
•
•
•
•
YEAR
MONTH
DAY
HOUR
MINUTE
SECOND
TIMEZONE_HOUR
TIMEZONE_MINUTE
例
例: 現在のタイムスタンプの要求
DBS 制御フラグ TimeDateWZControl が有効な場合、次に示す文は、現在のセッショ
ンの時間とタイムゾーンを基にした、現在のタイムスタンプを要求します。
SQL 関数、演算子、式および述部
311
第 7 章 組み込み関数
CURRENT_TIMESTAMP
SELECT CURRENT_TIMESTAMP;
SELECT CURRENT_TIMESTAMP AT LOCAL;
結果は以下のようになります。
Current TimeStamp(6)
-------------------------------2001-11-27 15:53:34.910000+00:00
セッションのタイムゾーンが、個別の DST と標準タイムゾーン変位に対応する、タ
イムゾーン文字列で定義されている場合は、夏時間の開始と終了を考慮に入れて自
動的に調整されたタイムスタンプが戻されます。それ以外の場合は、夏時間につい
ての調整は実行されません。
例: CURRENT_TIMESTAMP および TimeDateWZControl フラグ
この例では、CURRENT_TIMESTAMP が AT 句なしか、AT LOCAL 句とともに指定さ
れているときに、DBS 制御フラグ TimeDateWZControl が、この関数の返す値に与え
る効果を示しています。
次のように仮定します。
• Teradata Database サーバーのローカル時間は、協定世界時(UTC)で 2010 年 1 月
31 日の 11:59:00 です。
• ユーザー TK は、東京で暮らしています。東京は UTC からのオフセットが+9 時
間と定義されています。
• ユーザー LA は、ロサンゼルスで暮らしています。ロサンゼルスは UTC からのオ
フセットが-8 時間と定義されています。
• ユーザー TK とユーザー LA は、CURRENT_TIMESTAMP 関数をまったく同時に実
行しました。
TimeDateWZControl フラグが有効な場合
ユーザー TK の CURRENT_TIMESTAMP 関数は、以下を返します。
2010-02-01 10:59:00.000000+09:00
ユーザー LA の CURRENT_TIMESTAMP 関数は、以下を返します。
2010-01-31 16:59:00.000000-08:00
TimeDateWZControl フラグが無効な場合
ユーザー TK の CURRENT_TIMESTAMP 関数は、以下を返します。
2010-01-31 11:59:00.000000+09:00
ユーザー LA の CURRENT_TIMESTAMP 関数は、以下を返します。
2010-01-31 11:59:00.000000-08:00
312
SQL 関数、演算子、式および述部
第 7 章 組み込み関数
CURRENT_USER
例: タイムゾーン文字列を使用した現在のタイムスタンプの要求
次の問合わせは、タイムゾーン文字列'America Pacific'を基にしたタイムゾーン変位
での、現在のタイムスタンプを返します。返されるタイムスタンプは、夏時間の開
始と終了を考慮に入れて自動的に調整されます。
SELECT CURRENT_TIMESTAMP AT TIME ZONE 'America Pacific';
SELECT CURRENT_TIMESTAMP AT 'America Pacific';
例: デフォルトの出力フォーマットの変更
CURRENT_TIMESTAMP の結果のデフォルト出力書式を変更するには、Teradata 明
示変換構文を使用して、FORMAT 句を指定します。たとえば、次の文で現在のタイ
ムスタンプを要求し、デフォルトとは異なる書式を指定するとします。
SELECT CURRENT_TIMESTAMP (FORMAT 'MMMBDD,BYYYYBHH:MIBT');
結果は次のようになります。
Current TimeStamp(6)
--------------------Feb 19, 2002 07:45 am
関連トピック
詳細は、以下を参照してください。
• タイムゾーン文字列の詳細については、AT LOCAL および AT TIME ZONE タイム
ゾーン指定子を参照してください。
• 例: デフォルトの出力フォーマットの変更
• <SQL データ定義言語 - 構文規則および例、B035-1144>の「CREATE PROCEDURE
(SQL 形式)」
• <ユーティリティ 、B035-1102>の「DBS 制御(dbscontrol)」
• デフォルトのデータ タイプの書式と FORMAT 句の詳細については、< SQL デー
タ型とリテラル、B035-1143>の「データ タイプの書式および書式句」を参照し
てください。
CURRENT_USER
目的
現在許可されているユーザーのユーザー名を戻します。
構文
CURRENT_USER
SQL 関数、演算子、式および述部
313
第 7 章 組み込み関数
DATABASE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
結果のタイプと属性
CURRENT_USER のデータ タイプ、書式、およびタイトルは、次のとおりです。
データ タイプ
書式
タイトル
VARCHAR(30) CHARACTER SET UNICODE
X(30)
Current_User
結果値
プロキシ接続経由で Teradata Database にアクセスしている場合、CURRENT_USER
は、プロキシ ユーザー名を返します。それ以外の場合、USER ビルトイン関数と全
く同じように機能し、セッションのユーザー名を返します。詳細は、「USER」を参
照してください。
例
例: 現在のユーザーの識別
以下の文を使って、現在許可されているユーザーを識別できます。
SELECT CURRENT_USER;
システム応答は 、以下のようになります。
Current_User
-----------------------------BO-JSMITH
例: 現在のユーザーの肩書の選択
以下の例は、現在許可されているユーザーのジョブ タイトルを取り出します。
SELECT JobTitle FROM Employee WHERE Name = CURRENT_USER;
DATABASE
目的
現在のユーザーのデフォルト データベースの名前を戻します。
314
SQL 関数、演算子、式および述部
第 7 章 組み込み関数
DATE
構文
DATABASE
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果のタイプと属性
DATABASE のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ
書式
タイトル
VARCHAR(30) CHARACTER SET UNICODE
X(30)
Database
使用上の注意
DATABASE 要求によって現在のデフォルト データベースが変更されている場合は、
DATABASE 関数によって、デフォルトの新しい名前が戻されます。
例: デフォルトのデータベースの名前の要求
次の文は、デフォルト データベースの名前を要求します。
SELECT DATABASE;
システム応答は 、以下のようになります。
Database
-----------------------------Customer_Service
DATE
目的
現在日付を戻します。
構文
DATE
AT
LOCAL
expression
TIME ZONE
SQL 関数、演算子、式および述部
time_zone_string
315
第 7 章 組み込み関数
DATE
構文要素
AT LOCAL
DBS 制御フラグ TimeDateWZControl が有効な場合は、セッションの時間とセッショ
ンのタイムゾーンを基にして構築された値が返されます。
TimeDateWZControl が無効な場合は、Teradata Database サーバー ローカルの時間
値とセッションのタイムゾーンを基にして構成された値が返されます。
AT [TIME ZONE] expression
式で定義されたタイムゾーンの変位を使用します。
expression のデータ タイプは INTERVAL HOUR(2) TO MINUTE か、暗黙的に
INTERVAL HOUR(2) TO MINUTE に変換できるデータ タイプでなければなりません。
AT [TIME ZONE] time_zone_string
time_zone_string は、タイムゾーン変位を決定します。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠していますが、非 ANSI の Teradata Database 拡張
機能が含まれています。
使用上の注意
DATE は、要求が開始された時点での日付を返します。要求が終了するまでに、DATE
が複数回呼び出された場合でも、同じ日付が返されます。返される日付が、要求の
継続中に変更されることはありません。
AT 句なしで DATE を指定した場合や、DATE AT LOCAL を指定した場合、返される
値は、DBS 制御フラグ TimeDateWZControl の設定に応じて、次に示すように変化し
ます。
• TimeDateWZControl フラグが有効な場合、DATE は、セッションの時間とセッ
ションのタイムゾーンを基にして構築された日付を返します。
• TimeDateWZControl フラグが無効な場合、DATE は、Teradata Database サーバー
のローカルな時間値と、セッションのタイムゾーンを基にして構築された日付を
返します。
DATE は、夏時間(DST)の開始と終了を考慮に入れて調整された値を返します。ただ
し、この調整が実行されるのは、次の場合に限られます。
• DATE が AT [TIME ZONE] time_zone_string とともに指定されていて、
time_zone_string が、個別の DST と標準タイムゾーン変位に対応している。
• DATE が AT LOCAL とともに指定されているか、AT 句なしで指定されていて、
セッションのタイムゾーンが、個別の DST と標準のタイムゾーン変位に対応して
いるタイムゾーン文字列で定義されている。
DATE をユーザー定義メソッド呼出しの最初の引数として使用することはできません。
316
SQL 関数、演算子、式および述部
第 7 章 組み込み関数
DATE
結果のタイプと属性
DATE のデフォルトの書式は、Dateform モードの値に応じて異なります。DATE の
データ タイプ、書式、およびタイトルは、次のとおりです。
データ タイプ 書式
DATE
タイトル
日付形式モード
DATE 関数書式
INTEGERDATE
SDF で指定された DATE データ タ DATE
イプのデフォルトの書式
ANSIDATE
'YYYY-MM-DD'
DATE と CURRENT_DATE
DATE の使用はお勧めしません。その代わりに、ANSI SQL:2011 準拠の
CURRENT_DATE 関数を使用してください。
例
例 1: INTERVAL -'08:00:00' HOUR TO MINUTE を基に現在の日付を返す
この例では、DATE 値のデフォルト フォーマットが'yy/mm/dd'だと仮定していま
す。次の文を考えます。
SET TIME ZONE INTERVAL '01:00' HOUR TO MINUTE;
SELECT DATE AT TIME ZONE INTERVAL -'08:00' HOUR TO MINUTE;
SELECT DATE AT INTERVAL -'08:00' HOUR TO MINUTE;
SELECT DATE AT TIME ZONE INTERVAL -'08' HOUR;
SELECT DATE AT INTERVAL -'08' HOUR;
SELECT DATE AT TIME ZONE '-08:00';
SELECT DATE AT '-08:00';
SELECT DATE AT TIME ZONE '-8';
SELECT DATE AT '-8';
SELECT DATE AT TIME ZONE -8;
SELECT DATE AT -8;
SELECT DATE AT -8.0;
上記の SELECT 文は、タイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE を基
にして現在の日付を返します。現在のタイムスタンプが TIMESTAMP '2008-06-01
06:30:00.000000+00:00' (UTC)だとすると、上記の SELECT 文は日付として
'08/05/31'を返します。
SELECT 文が AT 句なしで指定されるか、AT LOCAL 句とともに指定されていて、
DBS 制御フラグ TimeDateWZControl が有効な場合、この文は現在の日付として
'08/06/01'を返します。この日付は、現行セッションの時間とタイムゾーン変位
INTERVAL '01:00' HOUR TO MINUTE に基づいています。たとえば、
SELECT DATE;
SELECT DATE AT LOCAL;
返される日付には、夏時間の開始や終了を考慮した調整が行なわれません。
SQL 関数、演算子、式および述部
317
第 7 章 組み込み関数
PROFILE
例 2: 'mm-dd-yy'への表示変更
FORMAT 句を使って、表示形式を変更してみましょう。
SELECT DATE (FORMAT 'mm-dd-yy');
Date
-------03-30-96
例: タイムゾーン文字列'America Pacific'に基づいて現在の日付を返す
次の問合わせは、タイムゾーン文字列'America Pacific'を基にしたタイムゾーン変位
での、現在の日付を返します。Teradata Database は、タイムゾーン文字列と、
CURRENT_TIMESTAMP AT '00:00'(UTC)を基にしてタイムゾーン変位を決定します。
返される日付は、夏時間の開始と終了を考慮に入れて自動的に調整されます。
SELECT DATE AT TIME ZONE 'America Pacific';
SELECT DATE AT 'America Pacific';
例 4: 表示を'mmmbdd,byyyy'に変更する
別の形式にします。
SELECT DATE (FORMAT 'mmmbdd,byyyy');
Date
-----------Mar 30, 1996
関連トピック
詳細は、以下を参照してください。
• dbscontrol の詳細については、<ユーティリティ 、B035-1102>の「DBS 制御
(dbscontrol)」を参照してください。
• タイムゾーン文字列の詳細については、AT LOCAL および AT TIME ZONE タイム
ゾーン指定子を参照してください。
• デフォルトのデータ タイプ書式の詳細については、< SQL データ型とリテラル、
B035-1143>の「データ タイプの書式および書式句」を参照してください。
• DATE と CURRENT_DATE の詳細については、CURRENT_DATE を参照してくださ
い。
PROFILE
目的
セッションの現在のプロファイルを戻すか、それがない場合は NULL を戻します。
318
SQL 関数、演算子、式および述部
第 7 章 組み込み関数
ROLE
構文
PROFILE
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果のタイプと属性
PROFILE のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ
書式
タイトル
VARCHAR(30) CHARACTER SET UNICODE
X(30)
Profile
例
以下の文を使って、セッションの現在のプロファイルを識別できます。
SELECT PROFILE ;
ROLE
目的
セッションの現在のロールを戻します。
構文
ROLE
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果のタイプと属性
ROLE のデータ タイプ、書式、およびタイトルは、次のとおりです。
データ タイプ
書式
タイトル
VARCHAR(30) CHARACTER SET UNICODE
X(30)
Role
SQL 関数、演算子、式および述部
319
第 7 章 組み込み関数
ROLE
結果値
セッション ログオンは、ディレクトリ ベースである場合とそうでない場合がありま
す。
プロキシ接続経由で Teradata Database にアクセスしている場合にプロキシ ユーザー
の現在のロールを取得するには、CURRENT_ROLE ビルトイン関数を使用します。
セッション ログオンがディレクトリ ベースでない
セッション ログオンがディレクトリ ベースでない場合は、次の表を参照してくださ
い。
セッションの現行ロール
結果値
既存のロール
そのロールの名前
ALL
'ALL'
NONE または NULL
NULL
セッション ログオンがディレクトリ ベースである
セッション ログオンがディレクトリ ベースである場合は、次の表を参照してくださ
い。
セッション
結果値
ディレクトリ管理ロールのセットが割り当てられていて、現
行ロールを変更しない場合
'EXTERNAL'
SET ROLE EXTERNAL 文を使用する場合
• ディレクトリ管理ロールのセットが割り当てられていない、 永続ユーザーのデフォルト
• デフォルト データベース管理ロールを持つ永続ユーザーに ロールの名前
マップされる、かつ
• 現行ロールを変更しない場合
SET ROLE role_name 文を使用する場合(role_name はディレク 指定したロールの名前
トリ管理ロールまたはデータベース管理ロール)
SET ROLE ALL 文を使用する場合
'ALL'
• ディレクトリ管理ロールのセットが割り当てられていない、 NULL
• 現行ロールを変更しない、および次のいずれかの条件が真
である
ディレクトリ ベース ログオンが永続ユーザーにマップさ
れない
ディレクトリ ベース ログオンがマップされる永続ユーザー
にデフォルト データベース管理ロールがない
SET ROLE NONE 文を使用する場合
320
SQL 関数、演算子、式および述部
第 7 章 組み込み関数
SESSION
セッション
結果値
SET ROLE NULL 文を使用する場合
使用上の注意
ROLE は、FastLoad および MultiLoad ユーティリティではサポートされません。
例: セッションの現在のロールの識別
以下の文を使って、セッションの現在のロールを識別できます。
SELECT ROLE;
システム応答は 、以下のようになります。
Role
-----------------------------EXTERNAL
SESSION
目的
現在のユーザーのセッションの番号を戻します。
構文
SESSION
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果のタイプと属性
SESSION のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ 書式
セッション
INTEGER
Session
INTEGER データ タイプのデフォルト書式。
デフォルト書式の詳細については、< SQL データ型とリテ
ラル、B035-1143>の「データ タイプの書式および書式句」
を参照してください。
SQL 関数、演算子、式および述部
321
第 7 章 組み込み関数
TEMPORAL_DATE
例: 現在のユーザーのセッション番号の識別
次の文は、現在のユーザーのセッションの番号を識別します。
SELECT SESSION;
システム応答は 、以下のようになります。
Session
----------1048
TEMPORAL_DATE
目的
セッションのタイムゾーンに基づいて評価した、現在のトランザクションの日付を
返します。
構文
TEMPORAL_DATE
結果のタイプと属性
TEMPORAL_DATE の、結果のデータ タイプ、書式、およびタイトルは次のとおりで
す。
データ タイプ
書式
DATE
DATE データ タイプのデフォルト書式(Dateform DATE
モードが IntegerDate に設定されている場合)。
タイトル
デフォルト書式の詳細については、< SQL デー
タ型とリテラル、B035-1143>の「データ タイ
プの書式および書式句」を参照してください。
使用上の注意
TEMPORAL_DATE の値は、単一のトランザクション内で実行された要求すべてに対
して同じになります。
システムは、セッションのタイムゾーンを使用して TEMPORAL_DATE を評価します。
CHECK 制約または DEFAULT 句に TEMPORAL_DATE があると、結果値が評価され
る時期は、この要求が CHECK 制約を適用したとき(挿入時または更新時)か、この要
求が特定の列の DEFAULT 値を使用したときになります。
322
SQL 関数、演算子、式および述部
第 7 章 組み込み関数
TEMPORAL_TIMESTAMP
制約事項
パーティション基本索引を定義する PARTITION BY 句のパーティション式内では、
TEMPORAL_DATE はサポートされません。
TEMPORAL_TIMESTAMP
目的
セッションのタイムゾーンに基づいて評価した、現在のトランザクションのタイム
スタンプを返します。
構文
TEMPORAL_TIMESTAMP
( precision )
構文要素
precision
返される値の精度範囲。有効な範囲は、0~6 です。デフォルトは 0 です。
結果のタイプと属性
TEMPORAL_TIMESTAMP の、結果のデータ タイプ、書式、およびタイトルは次の
とおりです。
データ タイプ
書式
TIMESTAMP(n) WITH TIME
ZONE、ただし、n は precision
引数と同じになる(省略時は 6)
TIMESTAMP WITH TIME ZONE タイプのデ Timestamp
フォルト書式。
タイトル
使用上の注意
TEMPORAL_TIMESTAMP の値は、単一のトランザクション内で実行された要求す
べてに対して同じになります。
システムは 、セッションのタイムゾーンを使用して TEMPORAL_TIMESTAMP を評
価します。
CHECK 制約または DEFAULT 句に TEMPORAL_TIMESTAMP があると、結果値が評
価される時期は、この要求が CHECK 制約を適用したとき(挿入時または更新時)か、
この要求が特定の列の DEFAULT 値を使用したときになります。
SQL 関数、演算子、式および述部
323
第 7 章 組み込み関数
TIME
精度
TEMPORAL_TIMESTAMP の結果の秒精度は秒の 100 分の 1 に制限されます。
TEMPORAL_TIMESTAMP は、秒の小数点以下 2 桁の有効数字よりも右側の部分につ
いてはゼロを戻します。
関連トピック
詳細は、以下を参照してください。
• ANSI テンポラル テーブル サポート<一時テーブルのサポート 、B035-1182>。
• デフォルト書式の詳細については、< SQL データ型とリテラル、B035-1143>の
「データ タイプの書式および書式句」を参照してください。
TIME
目的
現在の時間を返します。
構文
TIME
AT
LOCAL
expression
TIME ZONE
time_zone_string
構文要素
AT LOCAL
DBS 制御フラグ TimeDateWZControl が有効な場合は、セッションの時間とセッショ
ンのタイムゾーンを基にして構築された値が返されます。
TimeDateWZControl が無効な場合は、Teradata Database サーバー ローカルの時間
値とセッションのタイムゾーンを基にして構成された値が返されます。
AT [TIME ZONE] expression
式で定義されたタイムゾーンの変位を使用します。
expression のデータ タイプは INTERVAL HOUR(2) TO MINUTE か、暗黙的に
INTERVAL HOUR(2) TO MINUTE に変換できるデータ タイプでなければなりません。
AT [TIME ZONE] time_zone_string
time_zone_string は、タイムゾーン変位を決定します。
324
SQL 関数、演算子、式および述部
第 7 章 組み込み関数
TIME
ANSI への準拠
この文は、ANSI SQL:2011 に準拠していますが、非 ANSI の Teradata Database 拡
張機能が含まれています。
使用上の注意
TIME は、要求が開始された時点での現在の時間を返します。要求が終了するまで
に、TIME が複数回呼び出された場合でも、同じ時間が返されます。返される時間
が、要求の継続中に変更されることはありません。
AT 句なしで TIME を指定した場合や、TIME AT LOCAL を指定した場合、返される
値は、DBS 制御フラグ TimeDateWZControl の設定に応じて、次に示すように変化
します。
• TimeDateWZControl フラグが有効な場合、TIME は、セッションの時間とセッ
ションのタイムゾーンを基にして構築された時間を返します。
• TimeDateWZControl フラグが無効な場合、TIME は、Teradata Database サー
バーのローカルな時間値と、セッションのタイムゾーンを基にして構築された時
間を返します。
TIME データは内部的に UTC で格納されます。UTC は TIME 結果値の並替えに影響
することがあります。
TIME は、夏時間(DST)の開始と終了を考慮に入れて調整された値を返します。ただ
し、この調整が実行されるのは、次の場合に限られます。
• TIME が AT [TIME ZONE] time_zone_string とともに指定されていて、
time_zone_string が、個別の DST と標準タイムゾーン変位に対応している。
• TIME が AT LOCAL とともに指定されているか、AT 句なしで指定されていて、
セッションのタイムゾーンが、個別の DST と標準のタイムゾーン変位に対応し
ているタイムゾーン文字列で定義されている。
TIME をユーザー定義メソッド呼出しの最初の引数として使用することはできません。
結果のタイプと属性
TIME のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ
書式
タイトル
FLOAT
HHMMSS.CC (時間、分、秒、100 分の 1 秒)
Time
TIME と CURRENT_TIME
TIME の使用はお勧めしません。その代わりに、ANSI SQL:2011 準拠の
CURRENT_TIME 関数を使用してください。
SQL 関数、演算子、式および述部
325
第 7 章 組み込み関数
TIME
例
例 1: セッションの時間とタイムゾーンを基にした、現在の時間の要求
DBS 制御フラグ TimeDateWZControl が有効な場合、次に示す文は、現在のセッショ
ンの時間とタイムゾーンを基にした、現在の時間を要求します。
SELECT TIME;
SELECT TIME AT LOCAL;
結果は以下のようになります。
Time
-------16:20:20
セッションのタイムゾーンが、個別の DST と標準タイムゾーン変位に対応する、タ
イムゾーン文字列で定義されている場合は、夏時間の開始と終了を考慮に入れて自
動的に調整された時間が戻されます。それ以外の場合は、夏時間についての調整は
実行されません。
例 2: タイムゾーン文字列'America Pacific'に基づいて現在の時間を返す
次の問合わせは、タイムゾーン文字列'America Pacific'を基にしたタイムゾーン変位
での、現在の時間を返します。返される時間は、夏時間の開始と終了を考慮に入れ
て自動的に調整されます。
SELECT TIME AT TIME ZONE 'America Pacific';
SELECT TIME AT 'America Pacific';
例 3: 100 分の 1 秒の表示
100 分の 1 秒単位の部分は、デフォルト書式では表示されませんが、FORMAT 句を
使用すると表示できます。
SELECT TIME (FORMAT '99:99:99.99');
システム応答は 、以下のようになります。
Time
----------16:26:30.19
例 4: テーブルへの行の挿入
以下の例は、仮想上のテーブル(InsertTime 列のデータ タイプは FLOAT)に行を挿入
し、その行が挿入された時刻を記録します。
INSERT INTO HypoTable (ColumnA, ColumnB, InsertTime)
VALUES ('Abcde', 12345, TIME);
関連トピック
詳細は、以下を参照してください。
326
SQL 関数、演算子、式および述部
第 7 章 組み込み関数
USER
• 詳細は、<ユーティリティ 、B035-1102>の「DBS 制御(dbscontrol)」を参照して
ください。
• TIME データが内部的に UTC で格納される詳細については、< SQL データ操作言
語、B035-1146>の「ORDER BY 句」を参照してください。
• タイムゾーン文字列の詳細については、「AT LOCAL および AT TIME ZONE タイ
ムゾーン指定子」を参照してください。
• TIME と CURRENT_TIME の詳細については、「CURRENT_TIME」を参照してく
ださい。
USER
目的
セッションのユーザー名を戻します。
構文
USER
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
結果のタイプと属性
USER のデータ タイプ、書式、およびタイトルは次のとおりです。
データ タイプ
書式
タイトル
VARCHAR(30) CHARACTER SET UNICODE
X(30)
User
結果値
セッション ログ
オン
結果
非ディレクトリ
ベース
結果値は、セッションのユーザー名です。
ディレクトリ ベー セッションが永久テーブルにマップされる場合、結果値は永続ユーザー
ス
の名前になります。
セッションが永続ユーザーにマップされない場合、結果値は外部ユー
ザーの認証 ID になります。
SQL 関数、演算子、式および述部
327
第 7 章 組み込み関数
USER
プロキシ接続経由で Teradata Database にアクセスしている場合にプロキシ ユーザー
の現在の名前を取得するには、CURRENT_USER ビルトイン関数を使用します。
例
例: ユーザー名の識別
以下の文を使って、セッションのユーザー名を識別できます。
SELECT USER;
システム応答は 、以下のようになります。
User
-----------------------------JJ43901
例: ユーザーの肩書の選択
以下の例では、セッション ユーザーのジョブ タイトルを選択します。
SELECT JobTitle FROM Employee WHERE Name = USER;
関連トピック
詳細は、「CURRENT_USER」を参照してください。
328
SQL 関数、演算子、式および述部
第8章
ビジネス カレンダ
概要
この章では、システム定義のビジネス カレンダと、このカレンダの操作に使用でき
るマクロ、およびビジネス カレンダのテーブルとビューについて説明します。ま
た、システム定義のビジネス カレンダをサポートする埋め込みサービス システム
関数についても説明します。
ビジネス カレンダについて
ビジネス カレンダでは、営業日と休業日を定義します。営業日または休業日にする
日の意味はユーザーが決定します。たとえば、営業日を就業日にすることも、休業
日を非就業日、週末、祝祭日または長期休業日にすることもできます。システム定
義のカレンダに対して、さまざまな週のパターン(平日や週末)と、例外(祝祭日や開
休業日)を定義することができます。
セッションに設定できる Teradata システム定義のビジネス カレンダは 3 つあります。
• TERADATA
• ISO
• COMPATIBLE
これら 3 つのカレンダは、いずれも事実上の国際規格であるグレゴリオ暦に基づい
ています。グレゴリオ暦には、365 日の通常年と、366 日のうるう年があります。
これらのカレンダは、週の定義の方法や、部分的な週を認めるかどうかが異なりま
す。マクロを使用することで、平日/週末のパターンと、そのパターンに対する例外
を指定できます。
これらのカレンダは、1900 年 1 月 1 日から 2100 年 12 月 31 日までをサポートし
ます。デフォルトのセッション カレンダは、Teradata です。各カレンダは、すべて
日のが営業日になるようにデフォルト設定されています。このパターンは、マクロ
を使用することで変更できます。「ビジネス カレンダのマクロについて」を参照し
てください。
カレンダの相違点
カレンダ
第 1 週の起点
TERADATA
日曜日。
SQL 関数、演算子、式および述部
329
第 8 章 ビジネス カレンダ
計算
カレンダ
第 1 週の起点
その年の日曜より前の日は第 0 週に属します。
たとえば、その年の始まりが 2004 年 1 月 1 日(木曜日)だとする
と、1 月 1 日から 1 月 3 日までが第 0 週になります。第 1 週は、
1 月 4 日の日曜から始まります。
ISO
月曜日。
4 日間以上が含まれる最初の週が、その年の最初の週になります。
4 日間より少なくなる週は、前年の最後の週に属することになりま
す。部分的な週はありません。
このカレンダは、ISO 規格および欧州規格に準じています。たとえ
ば、その年の始まりが 2008 年 1 月 1 日(火曜日)だとすると、週は
月曜日から始まるため、2008 年の第 1 週は 20007 年 12 月 31 日
から 2008 年 1 月 6 日までになります。
COMPATIBLE
曜日に関係なく、1 月 1 日から始まります。
年の終わりに 1 日(通常年)または 2 日(うるう年)の部分的な週が存
在します。週の始まる曜日は、年ごとに変わります。
このカレンダは、Oracle との互換性があります。たとえば、2011
年 1 月 1 日は土曜日なので、その年の最初の週は 2011 年 1 月 1
日の土曜日から 2011 年 1 月 7 日の金曜日までになります。
計算
ISO 計算について
ISO カレンダで週、月、四半期および年を定義する方法は、Teradata カレンダや
COMPATIBLE カレンダとは異なります。ISO では、週は完全な(7 日間の)週に限られ
ます。すべてのビジネス カレンダ関数とビューは、ISO の計算に次のルールを使用
します。
週
ISO の週は常に 7 日あります。部分的な週はありません。ISO の週は常に月曜日から
始まり、日曜日で終わります。
年
各年には、52~53 の完全な週があります。年の開始と終了は、年境界の週に ISO の
木曜日ルールを適用することで判断します。グレゴリオ暦で木曜日が旧年側に入る
場合、その年境界の週は ISO カレンダでは旧年の一部に含まれます。グレゴリオ暦
で木曜日が新年側に入る場合、その年境界の週は ISO カレンダでは新年の一部に含
330
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
計算
まれます。たとえば、2009 年 12 月 31 日は木曜日です。そのため、ISO カレンダ
では、2009 年 12 月 28 日の月曜日から 2010 年 1 月 3 日の日曜日までが、2009
年の最後週になります。ISO カレンダでの 2010 年の最初の週は、2010 年 1 月 4
日の月曜日から始まります。それに対し、Teradata カレンダの 2010 年の最初の週
は 1 月 1 日の金曜日から始まります。
図 1 : 2009 年 12 月最終週 ISO
図 2 : 2010 年 1 月第 1 週 ISO
SQL 関数、演算子、式および述部
331
第 8 章 ビジネス カレンダ
計算
月
各月には、4~5 の完全な週があります。その月の開始と終了は、月境界の週に ISO
の木曜日ルールを適用することで判断します。例えば、ISO カレンダでは、2012 年
10 月は 10 月 28 日の日曜日が月の終わりになります。これは、月境界の週の木曜
日が 11 月 1 日にあたるためです。10 月 29 日の月曜日から始まる新しい週は、11
月の一部分になります。
図 3 : 2012 年 10 月最終週 ISO
図 4 : 2012 年 11 月第 1 週 ISO
四半期
ISO の年は 4 つの四半期に分割されます。各四半期には 13 の週があります。1 年が
53 週になる場合には、最後の四半期は 14 週になります。四半期は、4、4、5 週ま
332
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
計算
たは 4、5、4 週あるいは 5、4、4 週のパターンで 3 ヶ月に分割されます。1 年が
53 週の場合、最後の四半期は 4、5、5 週または 5、4、5 週または 5、5、4 週のパ
ターンの 3 ヶ月になります。四半期の開始または終了は、その四半期の最後の月に
あたる月境界の週に ISO の木曜日ルールを適用することで決定されます。月境界の
週は、その週の木曜日を含む月に属します。例えば、2016 年 1 月 1 日の金曜日は、
木曜日が含まれる 2015 年の最終四半期の最終週の一部になります。そのため、
2016 年 1 月 1 日の金曜日は、ISO カレンダでは 2015 年の最後の四半期に属する
ことになり、Teradata カレンダでは 2016 年の最初の四半期に属することになりま
す。
図 5 : 2015 年 12 月最終四半期週 ISO
SQL 関数、演算子、式および述部
333
第 8 章 ビジネス カレンダ
ビジネス カレンダのマクロについて
図 6 : 2016 年 1 月第 1 四半期週 ISO
ビジネス カレンダのマクロについて
システム ビジネス マクロを使用すると、管理者およびユーザーは次の処理を実行し
てシステム ビジネス カレンダ(Teradata、ISO、および COMPATIBLE)を構成できます。
• カレンダのパターンを作成します。
• カレンダの例外を作成します。
• カレンダから既存の例外を削除します。
これらのマクロは DIP スクリプトを実行すると作成され、DBC データベースに保持
されます。
注: マクロを表示するには、DIP スクリプトを使用します。
マクロ名
目的
CreateBusinessCalendarPattern ビジネス カレンダのパターンを作成します。
334
CreateException
特定のビジネス カレンダの例外リストを定義します。この
リストでは、カレンダの日のうち、カレンダに対して定義
されているパターンの例外となる日をすべて特定します。
DeleteException
特定のビジネス カレンダから特定の例外を削除します。
DeleteAllExceptions
特定のビジネス カレンダから例外をすべて削除します。
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
ビジネス カレンダのマクロについて
CreateBusinessCalendarPattern
このマクロを使用すると、ビジネス カレンダのパターンを作成できます。パターン
は、カレンダ全体およびカレンダが基づく基本構造単位(たとえば、週、月、四半
期、年)を対象とした営業日および休業日のテンプレートです。
注: 現時点では、週単位のパターンのみがサポートされています。各曜日を営業日ま
たは休業日と定義できます。特定の営業日を休業日(例えば祝日)にするには、
CreateException マクロを使用できます(「CreateException」を参照)。
このマクロを実行すると、カレンダのパターンが作成され、パターンに関する情報
が DBC.BusinessCalendarPattern テーブルに格納されます。
CreateBusinessCalendarPattern、必須パラメータ
パラメータ
データ タイプ
書式
説明
CalendarName
VARCHAR(256)
CHARACTER SET
UNICODE
X(128)
ビジネス カレンダの名前。シス
テム ビジネス カレンダの場合
は、Teradata、ISO、または
COMPATIBLE である必要があり
ます。
NOT CASESPECIFIC
NOT NULL
DayName
CHAR(10)
X(10)
カレンダ曜日の名前。SUNDAY、
MONDAY、TUESDAY、
WEDNESDAY、THURSDAY、
FRIDAY、SATURDAY のいずれか
である必要があります。
Pattern
CHAR(5)
X(5)
カレンダ曜日のパターン。ON (営
業日)または OFF (休業日)である
必要があります。
PatternComment
VARCHAR(2048)
X(1024)
カレンダ曜日のパターン(ON また
は OFF)の理由または根拠。
例: 休業日の設定
次の例では、Teradata ビジネス カレンダの各週の土曜日と日曜日を休業日と定義し
(休業日はステータスが OFF となります)、この情報を DBC.BusinessCalendarPattern
テーブルに追加しています。
注: デフォルトでは、Teradata ビジネス カレンダの週の各日が営業日となっています。
EXEC DBC.CreateBusinessCalendarPattern
('TERADATA', ‘SATURDAY’,’OFF’, ‘Non-work Day’);
EXEC DBC.CreateBusinessCalendarPattern
('TERADATA', ‘SUNDAY’,’OFF’, ‘Non-work Day’);
SQL 関数、演算子、式および述部
335
第 8 章 ビジネス カレンダ
ビジネス カレンダのマクロについて
例: 営業日の指定
次の例では、SUNDAY および MONDAY を営業日に指定して、ISO ビジネス カレン
ダを変更します。
EXEC DBC.CreateBusinessCalendarPattern
('ISO', 'SUNDAY','ON', 'Work Day');
EXEC DBC.CreateBusinessCalendarPattern
('ISO', 'MONDAY', 'ON', 'Work Day');
CreateException
このマクロを使用すると、特定のビジネス カレンダの例外リストを定義できます。
このリストでは、カレンダの日のうち、カレンダに対して定義されているパターン
の例外となる日(日付順)をすべて特定します。
このマクロを実行すると、リストの例外がカレンダおよび
DBC.BusinessCalendarException テーブルに挿入されます。
すでに例外となっている特定の日付に対して例外を定義しようとすると 、エラーが
返されます。既存の例外を置き換えるには、まず既存の例外を削除し、その後、目
的の日付について新しい例外を再定義する必要があります。
CreateException、必須パラメータ
パラメータ
書式
データ タイプ
説明
CalendarName
VARCHAR(256)
CHARACTER SET
UNICODE
X(128)
ビジネス カレンダの名前。シス
テム ビジネス カレンダの場合
は、Teradata、ISO、または
COMPATIBLE である必要があ
ります。
NOT CASESPECIFIC
NOT NULL
ExceptionIndicator
CHAR(5)
X(5)
例外の日のタイプ。ON (営業
日)または OFF (休業日)である必
要があります。
ExceptionDate
DATE
YYYY-MM-DD
例外の日付(その例外がすでに作
成されている日以外)。
PatternComment
VARCHAR(2048)
X(1024)
カレンダ曜日のパターン(ON ま
たは OFF)の理由または根拠。
CreateException、使用上の注意
CalendarPeriod 境界を超える例外を挿入しようとすると、挿入がアボートします。
例外としてすでに定義されている日に対して例外を挿入する場合は 、その日につい
ての既存の例外を削除した後、新しい例外に置き換える必要があります。
336
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
ビジネス カレンダのマクロについて
例: OFF および ON 例外の定義
この例では、Teradata ビジネス カレンダに OFF と ON の例外を定義し、それらの
情報を DBC.BusinessCalendarException テーブルに追加しています。OFF ステータ
スの日は休業日です。ON ステータスの日は営業日です。
EXEC DBC.CreateException
('Teradata', ’OFF’, DATE '2008-03-03', 'Holiday');
EXEC DBC.CreateException
('Teradata', ’ON’, DATE '2008-06-07', 'Holiday make up day');
例外が 2 つ、Teradata ビジネス カレンダに挿入されます。最初の例外は、2008 年
3 月 3 日が休業日になったことを示しています(コメントに祝祭日であると注記され
ています)。2 つ目の例外は、2008 年 6 月 7 日が営業日になったことを示していま
す(前回の祝祭日を設けるための日であるとコメントに注記されています)。
Teradata カレンダの CalendarPeriod は、1900 年 1 月 1 日から 2100 年 12 月 31
日までです。CalendarPeriod 境界を超えた祝日を挿入しようとすると、挿入がア
ボートします。
DeleteException
このマクロを使用すると、特定のビジネス カレンダから特定の例外を削除できま
す。例外を削除すると、その例外日のステータスが、カレンダのパターンでその日
に対して定義されているステータスに自動的に戻ります。
このマクロを実行すると、例外がカレンダおよび DBC.BusinessCalendarException
テーブルから削除されます。
カレンダから例外をすべて削除する必要がある場合は、DeleteAllExceptions マクロ
を使用します(「DeleteAllExceptions」を参照)。
DeleteException、必須パラメータ
パラメータ
データ タイプ
書式
説明
CalendarName
VARCHAR(256)
CHARACTER SET
UNICODE
X(128)
ビジネス カレンダの名前。システ
ム ビジネス カレンダの場合は、
Teradata、ISO、または
COMPATIBLE である必要がありま
す。
YY/MM/DD
例外の日付(その例外がすでに作成
されている日以外)。
NOT CASESPECIFIC
NOT NULL
ExceptionDate
SQL 関数、演算子、式および述部
DATE
337
第 8 章 ビジネス カレンダ
ビジネス カレンダのテーブルについて
例: 例外の削除。
この例では、2009 年 1 月 1 日の日付に対する例外を ISO ビジネス カレンダおよび
DBC.BusinessCalendarException テーブルから削除しています。
EXEC DBC.DeleteException('ISO', DATE '2009-01-01');
DeleteAllExceptions
このマクロを使用すると、特定のビジネス カレンダからすべての例外を削除できま
す。すべての例外を削除すると、すべての例外日のステータスが、カレンダのパター
ンのそれぞれの日に対して定義されているステータスに自動的に戻ります。
このマクロを実行すると、すべての例外がカレンダおよび
DBC.BusinessCalendarException テーブルから削除されます。
カレンダから特定の例外を削除する必要がある場合は、DeleteException マクロを使
用します(「DeleteException」を参照)。
DeleteAllExceptions、必須パラメータ
パラメータ
データ タイプ
CalendarName VARCHAR(128)
CHARACTER SET
UNICODE
書式
説明
X(128)
ビジネス カレンダの名前。システム
ビジネス カレンダの場合は、
Teradata、ISO、または
COMPATIBLE である必要があります。
NOT CASESPECIFIC
NOT NULL
例: ISO ビジネス カレンダからの例外の削除
この例では、すべての例外を ISO ビジネス カレンダおよび
DBC.BusinessCalendarException テーブルから削除しています。
EXEC DBC.DeleteAllExceptions('ISO');
ビジネス カレンダのテーブルについて
ビジネス カレンダのテーブルを問合わせると、ビジネス関連のカレンダ情報を確認
できます。
DBC.BusinessCalendarPattern テーブル
この表には、営業日と休業日のパターンに関するカレンダ情報を記録します。
338
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
ビジネス カレンダのテーブルについて
列名
列の説明
CalendarName
ビジネス カレンダの名前。
PatternType
週単位、月単位、四半期単位、または年単位としてパターン
を特定します。現時点では、週単位のパターンのみがサポー
トされています。パターン"W"は、週単位のパターンを意味
します。
DayNumber
週の中の日には 1~7 の番号が付けられており、開始は日曜
日(1)、終了は土曜日(7)です。この表には、日付ごとに行が
1 行あり、Pattern 列には日付の ON/OFF ステータスが格納
されます。
Pattern
週単位のパターンでは、1 または 0 に設定された 7 つの行を
記述します。DayNumber ごとに、営業日(1)または休業日(0)
のどちらかを示すステータスをこの列に格納します。
PatternComment
パターンの説明。
CreatorName
パターンを作成または変更したユーザーの名前。システム定
義のビジネス カレンダの場合、これは DBC になります。
LastModified
最後にパターンを変更したときのタイムスタンプ。
DBC.BusinessCalendarException テーブル
この表には、営業日と休業日のパターンの例外となる日付のリストが含まれています。
列名
列の説明
CalendarName
例外が表示されるビジネス カレンダの名前。
ExceptionIndicator
値 0 は ExceptionDate が休業日であることを示し、値 1 は
ExceptionDate が営業日であることを示します。
ExceptionDate
ExceptionDate は Teradata カレンダの範囲内(1900 年 1 月
1 日~2100 年 12 月 31 日)に含まれる必要があります。こ
の期間から外れた場合、ExceptionDate は受け入れられませ
ん。
ExceptionReason
例外の理由。例えば、2012 年 12 月 25 日(火曜日)は通常で
は営業日ですが、クリスマス休暇でもあります。このため、
ExceptionReason は「Christmas」になります。
ExceptionReason は NULL でもかまいません。
CreatorName
例外を作成したユーザーの名前。
CreationTime
例外を作成したときのタイムスタンプ。
例外には 2 つのタイプがあります。
SQL 関数、演算子、式および述部
339
第 8 章 ビジネス カレンダ
ビジネス カレンダのビューについて
• OFF 例外: 典型的な営業日が休日になる(たとえば、2011 年 9 月 5 日月曜日は
Labor Day で休日)。
• ON 例外: 典型的な休日が営業日になる(たとえば、事業所の職員全員が 2011 年 7
月 30 日土曜日に業務に就くことを求められる)。
OFF 例外が営業日にあたるかどうかや、ON 例外が休業日にあたるかどうかを確認す
る必要はありません。例外を設定して、ExceptionReason を指定するだけでかまい
ません。たとえば、7 月 4 日の月曜日は祝祭日ですが、Barbeque Bonanza ストアは
営業日であり、ExceptionReason は独立記念日セールになります。
ビジネス カレンダのビューについて
ビジネス カレンダのビューを問合わせることで、ビジネスに関連する情報(週の最初
の営業日など)を取得できます。
Sys_Calendar.BusinessCalendarExceptions
このビューからは、カレンダに定義した例外(普段は営業日にあたる月曜日の祝祭日
など)についての情報が得られます。このビューを問合わせると、例外を確認できま
す。
ビューの列名
説明
データ タイプ
書式
CalendarName
カレンダの名前。
VARCHAR(128)
X(128)
ExceptionIndicator 営業日には ON、休業日には OFF を返し VARCHAR(3)
ます。
X(3)
ExceptionDate
カレンダに設定された例外日。
DATE
YY/MM/DD
ExceptionReason
例外の理由。
VARCHAR(1024)
X(1024)
CreatorName
例外を作成したユーザー。
VARCHAR(128)
X(128)
CreationTime
例外を作成したときのタイムスタンプ。 TIMESTAMP(0)
YYYY-MM-DDBHH:MI:SS
Sys_Calendar.BusinessCalendarPatterns
このビューからは、カレンダに定義したパターン(平日/週末のパターンなど)につい
ての情報が得られます。
ビューの列名
説明
データ タイプ
書式
CalendarName
カレンダの名前。
VARCHAR(128)
X(128)
DayName
曜日名。たとえば金曜日。
VARCHAR(9)
X(9)
Pattern
ON または OFF パターンの設定。
VARCHAR(3)
X(3)
340
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
ビジネス カレンダのビューについて
ビューの列名
説明
データ タイプ
書式
PatternComment
パターンの各日のコメント。
VARCHAR(1024)
X(1024)
CreatorName
パターンを作成したユーザー。
VARCHAR(128)
X(128)
LastModified
最後にパターンを変更したときのタイム TIMESTAMP(0)
スタンプ。
YYYY-MM-DD:HH:MI:SS
Sys_Calendar.BusinessCalendar
この Sys_Calendar ビューは、システム定義された 3 つのビジネス カレンダにビジ
ネス機能を提供します。
ビューの列名
説明
データ タイプ
書式
Calendar_Date
日付。
DATE
YY/MM/DD
Day_of_Week
INTEGER 値。範囲は 1~7。
INTEGER
-(10)9
Day_of_Month
整数値。範囲は 1~31。
INTEGER
-(10)9
Day_of_Year
INTEGER 値。範囲は 1~366。
INTEGER
-(10)9
Day_of_Calendar
カレンダの初日からの日数。
INTEGER
-(10)9
Weekday_of_Month
その月の、n 番目の平日が現れる位置
(1-5)。
INTEGER
-(10)9
Week_of_Month
その月の週の番号。範囲は 0~5。
INTEGER
-(10)9
Week_of_Quarter
四半期の週の番号。範囲は 0~14。
INTEGER
-(10)9
Week_of_Year
その年の週の番号。範囲は 0~53。
INTEGER
-(10)9
Week_of_Calendar
カレンダ内の、特定の日付が現れる週の INTEGER
番号。
-(10)9
Month_of_Quarter
その四半期の、特定の日付が現れる月の INTEGER
番号。
-(10)9
Month_of_Year
その年の、特定の日付が現れる月の番号。 INTEGER
-(10)9
Month_of_Calendar
カレンダ内の、特定の日付が現れる月の INTEGER
番号。
-(10)9
Quarter_of_Year
特定の日付が現れる、年の四半期。
INTEGER
-(10)9
Quarter_of_Calendar
特定の日付が現れる、カレンダの四半期 INTEGER
の番号。
-(10)9
Year_of_Calendar
特定の日付が現れる、カレンダの年の番 INTEGER
号。
-(10)9
SQL 関数、演算子、式および述部
341
第 8 章 ビジネス カレンダ
ビジネス カレンダのビューについて
ビューの列名
説明
データ タイプ
書式
WeekEnd
特定の日付のある週の終わり。
DATE
YY/MM/DD
WeekBegin
特定の日付のある週の初め。
DATE
YY/MM/DD
MonthBegin
特定の日付のある月の初め。
DATE
YY/MM/DD
MonthEnd
特定の日付のある月の終わり。
DATE
YY/MM/DD
QuarterBegin
特定の日付のある四半期の初め。
DATE
YY/MM/DD
QuarterEnd
特定の日付のある四半期の終わり。
DATE
YY/MM/DD
YearBegin
特定の日付のある年の初め。
DATE
YY/MM/DD
YearEnd
特定の日付のある年の終わり。
DATE
YY/MM/DD
IsBusinessDay
特定の日付が営業日であるかどうか。
BYNET
-(3)9
BusinessWeekBegin
特定の日付が現れる週の最初の営業日。 DATE
YY/MM/DD
BusinessWeekEnd
特定の日付が現れる週の最後の営業日。 DATE
YY/MM/DD
BusinessMonthBegin
特定の日付が現れる月の最初の営業日。 DATE
YY/MM/DD
BusinessMonthEnd
特定の日付が現れる月の最後の営業日。 DATE
YY/MM/DD
BusinessQuarterBegin
特定の日付が現れる四半期の最初の営業 DATE
日。
YY/MM/DD
BusinessQuarterEnd
特定の日付が現れる四半期の最後の営業 DATE
日。
YY/MM/DD
BusinessYearBegin
特定の日付が現れる年の最初の営業日。 DATE
YY/MM/DD
BusinessYearEnd
特定の日付が現れる年の最後の営業日。 DATE
YY/MM/DD
例: ISO カレンダを使用した曜日の問合わせ
次の問合わせは、ISO カレンダを使用して曜日を返します。
Set session calendar = iso;
Sel day_of_week from Sys_Calendar.Calendar where calendar_date = date
'2011-01-01';
day_of_week
----------6
例
例: ISO カレンダを使用した曜日の問合わせ
次の問合わせは、ISO カレンダを使用して曜日を返します。
342
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
ビジネス カレンダのビューについて
Set session calendar = iso;
Sel day_of_week from Sys_Calendar.Calendar where calendar_date = date
'2011-01-01';
day_of_week
----------6
例: COMPATIBLE カレンダを使用した曜日の問合わせ
次の問合わせは、COMPATIBLE カレンダを使用して曜日を返します。
Set session calendar = compatible;
Sel day_of_week from Sys_Calendar.Calendar where calendar_date = date
'2011-01-01';
day_of_week
----------1
例: ISO カレンダを使用した週初めの問合わせ
次の問合わせは、ISO カレンダを使用して週初めを返します。
Set session calendar = iso;
Sel weekBegin from Sys_Calendar.BusinessCalendar where calendar_date =
date '2011-01-01';
WeekBegin
----------10/12/27
例: COMPATIBLE カレンダを使用した週初めの問合わせ
次の問合わせは、COMPATIBLE カレンダを使用して週初めを返します。
Set session calendar = compatible;
Sel weekBegin from Sys_Calendar.BusinessCalendar where calendar_date =
date '2011-01-01';
WeekBegin
----------11/01/01
例: OFF 例外日の追加
デフォルトでは、ISO カレンダの月曜日は営業日です。次の問合わせでは、2007 年
1 月 1 日月曜日に OFF 例外を追加します。
Exec DBC.CreateException('ISO', 'OFF', date '2007-01-01',
Day');
'Newyear
次の問合わせでは、2007 年 1 月 1 日の後の、次の営業日を返します。
SQL 関数、演算子、式および述部
343
第 8 章 ビジネス カレンダ
ビジネス カレンダ関数
Sel BusinessWeekBegin from Sys_Calendar.BusinessCalendar where
calendar_date = date '2007-01-01';
BusinessWeekBegin
----------07/01/02
例: 週初めおよび週番号の問合わせ
次の問合わせは、2009 年の週初めと週番号を返します。このとき、セッションに設
定されているカレンダがないと仮定します。このセッションでは、デフォルトのビ
ジネス カレンダである“Teradata”が使用されます。
SEL WeekBegin, week_of_year FROM Sys_Calendar.BusinessCalendar WHERE
calendar_date = DATE '2009-03-15';
Week_begin
week_of_year
----------------------------09/03/15
11
ビジネス カレンダ関数
ビジネス カレンダ関数について
SQL 文内で UDF を指定できる部分(INSERT 文、UPDATE 文、DELETE 文、MERGE
文、SELECT 文など)にはビジネス カレンダ関数を指定できます。
ビジネス カレンダ関数には、次の事項が適用されます。
• カレンダ名を指定していないと、そのカレンダのデフォルトはセッションのカレ
ンダになります。
• 年に関連するすべての関数(MonthNumber_Of_Year など)は、その年の 1 月 1 日
から相対的に計算されます。
• カレンダに関連するすべての関数(DayNumber_Of_Calendar など)は、カレンダの
始まる 1900-01-01 から相対的に計算されます。
• これらの関数は、DML 文内、および DDL 文内の CHECK CONSTRAINTS 内のどこ
にでも指定できます。それ以外にも、SQL 文内で UDF を指定できるすべての場所
でも、これらの関数を指定できます。
• ビジネス カレンダ関数のすべての定義は、TD_SYSFNLIB データベースに格納さ
れています。SELECT 文で使用するビジネス カレンダ関数の書式とタイトルは、
通常の UDF スタイルに準じます。
• これらの関数は、すべての Teradata ユーザーが使用可能なものであり、権限は必
要ありません。
• 関数内部では、すべての計算が UTC で行なわれます(入力のタイプが、TIMESTAMP
または TIMESTAMP WITH TIME ZONE の場合)。
344
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
ビジネス カレンダ関数
ビジネス カレンダ関数を使用するための前提条件
これらの関数を使用する前に、データベース初期化プログラム(DIP)ユーティリティ
を実行し、DIPSYSFNC スクリプトを実行する必要があります。DIPALL または
DIPSYSFNC スクリプトにより、カレンダ関数が SYSLIB データベース内に作成され
ます。DIP ユーティリティの詳細は、<ユーティリティ、B035-1102>を参照してく
ださい。
ビジネス カレンダ関数と同じ名前の、ユーザーが開発した UDF を持っている場合
は、ビジネス カレンダ関数を呼び出す前に、ユーザーが開発した UDF を通常の UDF
検索パスから削除する必要があります。現在のデータベースでビジネス カレンダ関
数を見つけられない場合、Teradata Database は TD_SYSFNLIB データベースで関数
を検索します。この代わりに、完全修飾した構文
(TD_SYSFNLIB.calendar_function_name)を使用して、カレンダ関数を呼び出すこと
もできます。
例: 全四半期の第 1 週の累積売上げ
この例では、全四半期の第 1 週の品目の累積売上げを検索します。カレンダ設定ご
とに結果を表示します。
SEL Item_Code, SUM(Sale_Amt) FROM Sales_Tbl
WHERE WeekNumber_Of_Quarter(Sale_Date) = 1
GROUP BY Item_Code;
SET SESSION calendar = Teradata;
Item_Code
SUM(Sale_Amt
)
101
225
102
120
SET SESSION calendar = Compatible
Item_Code
SUM(Sale_Amt
)
101
245
102
100
SET SESSION calendar = ISO;
Item_Code
SUM(Sale_Amt
)
101
135
102
30
Sales_Tbl
SQL 関数、演算子、式および述部
345
第 8 章 ビジネス カレンダ
ビジネス カレンダ関数
Item_Cod Sale_Am Sale_Date
e
t
101
10
2008-12-30
101
15
2008-12-31
101
20
2009-01-01
101
25
2009-01-02
101
30
2009-01-03
101
35
2009-01-04
101
40
2009-01-05
101
45
2009-01-06
101
50
2009-01-07
101
55
2009-01-08
102
10
2009-01-01
102
20
2009-01-03
102
30
2009-01-05
102
40
2009-01-07
102
50
2009-01-09
Jan 2009 Calendar
S
M T
W T
F
S
1
2
3
8
9
1
0
4
5
6
7
1
1
1
2
13 1
4
15 1
6
1
7
1
8
1
9
20 2
1
22 2
3
2
4
2
5
2
6
27 2
8
29 3
0
3
1
例
例: 全四半期の第 1 週の累積売上げ - Teradata カレンダ
この例では、Teradata カレンダを使用して、全四半期の第 1 週の累積売上げをどの
ように集計するかを示します。
SET SESSION calendar = Teradata;
SEL Item_Code, SUM(Sale_Amt) FROM Sales_Tbl
346
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
ビジネス カレンダ関数
WHERE WeekNumber_Of_Quarter(Sale_Date) = 1
GROUP BY Item_Code;
SET SESSION calendar = Teradata;
Item_Code
SUM(Sale_Amt
)
101
225
102
120
Sales_Tbl
Item_Code Sale_Amt
Sale_Date
101
10
2008-12-3
0
101
15
2008-12-3
1
101
20
2009-01-0
1
101
25
2009-01-0
2
101
30
2009-01-0
3
101
35
2009-01-0
4
101
40
2009-01-0
5
101
45
2009-01-0
6
101
50
2009-01-0
7
101
55
2009-01-0
8
102
10
2009-01-0
1
102
20
2009-01-0
3
SQL 関数、演算子、式および述部
347
第 8 章 ビジネス カレンダ
ビジネス カレンダ関数
102
30
2009-01-0
5
102
40
2009-01-0
7
102
50
2009-01-0
9
Jan 2009 Calendar
S
M
T
W
T
F
S
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
例: 全四半期の第 1 週の累積売上げ - ISO カレンダ
この例では、ISO カレンダを使用して、全四半期の第 1 週の累積売上げをどのよう
に集計するかを示します。
SET SESSION calendar = ISO;
SEL Item_Code, SUM(Sale_Amt) FROM Sales_Tbl
WHERE WeekNumber_Of_Quarter(Sale_Date) = 1
GROUP BY Item_Code;
SET SESSION calendar = ISO;
Item_Code
SUM(Sale_Amt
)
101
135
102
30
Sales_Tbl
348
Item_Code
Sale_Amt
Sale_Date
101
10
2008-12-30
101
15
2008-12-31
101
20
2009-01-01
101
25
2009-01-02
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
ビジネス カレンダ関数
101
30
2009-01-03
101
35
2009-01-04
101
40
2009-01-05
101
45
2009-01-06
101
50
2009-01-07
101
55
2009-01-08
102
10
2009-01-01
102
20
2009-01-03
102
30
2009-01-05
102
40
2009-01-07
102
50
2009-01-09
Jan 2009 Calendar
S
4
M
5
T
6
W
7
T
F
S
1
2
3
8
9
10
11 12 13 14 15 16 17
18 19 20 21 22 23 24
25 26 27 28 29 30 31
例: 全四半期の第 1 週の累積売上げ - COMPATIBLE カレンダ
この例では、COMPATIBLE カレンダを使用して、全四半期の第 1 週の累積売上げを
どのように集計するかを示します。
SET SESSION calendar = Compatible;
SEL Item_Code, SUM(Sale_Amt) FROM Sales_Tbl
WHERE WeekNumber_Of_Quarter(Sale_Date) = 1
GROUP BY Item_Code;
SET SESSION calendar = Compatible;
Item_Code
SUM(Sale_Amt
)
101
245
102
100
SQL 関数、演算子、式および述部
349
第 8 章 ビジネス カレンダ
ビジネス カレンダ関数
Sales_Tbl
Item_Co Sale_Am Sale_Date
de
t
101
10
2008-1230
101
15
2008-1231
101
20
2009-0101
101
25
2009-0102
101
30
2009-0103
101
35
2009-0104
101
40
2009-0105
101
45
2009-0106
101
50
2009-0107
101
55
2009-0108
102
10
2009-0101
102
20
2009-0103
102
30
2009-0105
102
40
2009-0107
102
50
2009-0109
Jan 2009 Calendar
S
350
M
T
W
T
F
S
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
ビジネス カレンダ関数
4
5
6
7
1
2
3
8
9
10
11 12 13
14 15
16 17
18 19 20
21 22
23 24
25 26 27
28 29
30 31
例: 全四半期の第 1 週の平日累積売上げ - Teradata カレンダ
この例では、全四半期の第 1 週の平日における品目の累積売上げを検索します。
SET SESSION calendar = Teradata;
/* Setting SUNDAY and SATURDAY as weekend days. */
exec dbc.createbusinesscalendarpattern('teradata','SUNDAY','OFF',);
exec dbc.createbusinesscalendarpattern('teradata','SATURDAY','OFF',);
SEL Item_Code, SUM(Sale_Amt) FROM Sales_Tbl,
Sys_Calendar.BusinessCalendar
WHERE WeekNumber_Of_Quarter(Sale_Date) = 1
AND calendar_date = Sale_Date
AND IsBusinessDay = 1
GROUP BY Item_Code
ORDER BY 1;
SET SESSION calendar = Teradata;
Item_Code
SUM(Sale_Amt)
101
190
102
120
Sales_Tbl
Item_Cod Sale_Amt
e
Sale_Date
101
10
2008-12-3
0
101
15
2008-12-3
1
101
20
2009-01-0
1
101
25
2009-01-0
2
SQL 関数、演算子、式および述部
351
第 8 章 ビジネス カレンダ
ビジネス カレンダ関数
101
30
2009-01-0
3
101
35
2009-01-0
4
101
40
2009-01-0
5
101
45
2009-01-0
6
101
50
2009-01-0
7
101
55
2009-01-0
8
102
10
2009-01-0
1
102
20
2009-01-0
3
102
30
2009-01-0
5
102
40
2009-01-0
7
102
50
2009-01-0
9
Jan 2009 Calendar
S
M
T
W
T
F
S
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
例: 2011 年 9 月の第 1 週の表示
この例では、ビジネス カレンダ設定ごとに 2011 年 9 月の第 1 週を表示します。
SEL calendar_date, week_of_month FROM Sys_Calendar.BusinessCalendar
WHERE week_of_month = 1
AND month_of_year = 9
352
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
ビジネス カレンダ関数
AND year_of_calendar = 2011
ORDER BY 1;
SET SESSION calendar = ISO;
Sep-2011 Calendar
S
M
T
W
T
F
S
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
calendar_date
------------11/08/29
11/08/30
11/08/31
11/09/01
11/09/02
11/09/03
week_of_month
------------1
1
1
1
1
1
11/09/04 1
SET SESSION calendar = Teradata;
Sep-2011 Calendar
S
M
T
W
T
F
S
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
calendar_date
------------11/09/04
11/09/05
11/09/06
11/09/07
11/09/08
11/09/09
SQL 関数、演算子、式および述部
week_of_month
------------1
1
1
1
1
1
353
第 8 章 ビジネス カレンダ
ビジネス カレンダ関数
11/09/10
1
SET SESSION calendar = Compatible;
Sep-2011 Calendar
S
M
T
W
T
F
S
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
calendar_date
------------11/09/01
11/09/02
11/09/03
11/09/04
11/09/05
11/09/06
11/09/07
week_of_month
------------1
1
1
1
1
1
1
例: 月の毎週初めの在庫ステータス
次の例では、ビジネス カレンダ設定ごとに 2011 年 9 月の毎週初めの在庫ステータ
スを表示します。
SEL Item, BEGIN(week_duration) AS WeekBegin, Inventory
FROM Inventory_Tbl
EXPAND ON Duration AS week_duration
BY ANCHOR WEEK_BEGIN;
Inventory_Tbl
354
Item
Duration
Inventor
y
101
2011-09-01,
2011-09-05
12
101
2011-09-05,
2011-09-12
18
101
2011-09-12,
2011-09-18
15
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
ビジネス カレンダ関数
101
2011-09-18,
2011-09-21
11
Sep-2011 Calendar
S
M
T
W
T
F
S
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
SET SESSION CALENDAR = Teradata;
Item
WeekBegin
Inventory
101
2011-09-04
12
101
2011-09-11
18
101
2011-09-18
11
SET SESSION CALENDAR = ISO;
Item
WeekBegin
Inventory
101
2011-09-05
18
101
2011-09-12
15
101
2011-09-19
11
SET SESSION CALENDAR = Compatible;
Item
WeekBegin
Inventory
101
2011-09-03
12
101
2011-09-10
18
101
2011-09-17
15
例: 2004 年の各四半期の週数
次の例では、2004 年の各四半期の週の数を表示します。
SEL quarter_of_year, MAX(week_of_quarter)
FROM Sys_Calendar.BusinessCalendar
WHERE year_of_calendar=2004
GROUP BY 1 ORDER BY 1;
SQL 関数、演算子、式および述部
355
第 8 章 ビジネス カレンダ
ビジネス カレンダ関数
SET SESSION CALENDAR = Teradata;
Quarter_of_Y Maximum(Week_of_Qu
ear
arter)
1
13
2
13
3
13
4
13
SET SESSION CALENDAR = ISO;
Quarter_of_Ye Maximum(Week_of_Qua
ar
rter)
1
13
2
13
3
13
4
14
SET SESSION CALENDAR =
COMPATIBLE;
Quarter_of_Y Maximum(Week_of_Qu
ear
arter)
1
13
2
13
3
14
4
14
例: 四半期別の売上げ
次の例では、ビジネス カレンダ設定ごとに四半期別の売上げをどのように計算する
かを示します。
SEL QuarterNumber_Of_Year(Sale_Date) Quarter_No,
Item_Code, SUM(Sale_Amt) FROM Sales_Tbl
GROUP BY 1,2
ORDER BY 1,2;
SET SESSION calendar = ISO;
Quarter_No Item_Code SUM(Sale_Amt
)
356
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
ビジネス カレンダ関数
1
101
325
1
102
150
SET SESSION calendar = Teradata;
Quarter_No Item_Code SUM(Sale_Amt)
1
101
300
1
102
150
4
101
25
SET SESSION calendar = COMPATIBLE;
Quarter_No Item_Code SUM(Sale_Amt
)
1
101
300
1
102
150
4
101
25
Sales_Tbl
Item_Co
de
Sale_Am Sale_Date
t
101
10
2008-12-3
0
101
15
2008-12-3
1
101
20
2009-01-0
1
101
25
2009-01-0
2
101
30
2009-01-0
3
101
35
2009-01-0
4
101
40
2009-01-0
5
SQL 関数、演算子、式および述部
357
第 8 章 ビジネス カレンダ
td_week_begin
101
45
2009-01-0
6
101
50
2009-01-0
7
101
55
2009-01-0
8
102
10
2009-01-0
1
102
20
2009-01-0
3
102
30
2009-01-0
5
102
40
2009-01-0
7
102
50
2009-01-0
9
Jan 2009 Calendar
S
M
T
W
T
F
S
29
30
31
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
td_week_begin
目的
expression_1.に指定されている DATE または TIMESTAMP の直前にあたる週初めを
返します。
構文
td_week_begin
TD_SYSFNLIB.
358
( expression_1
)
,
calendar_name
NULL
,
expression_2
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
td_week_begin
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression_1
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
expression_1 が DATE である場合は、expression_2 を指定できません。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
expression_2
TIME、TIME WITH TIME ZONE、NULL のいずれかの値。NULL を指定した場合、
TIME は 00:00:00+00:00 であるとみなされます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義
されます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
戻り値は、次のいずれかのデータ タイプです。
SQL 関数、演算子、式および述部
359
第 8 章 ビジネス カレンダ
td_week_end
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
例: DATE または TIMESTAMP より前の週の問合わせ
次の SQL 文を実行します。
SELECT TD_WEEK_BEGIN(TIMESTAMP'2012-01-15
12:00:00+02:00','ISO',TIME'05:00:00');
2012-01-09 07:00:00+02:00 を返します。
td_week_end
目的
expression_1 に指定されている DATE または TIMESTAMP の直後にあたる週末を返
します。
構文
td_week_end
( expression_1
TD_SYSFNLIB.
)
,
calendar_name
NULL
,
expression_2
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression_1
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
expression_1 が DATE である場合は、expression_2 を指定できません。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
360
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
td_week_end
expression_2
TIME、TIME WITH TIME ZONE、NULL のいずれかの値。NULL を指定した場合、
TIME は 00:00:00+00:00 であるとみなされます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義
されます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
戻り値は、次のいずれかのデータ タイプです。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
例: DATE または TIMESTAMP の後の週末の問合わせ
次の SQL 文を実行します。
SELECT TD_WEEK_END(timestamp'2012-05-08 10:00:00');
2012-05-12 23:59:59 を返します。
カレンダを指定していないため、セッション カレンダ、つまりこの例では TERADATA
が使用されることになります。
SQL 関数、演算子、式および述部
361
第 8 章 ビジネス カレンダ
td_sunday
td_sunday
目的
expression_1 に指定されている DATE または TIMESTAMP の直前にあたる日曜日を
返します。
構文
td_sunday
( expression_1
TD_SYSFNLIB.
)
,
calendar_name
NULL
,
expression_2
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression_1
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
expression_1 が DATE である場合は、expression_2 を指定できません。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
expression_2
TIME、TIME WITH TIME ZONE、NULL のいずれかの値。NULL を指定した場合、
TIME は 00:00:00+00:00 であるとみなされます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
この関数はオーバーロードされ、1~3 個の引数を指定して呼び出すことができます。
第 1 引数 expression は、次に示すデータ型で定義されます。
362
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
td_monday
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義
されます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
戻り値は、次のいずれかのデータ タイプです。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
例: DATE または TIMESTAMP より前の日曜日の問合わせ
次の SQL 文を実行します。
SELECT TD_SUNDAY(timestamp'2012-05-08 10:00:00');
2012-05-06 00:00:00 を返します。
カレンダを指定していないため、セッション カレンダ、つまりこの場合は TERADATA
が使用されることになります。
td_monday
目的
expression_1 に指定されている DATE または TIMESTAMP の直前にあたる月曜日を
返します。
構文
td_monday
TD_SYSFNLIB.
SQL 関数、演算子、式および述部
( expression_1
)
,
calendar_name
NULL
,
expression_2
363
第 8 章 ビジネス カレンダ
td_monday
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression_1
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
expression_1 が DATE である場合は、expression_2 を指定できません。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
expression_2
TIME、TIME WITH TIME ZONE、NULL のいずれかの値。NULL を指定した場合、
TIME は 00:00:00+00:00 であるとみなされます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
この関数はオーバーロードされ、1~3 個の引数を指定して呼び出すことができます。
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義さ
れます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
364
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
td_tuesday
結果
戻り値は、次のいずれかのデータ タイプです。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
例: DATE または TIMESTAMP より前の月曜日の問合わせ
次の SQL 文を実行します。
TD_MONDAY(Date,'TERADATA');
12/05/07 を返します。
td_tuesday
目的
expression_1 に指定されている DATE または TIMESTAMP の直前にあたる火曜日を
返します。
構文
td_tuesday
TD_SYSFNLIB.
( expression_1
)
,
calendar_name
NULL
,
expression_2
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression_1
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
expression_1 が DATE である場合は、expression_2 を指定できません。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
SQL 関数、演算子、式および述部
365
第 8 章 ビジネス カレンダ
td_tuesday
NULL
セッションのビジネス カレンダ。
expression_2
TIME、TIME WITH TIME ZONE、NULL のいずれかの値。NULL を指定した場合、
TIME は 00:00:00+00:00 であるとみなされます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義さ
れます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
戻り値は、次のいずれかのデータ タイプです。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
例: DATE または TIMESTAMP より前の火曜日の問合わせ
次の SQL 文を実行します。
SELECT TD_TUESDAY(TIMESTAMP'2012-05-08 10:00:00');
2012-05-08 00:00:00 を返します。
カレンダを指定していないため、セッション カレンダ、つまりこの場合は TERADATA
が使用されることになります。
366
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
td_wednesday
td_wednesday
目的
expression_1 に指定されている DATE または TIMESTAMP の直前にあたる水曜日を
返します。
構文
td_wednesday
( expression_1
TD_SYSFNLIB.
)
,
calendar_name
NULL
,
expression_2
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression_1
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
expression_1 が DATE である場合は、expression_2 を指定できません。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
expression_2
TIME、TIME WITH TIME ZONE、NULL のいずれかの値。NULL を指定した場合、
TIME は 00:00:00+00:00 であるとみなされます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
SQL 関数、演算子、式および述部
367
第 8 章 ビジネス カレンダ
td_thursday
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義さ
れます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
戻り値は、次のいずれかのデータ タイプです。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
例: DATE または TIMESTAMP より前の水曜日の問合わせ
次の SQL 文を実行します。
SELECT TD_WEDNESDAY(TIMESTAMP'2012-05-08 10:00:00+01:00','ISO');
2012-05-02 01:00:00+01:00 を返します。
td_thursday
目的
expression_1 に指定されている DATE または TIMESTAMP の直前にあたる木曜日を
返します。
構文
td_thursday
TD_SYSFNLIB.
( expression_1
)
,
calendar_name
NULL
,
expression_2
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
368
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
td_thursday
expression_1
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
expression_1 が DATE である場合は、expression_2 を指定できません。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
expression_2
TIME、TIME WITH TIME ZONE、NULL のいずれかの値。NULL を指定した場合、
TIME は 00:00:00+00:00 であるとみなされます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
この関数はオーバーロードされ、1~3 個の引数を指定して呼び出すことができます。
第 1 引数は、次のデータ タイプのいずれかになります。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数は、次のシステム定義のカレンダのいずれか (TERADATA、ISO、または
COMPATIBLE)または NULL になります。
第 3 引数は、次のデータ タイプのいずれかになります。
• TIME
• TIME WITH TIME ZONE
• NULL
結果
戻り値は、次のいずれかのデータ タイプです。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
SQL 関数、演算子、式および述部
369
第 8 章 ビジネス カレンダ
td_friday
例: DATE または TIMESTAMP より前の木曜日の問合わせ
次の SQL 文を実行します。
SELECT TD_THURSDAY(TIMESTAMP'2012-05-08 10:00:00',NULL,NULL);
2012-05-03 00:00:00 を返します。
NULL を指定しているため、セッション カレンダ、つまりこの場合は TERADATA が
使用されることになります。
td_friday
目的
expression_1 に指定されている DATE または TIMESTAMP の直前にあたる金曜日を
返します。
構文
td_friday
( expression_1
TD_SYSFNLIB.
)
,
calendar_name
NULL
,
expression_2
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression_1
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
expression_1 が DATE である場合は、expression_2 を指定できません。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
370
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
td_friday
expression_2
TIME、TIME WITH TIME ZONE、NULL のいずれかの値。NULL を指定した場合、
TIME は 00:00:00+00:00 であるとみなされます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
この関数はオーバーロードされ、1~3 個の引数を指定して呼び出すことができます。
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義
されます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
戻り値は、次のいずれかのデータ タイプです。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
例: DATE または TIMESTAMP より前の金曜日の問合わせ
次の SQL 文を実行します。
SELECT TD_FRIDAY(TIMESTAMP'2012-05-08 10:00:00',NULL,TIME'05:00:00');
2012-05-04 05:00:00 を返します。
NULL を指定しているため、セッション カレンダ、つまりこの場合は TERADATA が
使用されることになります。
SQL 関数、演算子、式および述部
371
第 8 章 ビジネス カレンダ
td_saturday
td_saturday
目的
expression_1 に指定されている DATE または TIMESTAMP の直前にあたる土曜日を
返します。
構文
td_saturday
( expression_1
TD_SYSFNLIB.
)
,
calendar_name
NULL
,
expression_2
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression_1
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
expression_1 が DATE である場合は、expression_2 を指定できません。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
expression_2
TIME、TIME WITH TIME ZONE、NULL のいずれかの値。NULL を指定した場合、
TIME は 00:00:00+00:00 であるとみなされます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
この関数はオーバーロードされ、1~3 個の引数を指定して呼び出すことができます。
第 1 引数 expression は、次に示すデータ型で定義されます。
372
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
DayNumber_Of_Week
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義
されます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
戻り値は、次のいずれかのデータ タイプです。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
例: DATE または TIMESTAMP より前の土曜日の問合わせ
次の SQL 文を実行します。
SELECT TD_SATURDAY(TIMESTAMP'2012-05-08
10:00:00',NULL,TIME'05:00:00+03:00');
2012-05-05 02:00:00 を返します。
NULL を指定しているため、セッション カレンダ、つまりこの場合は TERADATA が
使用されることになります。
DayNumber_Of_Week
目的
週初めから指定された日までの日数を返します。
構文
DAYNUMBER_OF_WEEK
TD_SYSFNLIB.
( expression
,
)
calendar_name
NULL
SQL 関数、演算子、式および述部
373
第 8 章 ビジネス カレンダ
DayNumber_Of_Week
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
この関数はオーバーロードされ、1~3 個の引数を指定して呼び出すことができます。
第 1 引数は、次のデータ タイプのいずれかになります。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数は、次のシステム定義のカレンダのいずれか (TERADATA、ISO、または
COMPATIBLE)または NULL になります。
第 3 引数は、次のデータ タイプのいずれかになります。
• TIME
• TIME WITH TIME ZONE
• NULL
結果
結果は曜日を表わす 1 から 7 の INTEGER 値になります。この値で、週の最初の日は
1、週の最後の日は 7 です。週の最初の日は、セッションが使用しているビジネス
カレンダによって定義されます。たとえば、ISO カレンダでは月曜日は 1、Teradata
ビジネス カレンダでは月曜日は 2 です。
374
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
td_month_begin
使用上の注意
DayNumber_Of_Week 関数では、同様の結果を得るために Sys_Calendar.Calendar
システム ビューを使用する方法に比べて、パフォーマンスが向上します。
例: 従業員の名前の問合わせ
次の問合わせは、その週の最初の日に入社した従業員の名前を返します。
SELECT empname from emp
WHERE DAYNUMBER_OF_WEEK (date_of_join)= 1;
関連トピック
CALENDAR システム ビューについて、詳細は<データ ディクショナリ、B035-1092>
を参照してください。
td_month_begin
目的
expression_1 に指定されている DATE または TIMESTAMP の直前にあたる月初めを
返します。
構文
td_month_begin
TD_SYSFNLIB.
( expression_1
)
,
calendar_name
NULL
,
expression_2
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression_1
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
expression_1 が DATE である場合は、expression_2 を指定できません。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
SQL 関数、演算子、式および述部
375
第 8 章 ビジネス カレンダ
td_month_begin
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
expression_2
TIME、TIME WITH TIME ZONE、NULL のいずれかの値。NULL を指定した場合、
TIME は 00:00:00+00:00 であるとみなされます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義さ
れます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
戻り値は、次のいずれかのデータ タイプです。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
例: DATE または TIMESTAMP の直前にあたる月初の問合わせ
次の SQL 文を実行します。
SELECT TD_MONTH_BEGIN(DATE'2012-01-15');
12/01/01 を返します。
カレンダを指定していないため、セッション カレンダ、つまりこの場合は Teradata
が使用されることになります。
376
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
td_month_end
td_month_end
目的
expression_1 に指定されている DATE または TIMESTAMP の直後にあたる月末を返
します。
構文
td_month_end
( expression_1
TD_SYSFNLIB.
)
,
calendar_name
NULL
,
expression_2
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression_1
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
expression_1 が DATE である場合は、expression_2 を指定できません。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
expression_2
TIME、TIME WITH TIME ZONE、NULL のいずれかの値。NULL を指定した場合、
TIME は 00:00:00+00:00 であるとみなされます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
この関数はオーバーロードされ、1~3 個の引数を指定して呼び出すことができます。
第 1 引数 expression は、次に示すデータ型で定義されます。
SQL 関数、演算子、式および述部
377
第 8 章 ビジネス カレンダ
DayNumber_Of_Month
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義さ
れます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
戻り値は、次のいずれかのデータ タイプです。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
例: DATE または TIMESTAMP の直後にあたる月末の問合わせ
次の SQL 文を実行します。
SELECT TD_MONTH_END(DATE'2012-01-15',NULL);
12/01/31 を返します。
NULL を指定しているため、セッション カレンダ、つまりこの場合は Teradata が
使用されることになります。
DayNumber_Of_Month
目的
月初めから指定された日までの日数を返します。
構文
DAYNUMBER_OF_MONTH
( expression
TD_SYSFNLIB.
,
)
calendar_name
NULL
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
378
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
DayNumber_Of_Month
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
この関数はオーバーロードされ、1~3 個の引数を指定して呼び出すことができます。
第 1 引数は、次のデータ タイプのいずれかになります。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数は、次のシステム定義のカレンダのいずれか (TERADATA、ISO、または
COMPATIBLE)または NULL になります。
第 3 引数は、次のデータ タイプのいずれかになります。
• TIME
• TIME WITH TIME ZONE
• NULL
結果
結果は 1 から 31 の INTEGER 値になります。
使用上の注意
DayNumber_Of_Month 関数では、同様の結果を得るために Sys_Calendar.Calendar
システム ビューを使用する方法に比べて、パフォーマンスが向上します。
SQL 関数、演算子、式および述部
379
第 8 章 ビジネス カレンダ
DayOccurrence_Of_Month
例: 月の初めからの日数の問合わせ
次に示す例は、どちらもセッションに設定されたビジネス カレンダがありません。
そのため、その問合わせは、システム定義のビジネス カレンダである Teradata を使
用します。
次の問合わせでは、その月の日数として 1 ではなく 31 が得られます。これは、入力
が UTC 2009-12-31 19:00:00 に変換されるためです。
SET TIME ZONE INTERVAL ‘05:00’ HOUR TO MINUTE;
SELECT DAYNUMBER_OF_MONTH (TIMESTAMP‘2010-01-01 00:00:00’);
次の問合わせでは、その月の日数として 1 ではなく 31 が得られます。これは、入力
が UTC 2009-12-31 21:00:00 に変換されるためです。
SEL DAYNUMBER_OF_MONTH (TIMESTAMP’2010-01-01 00:00:00+03:00’);
関連トピック
CALENDAR システム ビューについて、詳細は<データ ディクショナリ、B035-1092>
を参照してください。
DayOccurrence_Of_Month
目的
指定された日の曜日が、その月の n 番目の出現かを返します。
構文
DAYOCCURRENCE_OF_MONTH
( expression
TD_SYSFNLIB.
,
)
calendar_name
NULL
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression_1
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
380
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
DayOccurrence_Of_Month
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
この関数はオーバーロードされ、1~3 個の引数を指定して呼び出すことができます。
第 1 引数は、次のデータ タイプのいずれかになります。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数は、次のシステム定義のカレンダのいずれか (TERADATA、ISO、または
COMPATIBLE)または NULL になります。
第 3 引数は、次のデータ タイプのいずれかになります。
• TIME
• TIME WITH TIME ZONE
• NULL
結果
結果は 1 から 5 の整数値になります。これは、その月の n 番目の平日が現われる位
置を表わします。
使用上の注意
DayOccurrence_of_Month 関数では、同様の結果を得るために
Sys_Calendar.Calendar システム ビューを使用する方法に比べて、パフォーマンス
が向上します。
例: ある平日がその月の何週目に属するかを問合わせる
現在の日付が 2010 年 5 月 1 日の場合、次の問合わせは 1 を返します。これは、
2010 年 5 月 1 日が月の最初の土曜日にあたるからです。
SELECT TD_SYSFNLIB.DAYOCCURRENCE_OF_MONTH(CURRENT_DATE);
SELECT TD_SYSFNLIB.DAYOCCURRENCE_OF_MONTH(DATE '2010-05-01');
SQL 関数、演算子、式および述部
381
第 8 章 ビジネス カレンダ
WeekNumber_Of_Month
関連トピック
詳細は、<データ ディクショナリ 、B035-1092>を参照してください。
WeekNumber_Of_Month
目的
月初めから指定された日までの週の数を返します。
構文
WEEKNUMBER_OF_MONTH
( expression
TD_SYSFNLIB.
,
)
calendar_name
NULL
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression_1
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
• TIMESTAMP
382
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
td_year_begin
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義
されます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は 1 から 5 の INTEGER 値になります。これは、その月の n 番目の週が現われ
る位置を表わします。値 0 は 7 に満たない週(第 0 週)を意味します。
使用上の注意
WeekNumber_Of_Month 関数では、同様の結果を得るために Sys_Calendar.Calendar
システム ビューを使用する方法に比べて、パフォーマンスが向上します。
例: 月の初めからの週数の問合わせ
現在の日付が 1901 年 1 月 5 日の場合、次の問合わせは 0 を返します。これは、
1901 年 1 月 5 日が Teradata カレンダでは 1 月の第 0 週に含まれるからです。
SELECT TD_SYSFNLIB.WEEKNUMBER_OF_MONTH (CURRENT_DATE);
次の問合わせは 1 を返します。これは、1901 年 1 月 5 日が ISO カレンダでは 1 月
の第 1 週に含まれるからです。
SELECT TD_SYSFNLIB.WEEKNUMBER_OF_MONTH (DATE ‘1901-01-05’, ‘ISO’);
td_year_begin
目的
expression_1 に指定されている DATE または TIMESTAMP の直前にあたる年初めを
返します。
構文
td_year_begin
TD_SYSFNLIB.
SQL 関数、演算子、式および述部
( expression_1
)
,
calendar_name
NULL
,
expression_2
383
第 8 章 ビジネス カレンダ
td_year_begin
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression_1
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
expression_1 が DATE である場合は、expression_2 を指定できません。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
expression_2
TIME、TIME WITH TIME ZONE、NULL のいずれかの値。NULL を指定した場合、
TIME は 00:00:00+00:00 であるとみなされます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義さ
れます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
戻り値は、次のいずれかのデータ タイプです。
384
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
td_year_end
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
例: DATE または TIMESTAMP の直前に始まる年の問合わせ
次の SQL 文を実行します。
SELECT TD_YEAR_BEGIN(TIMESTAMP'2012-01-15 12:00:00','ISO',NULL);
2012-01-02 00:00:00 を返します。
td_year_end
目的
expression_1 に指定されている DATE または TIMESTAMP の直後にあたる年末を返
します。
構文
td_year_end
( expression_1
TD_SYSFNLIB.
)
,
calendar_name
NULL
,
expression_2
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression_1
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
expression_1 が DATE である場合は、expression_2 を指定できません。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
SQL 関数、演算子、式および述部
385
第 8 章 ビジネス カレンダ
DayNumber_Of_Year
expression_2
TIME、TIME WITH TIME ZONE、NULL のいずれかの値。NULL を指定した場合、
TIME は 00:00:00+00:00 であるとみなされます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義さ
れます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
戻り値は、次のいずれかのデータ タイプです。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
例: DATE または TIMESTAMP の後の年末の問合わせ
次の SQL 文を実行します。
SELECT TD_YEAR_END(TIMESTAMP'2012-01-15 10:00:00','ISO');
2012-12-30 23:59:59 を返します。
DayNumber_Of_Year
目的
年初めから指定された日までの日数を返します。
386
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
DayNumber_Of_Year
構文
DAYNUMBER_OF_YEAR
( expression
,
TD_SYSFNLIB.
)
calendar_name
NULL
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression_1
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
この関数はオーバーロードされ、1~3 個の引数を指定して呼び出すことができます。
第 1 引数は、次のデータ タイプのいずれかになります。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数は、次のシステム定義のカレンダのいずれか (TERADATA、ISO、または
COMPATIBLE)または NULL になります。
第 3 引数は、次のデータ タイプのいずれかになります。
• TIME
• TIME WITH TIME ZONE
• NULL
SQL 関数、演算子、式および述部
387
第 8 章 ビジネス カレンダ
WeekNumber_Of_Year
結果
結果は 1 から 366 の INTEGER 値になります。
使用上の注意
DayNumber_Of_Year 関数では、同様の結果を得るために Sys_Calendar.Calendar シ
ステム ビューを使用する方法に比べて、パフォーマンスが向上します。
例: DATE または TIMESTAMP の直後にあたる年末の問合わせ
現在の日付が 2010 年 2 月 10 日の場合、次の問合わせは 41 を返します。これは、
2010 年 2 月 10 日が Teradata カレンダの年初めから 41 番目の日にあたるからです。
SELECT TD_SYSFNLIB.DAYNUMBER_OF_YEAR(CURRENT_DATE);
SELECT TD_SYSFNLIB.DAYNUMBER_OF_YEAR(DATE '2010-02-10');
関連トピック
CALENDAR システム ビューについて、詳細は<データ ディクショナリ、B035-1092>
を参照してください。
WeekNumber_Of_Year
目的
年初めから指定された日までの週の数を返します。
構文
WEEKNUMBER_OF_YEAR
( expression
TD_SYSFNLIB.
,
)
calendar_name
NULL
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
388
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
WeekNumber_Of_Year
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義
されます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は 0 から 53 の INTEGER 値になります。1 はその年の第 1 週であり、53 はそ
の年の最終週になります。値 0 は、その年に部分的な週(第 0 週)があることを意味
します。
使用上の注意
WeekNumber_Of_Year 関数では、同様の結果を得るために Sys_Calendar.Calendar
システム ビューを使用する方法に比べて、パフォーマンスが向上します。
例: 年の初めからの週数の問合わせ
現在の日付が 1901 年 1 月 5 日の場合、次の問合わせは 0 を返します。これは、
1901 年 1 月 5 日が Teradata カレンダでは 1901 年の第 0 週に含まれるからです。
SQL 関数、演算子、式および述部
389
第 8 章 ビジネス カレンダ
MonthNumber_Of_Year
SELECT TD_SYSFNLIB.WEEKNUMBER_OF_YEAR (CURRENT_DATE);
次の問合わせは 1 を返します。これは、1901 年 1 月 5 日が COMPATIBLE カレン
ダでは 1901 年の第 1 週に含まれるからです。
SELECT TD_SYSFNLIB.WEEKNUMBER_OF_YEAR (DATE ‘1901-01-05’, ‘COMPATIBLE’);
関連トピック
詳細は、<データ ディクショナリ 、B035-1092>を参照してください。
MonthNumber_Of_Year
目的
年初めから指定された日までの月数を返します。
構文
MONTHNUMBER_OF_YEAR
( expression
TD_SYSFNLIB.
,
)
calendar_name
NULL
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression_1
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
390
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
MonthNumber_Of_Year
引数のタイプ
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義
されます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は 1 から 12 の整数値になります。これは、その年の n 番目の月を表わします。
使用上の注意
MonthNumber_Of_Year 関数では、同様の結果を得るために Sys_Calendar.Calendar
システム ビューを使用する方法に比べて、パフォーマンスが向上します。
例: 年の初めからの月数の問合わせ
現在の日付が 2011 年 3 月 15 日の場合、次の問合わせは 3 を返します。これは、
2011 年 3 月 15 日が Teradata カレンダの 3 番目の月にあるからです。
SELECT TD_SYSFNLIB.MONTHNUMBER_OF_YEAR(CURRENT_DATE);
次の問合わせは 3 を返します。これは、2011 年 3 月 15 日が ISO カレンダの 3 番
目の月にあるからです。
SELECT TD_SYSFNLIB.MONTHNUMBER_OF_YEAR(DATE '2011-03-15', ’ISO’);
関連トピック
CALENDAR システム ビューについて、詳細は<データ ディクショナリ、B035-1092>
を参照してください。
SQL 関数、演算子、式および述部
391
第 8 章 ビジネス カレンダ
td_quarter_begin
td_quarter_begin
目的
expression_1 に指定されている DATE または TIMESTAMP の直前にあたる四半期初
めを返します。
構文
td_quarter_begin
( expression_1
TD_SYSFNLIB.
)
,
calendar_name
NULL
,
expression_2
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression_1
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
expression_1 が DATE である場合は、expression_2 を指定できません。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
expression_2
TIME、TIME WITH TIME ZONE、NULL のいずれかの値。NULL を指定した場合、
TIME は 00:00:00+00:00 であるとみなされます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
392
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
td_quarter_end
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義
されます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
戻り値は、次のいずれかのデータ タイプです。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
例: DATE または TIMESTAMP の直前にあたる四半期の問合わせ
次の SQL 文を実行します。
SELECT TD_QUARTER_BEGIN(DATE'2012-01-15','COMPATIBLE');
12/01/01 を返します。
td_quarter_end
目的
expression_1 に指定されている DATE または TIMESTAMP の直後にあたる四半期末
を返します。
構文
td_quarter_end
TD_SYSFNLIB.
( expression_1
)
,
calendar_name
NULL
,
expression_2
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
SQL 関数、演算子、式および述部
393
第 8 章 ビジネス カレンダ
td_quarter_end
expression_1
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
expression_1 が DATE である場合は、expression_2 を指定できません。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
expression_2
TIME、TIME WITH TIME ZONE、NULL のいずれかの値。NULL を指定した場合、
TIME は 00:00:00+00:00 であるとみなされます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義さ
れます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
戻り値は、次のいずれかのデータ タイプです。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
394
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
WeekNumber_Of_Quarter
例: DATE または TIMESTAMP の直後にあたる四半期末の問合わせ
次の SQL 文を実行します。
SELECT TD_QUARTER_END(TIMESTAMP'2012-01-15 10:00:00','COMPATIBLE');
2012-03-31 23:59:59 を返します。
WeekNumber_Of_Quarter
目的
四半期の初めから指定された日までの週の数を返します。
構文
WEEKNUMBER_OF_QUARTER
( expression
TD_SYSFNLIB.
,
)
calendar_name
NULL
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
SQL 関数、演算子、式および述部
395
第 8 章 ビジネス カレンダ
MonthNumber_Of_Quarter
引数のタイプ
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義さ
れます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は 1 から 14 の INTEGER 値になります。これは、その四半期の n 番目の週を表
わします。値 0 は 7 に満たない週(第 0 週)を意味します。
例: 四半期の最初からの週数の問合わせ
現在の日付が 2011 年 4 月 20 日の場合、次の問合わせは 3 because April 20,
2011, is in the third week of the quarter in the Teradata calendar を
返します。
SELECT TD_SYSFNLIB.WEEKNUMBER_OF_QUARTER(CURRENT_DATE);
次の問合わせは 3 を返します。これは、2011 年 4 月 20 日が ISO カレンダの四半期
の 3 番目の週にあるからです。
SELECT TD_SYSFNLIB.WEEKNUMBER_OF_QUARTER (DATE '2011-04-20', ’ISO’);
MonthNumber_Of_Quarter
目的
四半期の初めから指定された日までの月数を返します。
構文
MONTHNUMBER_OF_QUARTER
TD_SYSFNLIB.
( expression
,
)
calendar_name
NULL
396
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
MonthNumber_Of_Quarter
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義
されます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は 1 から 3 の整数値になります。これは、その四半期の n 番目の月を表わしま
す。
SQL 関数、演算子、式および述部
397
第 8 章 ビジネス カレンダ
QuarterNumber_Of_Year
使用上の注意
MonthNumber_Of_Quarter 関数では、同様の結果を得るために
Sys_Calendar.Calendar システム ビューを使用する方法に比べて、パフォーマンスが
向上します。
例: 四半期の初めからの月数の問合わせ
現在の日付が 2011 年 4 月 20 日の場合、次の問合わせは 1 を返します。これは、
2011 年 4 月 20 日が Teradata カレンダの四半期の 1 番目の月にあるからです。
SELECT TD_SYSFNLIB.MONTHNUMBER_OF_QUARTER(CURRENT_DATE);
次の問合わせは 1 を返します。これは、2011 年 4 月 20 日が ISO カレンダの四半期
の 1 番目の月にあるからです。
SELECT TD_SYSFNLIB.MONTHNUMBER_OF_QUARTER(DATE '2011-04-20', ’ISO’);
関連トピック
詳細は、<データ ディクショナリ 、B035-1092>を参照してください。
QuarterNumber_Of_Year
目的
年初めから指定された日までの四半期の数を返します。
構文
QUARTERNUMBER_OF_YEAR
( expression
TD_SYSFNLIB.
,
)
calendar_name
NULL
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
398
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
QuarterNumber_Of_Year
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義
されます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は 1 から 4 の整数値になります。これは、その年の n 番目の四半期を表わしま
す。
使用上の注意
QuarterNumber_Of_Year 関数では、同様の結果を得るために Sys_Calendar.Calendar
システム ビューを使用する方法に比べて、パフォーマンスが向上します。
例: 年の初めからの四半期数の問合わせ
現在の日付が 2010 年 12 月 20 日の場合、次の問合わせは 4 を返します。これは、
2010 年 12 月 20 日が Teradata カレンダの 4 番目の四半期にあるからです。
SELECT TD_SYSFNLIB.QUARTERNUMBER_OF_YEAR(CURRENT_DATE);
SQL 関数、演算子、式および述部
399
第 8 章 ビジネス カレンダ
DayNumber_Of_Calendar
次の問合わせは 4 を返します。これは、2010 年 12 月 10 日が ISO カレンダの 4 番
目の四半期にあるからです。
SELECT TD_SYSFNLIB.QUARTERNUMBER_OF_YEAR(DATE '2010-12-20', ’ISO’);
関連トピック
CALENDAR システム ビューについて、詳細は<データ ディクショナリ、B035-1092>
を参照してください。
DayNumber_Of_Calendar
目的
ビジネス カレンダの初日から指定された日までの日数を返します。
構文
DAYNUMBER_OF_CALENDAR
( expression
TD_SYSFNLIB.
,
)
calendar_name
NULL
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
400
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
WeekNumber_Of_Calendar
引数のタイプ
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義
されます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は、ビジネス カレンダの初日からの日数(同日を含む)を表わす INTEGER 値です。
使用上の注意
DayNumber_Of_Calendar 関数では、同様の結果を得るために
Sys_Calendar.Calendar システム ビューを使用する方法に比べて、パフォーマンス
が向上します。
例: ビジネス カレンダの最初からの日数の問合わせ
現在の日付が 1901 年 1 月 5 日の場合、次の問合わせは 370 を返します。これは、
1901 年 1 月 5 日が 1900 年 1 月 1 日から 370 番目の日にあたるからです。
SELECT TD_SYSFNLIB.DAYNUMBER_OF_CALENDAR(CURRENT_DATE);
SELECT TD_SYSFNLIB.DAYNUMBER_OF_CALENDAR(DATE '1901-01-05');
関連トピック
CALENDAR システム ビューについて、詳細は<データ ディクショナリ、B035-1092>
を参照してください。
WeekNumber_Of_Calendar
目的
ビジネス カレンダの初日から指定された日までの週の数を返します。
SQL 関数、演算子、式および述部
401
第 8 章 ビジネス カレンダ
WeekNumber_Of_Calendar
構文
WEEKNUMBER_OF_CALENDAR
( expression
TD_SYSFNLIB.
,
)
calendar_name
NULL
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義さ
れます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
402
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
MonthNumber_Of_Calendar
結果
結果は INTEGER 値になります。値 0 は、その年に 7 に満たない週(第 0 週)があるこ
とを意味します。
使用上の注意
WeekNumber_Of_Calendar 関数では、同様の結果を得るために
Sys_Calendar.Calendar システム ビューを使用する方法に比べて、パフォーマンス
が向上します。
例: ビジネス カレンダの最初からの週数の問合わせ
現在の日付が 1901 年 1 月 5 日の場合、次の問合わせは 52 を返します。これは、
1901 年 1 月 5 日が Teradata カレンダの開始(1900-01-01)から 52 週目にあるから
です。
SELECT TD_SYSFNLIB.WEEKNUMBER_OF_CALENDAR (CURRENT_DATE);
次の問合わせは 53 を返します。これは、1901 年 1 月 5 日が COMPATIBLE カレン
ダの開始(1900-01-01)から 53 週目にあるからです。
SELECT TD_SYSFNLIB.WEEKNUMBER_OF_CALENDAR (DATE ‘1901-01-05’,
‘COMPATIBLE’);
MonthNumber_Of_Calendar
目的
カレンダの初日から指定された日までの月数を返します。
構文
MONTHNUMBER_OF_CALENDAR
( expression
TD_SYSFNLIB.
,
)
calendar_name
NULL
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
SQL 関数、演算子、式および述部
403
第 8 章 ビジネス カレンダ
MonthNumber_Of_Calendar
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
NULL
セッションのビジネス カレンダ。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義さ
れます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は、カレンダの初日からの月数(同月を含む)を表わす INTEGER 値です。
使用上の注意
MonthNumber_Of_Calendar 関数では、同様の結果を得るために
Sys_Calendar.Calendar システム ビューを使用する方法に比べて、パフォーマンスが
向上します。
404
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
QuarterNumber_Of_Calendar
例: カレンダの最初からの月数の問合わせ
現在の日付が 1901 年 5 月 5 日の場合、次の問合わせは 17 を返します。これは、
1901 年 5 月 5 日が Teradata カレンダの開始(1900-01-01)から 17 番目の月にある
からです。
SELECT TD_SYSFNLIB.MONTHNUMBER_OF_CALENDAR(CURRENT_DATE);
次の問合わせは 17 を返します。これは、1901 年 5 月 5 日が COMPATIBLE カレン
ダの開始(1900-01-01)から 17 番目の月にあるからです。
SELECT TD_SYSFNLIB.MONTHNUMBER_OF_CALENDAR(DATE
'1901-05-05', ’COMPATIBLE’);
関連トピック
詳細は、<データ ディクショナリ 、B035-1092>を参照してください。
QuarterNumber_Of_Calendar
目的
カレンダの初日から指定された日までの四半期の数を返します。
構文
QUARTERNUMBER_OF_CALENDAR
( expression
TD_SYSFNLIB.
,
)
calendar_name
NULL
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
SQL 関数、演算子、式および述部
405
第 8 章 ビジネス カレンダ
QuarterNumber_Of_Calendar
NULL
セッションのビジネス カレンダ。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義さ
れます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は、カレンダの初日からの四半期の数(同四半期を含む)を表わす INTEGER 値です。
使用上の注意
QuarterNumber_Of_Calendar 関数では、同様の結果を得るために
Sys_Calendar.Calendar システム ビューを使用する方法に比べて、パフォーマンスが
向上します。
例: カレンダの最初からの四半期数の問合わせ
現在の日付が 1901 年 5 月 5 日の場合、次の問合わせは 6 を返します。これは、
1901 年 5 月 5 日が Teradata カレンダの初日(1900-01-01)から 6 番目の四半期にあ
るからです。
SELECT TD_SYSFNLIB.QUARTERNUMBER_OF_CALENDAR(CURRENT_DATE);
次の問合わせは 6 を返します。これは、1901 年 5 月 5 日が COMPATIBLE カレンダ
の初日(1900-01-01)から 6 番目の四半期にあるからです。
SELECT TD_SYSFNLIB.QUARTERNUMBER_OF_CALENDAR (DATE
'1901-05-05', ’COMPATIBLE’);
406
SQL 関数、演算子、式および述部
第 8 章 ビジネス カレンダ
YearNumber_Of_Calendar
関連トピック
CALENDAR システム ビューについて、詳細は<データ ディクショナリ、B035-1092>
を参照してください。
YearNumber_Of_Calendar
目的
指定した日の年を返します。
構文
YEARNUMBER_OF_CALENDAR
( expression
TD_SYSFNLIB.
,
)
calendar_name
NULL
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
calendar_name
カレンダ名。使用可能な値は Teradata、ISO、および COMPATIBLE です。
この引数は文字リテラルでなければなりません。また、この引数をテーブルの列や
式にすることはできません。カレンダに名前を付けていない場合、Teradata はセッ
ションのカレンダを使用します。
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
NULL
セッションのビジネス カレンダ。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
第 1 引数 expression は、次に示すデータ型で定義されます。
• DATE
SQL 関数、演算子、式および述部
407
第 8 章 ビジネス カレンダ
YearNumber_Of_Calendar
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
第 2 引数 calendar_name は任意選択であり、次に示す引数のデータ タイプで定義さ
れます。
• VARCHAR
• NULL
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は、年を表わす 4 桁書式の INTEGER 値になります。
使用上の注意
YearNumber_Of_Calendar 関数では、同様の結果を得るために
Sys_Calendar.Calendar システム ビューを使用する方法に比べて、パフォーマンスが
向上します。
例: 指定した日の年の問合わせ
現在の日付が 1906 年 6 月 14 日の場合、次の問合わせは 1906 を返します。
SELECT TD_SYSFNLIB.YEARNUMBER_OF_CALENDAR(CURRENT_DATE);
SELECT TD_SYSFNLIB.YEARNUMBER_OF_CALENDAR (DATE
'1906-06-14', ’COMPATIBLE’);
関連トピック
詳細は、以下を参照してください。
• データ ディクショナリ 、B035-1092
408
SQL 関数、演算子、式および述部
第9章
CALENDAR 関数
概要
この章では、カレンダ属性を使用する日時操作をサポートする関数について説明し
ます。
前提条件
これらの関数を使用する前に、データベース初期化プログラム(DIP)ユーティリティ
を実行し、DIPUDT スクリプトを実行する必要があります。DIPALL および DIPUDT
スクリプトにより、カレンダ関数が SYSLIB データベース内に作成されます。DIP
ユーティリティの詳細は、<ユーティリティ 、B035-1102>を参照してください。
カレンダ関数と同じ名前の、ユーザーが開発した UDF を持っている場合は、カレン
ダ関数を呼び出す前に、ユーザーが開発した UDF を通常の UDF 検索パスから削除
する必要があります。現在のデータベースでカレンダ関数を見つけられない場合、
Teradata Database は SYSLIB データベースで関数を検索します。この代わりに、完
全修飾した構文(SYSLIB.calendar_function_name)を使用して、カレンダ関数を呼び
出すこともできます。
td_day_of_week
目的
指定された日の曜日を返します。
構文
td_day_of_week
(expression)
SYSLIB.
構文要素
SYSLIB
関数が格納されているデータベースの名前。
SQL 関数、演算子、式および述部
409
第 9 章 CALENDAR 関数
td_day_of_month
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
引数のタイプ
td_day_of_week はオーバーロード スカラー関数です。この関数は以下に示すパラ
メータのデータ タイプで定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は曜日を表わす 1 から 7 の INTEGER 値になります。この値で、日曜日は 1、土
曜日は 7 です。
使用上の注意
td_day_of_week 関数では、同様の結果を得るために Sys_Calendar.Calendar システ
ム ビューを使用する方法に比べて、パフォーマンスが向上します。
例: 指定した日が該当する曜日の問合わせ
現在の日付が 2010 年 10 月 18 日月曜日の場合、次の問合わせは結果として値 2 を
返します。これは、月曜日が週の 2 番目の日にあたるからです。
SELECT td_day_of_week(CURRENT_DATE);
SELECT td_day_of_week(DATE '2010-10-18');
td_day_of_month
目的
月初めから指定された日までの日数を返します。
構文
td_day_of_month
(expression)
SYSLIB.
410
SQL 関数、演算子、式および述部
第 9 章 CALENDAR 関数
td_day_of_month
構文要素
SYSLIB
関数が格納されているデータベースの名前。
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
td_day_of_month はオーバーロード スカラー関数です。この関数は以下に示すパラ
メータのデータ タイプで定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は 1 から 31 の INTEGER 値になります。
使用上の注意
td_day_of_month 関数では、同様の結果を得るために Sys_Calendar.Calendar シス
テム ビューを使用する方法に比べて、パフォーマンスが向上します。
例: 月の最初からの日数の問合わせ
現在の日付が 2010 年 5 月 27 日の場合、次の問合わせは結果として値 27 を返しま
す。これは、2010 年 5 月 27 日が 5 月の月初めから 27 番目の日にあたるからです。
SELECT td_day_of_month(CURRENT_DATE);
SELECT td_day_of_month(DATE '2010-05-27');
SQL 関数、演算子、式および述部
411
第 9 章 CALENDAR 関数
td_day_of_year
関連トピック
詳細は、以下を参照してください。
• オーバーロード関数の詳細については、<SQL 外部ルーチン プログラミング、
B035-1147>の「関数名のオーバーロード」を参照してください。
• CALENDAR システム ビューについて、詳細は<データ ディクショナリ 、
B035-1092>を参照してください。
• オーバーロード関数の詳細については、<SQL 外部ルーチン プログラミング、
B035-1147>の「関数名のオーバーロード」を参照してください。
td_day_of_year
目的
年初め(1 月 1 日)から指定された日までの日数を返します。
構文
td_day_of_year
(expression)
SYSLIB.
構文要素
SYSLIB
関数が格納されているデータベースの名前。
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
td_day_of_year はオーバーロード スカラー関数です。この関数は以下に示すパラ
メータのデータ タイプで定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
412
SQL 関数、演算子、式および述部
第 9 章 CALENDAR 関数
td_weekday_of_month
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は 1 から 366 の INTEGER 値になります。
使用上の注意
td_day_of_year 関数では、同様の結果を得るために Sys_Calendar.Calendar システ
ム ビューを使用する方法に比べて、パフォーマンスが向上します。
例: 年の最初からの日数の問合わせ
現在の日付が 2010 年 2 月 10 日の場合、次の問合わせは結果として値 41 を返しま
す。これは、2010 年 2 月 10 日が年初めから 41 番目の日にあたるからです。
SELECT td_day_of_year(CURRENT_DATE);
SELECT td_day_of_year(DATE '2010-02-10');
関連トピック
詳細は、以下を参照してください。
• <SQL 外部ルーチン プログラミング、B035-1147>の「関数名のオーバーロード」
• データ ディクショナリ 、B035-1092
td_weekday_of_month
目的
指定された日の曜日が、その月の n 番目の出現かを返します。
構文
td_weekday_of_month
(expression)
SYSLIB.
構文要素
SYSLIB
関数が格納されているデータベースの名前。
SQL 関数、演算子、式および述部
413
第 9 章 CALENDAR 関数
td_weekday_of_month
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
td_weekday_of_month はオーバーロード スカラー関数です。この関数は以下に示す
パラメータのデータ タイプで定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は 1 から 5 の整数値になります。これは、その月の n 番目の曜日の出現を表わ
します。
使用上の注意
td_weekday_of_month 関数では、同様の結果を得るために Sys_Calendar.Calendar
システム ビューを使用する方法に比べて、パフォーマンスが向上します。
例: ある平日がその月の何週目に属するかを問合わせる
現在の日付が 2010 年 5 月 1 日の場合、次の問合わせは結果として値 1 を返しま
す。これは、2010 年 5 月 1 日が月の最初の日曜日にあたるからです。
SELECT td_weekday_of_month(CURRENT_DATE);
SELECT td_weekday_of_month(DATE '2010-05-01');
関連トピック
詳細は、以下を参照してください。
• <SQL 外部ルーチン プログラミング、B035-1147>の「関数名のオーバーロード」
414
SQL 関数、演算子、式および述部
第 9 章 CALENDAR 関数
td_week_of_month
• CALENDAR システム ビューについて、詳細は<データ ディクショナリ 、
B035-1092>を参照してください。
td_week_of_month
目的
指定された日が、月初めから n 番目の週かを返します。
構文
td_week_of_month
(expression)
SYSLIB.
構文要素
SYSLIB
関数が格納されているデータベースの名前。
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
td_week_of_month はオーバーロード スカラー関数です。この関数は以下に示すパ
ラメータのデータ タイプで定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は 0 から 5 の整数値になります。これは、月初めから n 番目の週を表わしま
す。最初の 7 日に満たない週は 0 です。
SQL 関数、演算子、式および述部
415
第 9 章 CALENDAR 関数
td_week_of_year
使用上の注意
td_week_of_month 関数では、同様の結果を得るために Sys_Calendar.Calendar シス
テム ビューを使用する方法に比べて、パフォーマンスが向上します。
例: 月の最初から n 番目の週であるかを問合わせる
現在の日付が 2010 年 5 月 1 日の場合、次の問合わせは結果として値 0 を返しま
す。これは 2010 年 5 月 1 日が、5 月の最初の 7 日に満たない週にあたるからです。
SELECT td_week_of_month(CURRENT_DATE);
SELECT td_week_of_month(DATE '2010-05-01');
関連トピック
詳細は、以下を参照してください。
• <SQL 外部ルーチン プログラミング、B035-1147>の「関数名のオーバーロード」
• CALENDAR システム ビューについて、詳細は<データ ディクショナリ 、
B035-1092>を参照してください。
td_week_of_year
目的
指定された日が、年初め(1 月 1 日)から n 番目の週かを返します。
構文
td_week_of_year
(expression)
SYSLIB.
構文要素
SYSLIB
関数が格納されているデータベースの名前。
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
416
SQL 関数、演算子、式および述部
第 9 章 CALENDAR 関数
td_week_of_calendar
引数のタイプ
td_week_of_year はオーバーロード スカラー関数です。この関数は以下に示すパラ
メータのデータ タイプで定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は 0 から 53 の整数値になります。これは、年初めから n 番目の週を表わしま
す。最初の 7 日に満たない週は 0 です。
使用上の注意
td_week_of_year 関数では、同様の結果を得るために Sys_Calendar.Calendar システ
ム ビューを使用する方法に比べて、パフォーマンスが向上します。
例: 年の最初から n 番目の週であるかを問合わせる
現在の日付が 2010 年 5 月 4 日の場合、次の問合わせは結果として値 18 を返しま
す。これは、2010 年 5 月 4 日がその年の 18 番目の週にあたるからです。
SELECT td_week_of_year(CURRENT_DATE);
SELECT td_week_of_year(DATE '2010-05-04');
関連トピック
詳細は、以下を参照してください。
• <SQL 外部ルーチン プログラミング、B035-1147>の「関数名のオーバーロード」
• データ ディクショナリ 、B035-1092
td_week_of_calendar
目的
1900 年 1 月 1 日から始まるカレンダの最初の日から指定された日までの週の数を
返します。
SQL 関数、演算子、式および述部
417
第 9 章 CALENDAR 関数
td_week_of_calendar
構文
td_week_of_calendar
(expression)
SYSLIB.
構文要素
SYSLIB
関数が格納されているデータベースの名前。
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
td_week_of_calendar はオーバーロード スカラー関数です。この関数は以下に示す
パラメータのデータ タイプで定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は、1900 年 1 月 1 日からの週の数を表わす INTEGER 値になります。最初の 7
日に満たない週は 0 です。
使用上の注意
td_week_of_calendar 関数では、同様の結果を得るために Sys_Calendar.Calendar シ
ステム ビューを使用する方法に比べて、パフォーマンスが向上します。
例: カレンダの最初からの週数の問合わせ
現在の日付が 1901 年 1 月 10 日の場合、次の問合わせは結果として値 53 を返しま
す。これは、1901 年 1 月 10 日が 1900 年 1 月 1 日から 53 番目の週にあたるから
です。
418
SQL 関数、演算子、式および述部
第 9 章 CALENDAR 関数
td_month_of_quarter
SELECT td_week_of_calendar(CURRENT_DATE);
SELECT td_week_of_calendar(DATE '1901-01-10');
関連トピック
詳細は、以下を参照してください。
• オーバーロード関数の詳細については、<SQL 外部ルーチン プログラミング、
B035-1147>の「関数名のオーバーロード」を参照してください。
• データ ディクショナリ 、B035-1092
td_month_of_quarter
目的
四半期の初めから指定された日までの月数を返します。
構文
td_month_of_quarter
(expression)
SYSLIB.
構文要素
SYSLIB
関数が格納されているデータベースの名前。
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
td_month_of_quarter はオーバーロード スカラー関数です。この関数は以下に示す
パラメータのデータ タイプで定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
SQL 関数、演算子、式および述部
419
第 9 章 CALENDAR 関数
td_month_of_year
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は 1 から 3 の INTEGER 値になります。
使用上の注意
td_month_of_quarter 関数では、同様の結果を得るために Sys_Calendar.Calendar シ
ステム ビューを使用する方法に比べて、パフォーマンスが向上します。
例: 四半期の最初からの月数の問合わせ
現在の日付が 2010 年 6 月 12 日の場合、次の問合わせは結果として値 3 を返しま
す。これは、2010 年 6 月 12 日が第 2 四半期の 3 番目の月にあたるからです。
SELECT td_month_of_quarter(CURRENT_DATE);
SELECT td_month_of_quarter(DATE '2010-06-12');
関連トピック
詳細は、以下を参照してください。
• SQL 外部ルーチン プログラミング、B035-1147
• データ ディクショナリ 、B035-1092
td_month_of_year
目的
年初め(1 月 1 日)から指定された日までの月数を返します。
構文
td_month_of_year
(expression)
SYSLIB.
構文要素
SYSLIB
関数が格納されているデータベースの名前。
420
SQL 関数、演算子、式および述部
第 9 章 CALENDAR 関数
td_month_of_year
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
td_month_of_year はオーバーロード スカラー関数です。この関数は以下に示すパ
ラメータのデータ タイプで定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は 1 から 12 の INTEGER 値になります。
使用上の注意
td_month_of_year 関数では、同様の結果を得るために Sys_Calendar.Calendar シス
テム ビューを使用する方法に比べて、パフォーマンスが向上します。
例: 年の最初からの月数の問合わせ
現在の日付が 2010 年 8 月 29 日の場合、次の問合わせは結果として値 8 を返しま
す。これは、2010 年 8 月 29 日がその年の 8 番目の月にあたるからです。
SELECT td_month_of_year(CURRENT_DATE);
SELECT td_month_of_year(DATE '2010-08-29');
関連トピック
詳細は、以下を参照してください。
• <SQL 外部ルーチン プログラミング、B035-1147>の「関数名のオーバーロード」
• データ ディクショナリ 、B035-1092
SQL 関数、演算子、式および述部
421
第 9 章 CALENDAR 関数
td_month_of_calendar
td_month_of_calendar
目的
1900 年 1 月 1 日から始まるカレンダの最初の日から指定された日までの月数を返
します。
構文
td_month_of_calendar
(expression)
SYSLIB.
構文要素
SYSLIB
関数が格納されているデータベースの名前。
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
td_month_of_calendar はオーバーロード スカラー関数です。この関数は以下に示す
パラメータのデータ タイプで定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は、1900 年 1 月からの月数(同月を含む)を表わす INTEGER 値です。
使用上の注意
td_month_of_calendar 関数では、同様の結果を得るために Sys_Calendar.Calendar
システム ビューを使用する方法に比べて、パフォーマンスが向上します。
422
SQL 関数、演算子、式および述部
第 9 章 CALENDAR 関数
td_quarter_of_year
例: 暦年の最初からの月数の問合わせ
現在の日付が 1901 年 8 月 29 日の場合、次の問合わせは結果として値 20 を返しま
す。これは、1901 年 8 月 29 日が 1900 年 1 月 1 日から 20 番目の月にあたるから
です。
SELECT td_month_of_calendar(CURRENT_DATE);
SELECT td_month_of_calendar(DATE '1901-08-29');
関連トピック
詳細は、以下を参照してください。
• <SQL 外部ルーチン プログラミング、B035-1147>の「関数名のオーバーロード」
• データ ディクショナリ 、B035-1092
td_quarter_of_year
目的
指定された日に対する、その年の四半期の番号を返します。
構文
td_quarter_of_year
(expression)
SYSLIB.
構文要素
SYSLIB
関数が格納されているデータベースの名前。
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
td_quarter_of_year はオーバーロード スカラー関数です。この関数は以下に示すパ
ラメータのデータ タイプで定義されます。
SQL 関数、演算子、式および述部
423
第 9 章 CALENDAR 関数
td_quarter_of_calendar
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は 1 から 4 の INTEGER 値になります。これは、年初めからの四半期の数を表わ
します。1 は第 1 四半期(1 月、2 月、3 月)、4 は第 4 四半期(10 月、11 月、12 月)
です。
使用上の注意
td_quarter_of_year 関数では、同様の結果を得るために Sys_Calendar.Calendar シス
テム ビューを使用する方法に比べて、パフォーマンスが向上します。
例: その年の何番目の四半期であるかを問合わせる
現在の日付が 1983 年 11 月 14 日の場合、次の問合わせは結果として値 4 を返しま
す。これは、1983 年 11 月 14 日がその年の第 4 四半期にあたるからです。
SELECT td_quarter_of_year(CURRENT_DATE);
SELECT td_quarter_of_year(DATE '1983-11-14');
関連トピック
詳細は、以下を参照してください。
• <SQL 外部ルーチン プログラミング、B035-1147>の「関数名のオーバーロード」
• データ ディクショナリ 、B035-1092
td_quarter_of_calendar
目的
1900 年 1 月 1 日から始まるカレンダの最初の日から指定された日までの四半期の
数を返します。
構文
td_quarter_of_calendar
(expression)
SYSLIB.
424
SQL 関数、演算子、式および述部
第 9 章 CALENDAR 関数
td_quarter_of_calendar
構文要素
SYSLIB
関数が格納されているデータベースの名前。
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
td_quarter_of_calendar はオーバーロード スカラー関数です。この関数は以下に示
すパラメータのデータ タイプで定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
結果
結果は、1900 年の第 1 四半期からの四半期の数(当該の四半期を含む)を表わす
INTEGER 値です。
使用上の注意
td_quarter_of_calendar 関数では、同様の結果を得るために Sys_Calendar.Calendar
システム ビューを使用する方法に比べて、パフォーマンスが向上します。
例: カレンダの最初からの四半期数の問合わせ
現在の日付が 1901 年 11 月 14 日の場合、次の問合わせは結果として値 8 を返しま
す。これは、1901 年 11 月 14 日が 1900 年 1 月 1 日から 8 番目の四半期にあたる
からです。
SELECT td_quarter_of_calendar(CURRENT_DATE);
SELECT td_quarter_of_calendar(DATE '1901-11-14');
SQL 関数、演算子、式および述部
425
第 9 章 CALENDAR 関数
td_year_of_calendar
関連トピック
詳細は、以下を参照してください。
• <SQL 外部ルーチン プログラミング、B035-1147>の「関数名のオーバーロード」
• データ ディクショナリ 、B035-1092
td_year_of_calendar
目的
指定した日の年を返します。
構文
td_year_of_calendar
(expression)
SYSLIB.
構文要素
SYSLIB
関数が格納されているデータベースの名前。
expression
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプ
td_year_of_calendar はオーバーロード スカラー関数です。この関数は以下に示すパ
ラメータのデータ タイプで定義されます。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
関数に渡される引数が、これらの宣言されたデータ タイプの 1 つと一致しない場
合、関数が存在しないことを示すエラーが返されます。
426
SQL 関数、演算子、式および述部
第 9 章 CALENDAR 関数
td_year_of_calendar
結果
結果は、指定した日の年を表わす、4 桁形式の INTEGER 値です。
使用上の注意
td_year_of_calendar 関数では、同様の結果を得るために Sys_Calendar.Calendar シ
ステム ビューを使用する方法に比べて、パフォーマンスが向上します。
例: 指定した日の年の問合わせ
現在の日付が 1977 年 11 月 14 日の場合、次の問合わせは結果として値 1977 を返
します。これは指定した日の年です。
SELECT td_year_of_calendar(CURRENT_DATE);
SELECT td_year_of_calendar(DATE '1977-11-14');
関連トピック
詳細は、以下を参照してください。
• <SQL 外部ルーチン プログラミング、B035-1147>の「関数名のオーバーロード」
• CALENDAR システム ビューについて、詳細は<データ ディクショナリ 、
B035-1092>を参照してください。
SQL 関数、演算子、式および述部
427
第 9 章 CALENDAR 関数
td_year_of_calendar
428
SQL 関数、演算子、式および述部
第 10 章
比較演算子と関数
概要
この章では、SQL 比較演算子について説明します。
比較演算子
目的
比較演算子は論理述部の一種であり(条件式とも呼ばれます)、式間の関係の真偽を
テストします。
• ストアド プロシージャ内の IF、WHILE、REPEAT、および CASE 文
• 検索形式の CASE 式内の WHEN 句
• SELECT 文中の行を修飾または修飾解除するための WHERE、ON、および HAVING
句
• CASE_N 関数
構文
expression_1
operator
expression_2
expression_1
operator
quantifier
expression_1
operator
expression_1
,
literal
)
( subquery )
quantifier
,
(
(
)
operator
( subquery )
quantifier
構文要素
operator
比較演算子のうちの 1 つ。
expression_1,
expression_2
SQL スカラー式。派生 PERIOD 式も含みます。
SQL 関数、演算子、式および述部
429
第 10 章 比較演算子と関数
比較演算子
quantifier
次の数量詞キーワードの 1 つ。
• ANY
• SOME
• ALL
literal
1 つ以上のリテラル値。リテラルは、次のいずれかになります。
• 定義された値
• マクロ パラメータ
• TIME、DATE、または USER などの組み込み値
比較演算では、明示リテラルのリストに対して式を比較することができます。
式およびリテラルのデータ型には、互換性が必要です。オペランドのデータ型が異
なる場合には、Teradata Database は一方のタイプから他方のタイプへの暗黙の変換
を実行することがあります。
subquery
SQL の SELECT 文。
条件の中で subquery を使用することが制限される場合もあります。
scalar_expression
2 番目の scalar_expression との比較で評価される式。派生 PERIOD も含みます。
比較演算子は BLOB または CLOB タイプの式をサポートしていません。BLOB を BYTE
または VARBYTE に、CLOB を CHARACTER または VARCHAR に明示的にキャスト
し、結果を比較演算子と一緒に使用することができます。
結果が UDT データ タイプになる式が比較できるのは、結果が同じ UDT データ タイ
プになる別の式とだけです。
comparison_operator
真偽を評価される比較のタイプ。
結果
比較演算子を使用する論理式は TRUE、FALSE、または UNKNOWN と評価されます。
ANSI への準拠
次の比較演算子は、ANSI SQL:2011 に準拠しています。
• =
• <
• <=
• >
• <>
• >=
次の比較演算子は、ANSI SQL:2011 規格の Teradata 拡張機能です。使用は推奨され
ません。
430
SQL 関数、演算子、式および述部
第 10 章 比較演算子と関数
比較演算子
• EQ
• NOT=
• GT
• ^=
• LT
• GE
• NE
• LE
サポートされる比較演算子
Teradata Database は次の比較演算子をサポートしています。
ANSI 演算子
Teradata の拡張部分
関数
=
EQ
等しいかどうかをテストします。
<>
^=
NE
NOT=
等しくないかどうかをテストし
ます。
<
LT
より小さいかどうかをテストし
ます。
<=
LE
より小さい、または等しいかど
うかをテストします。
>
GT
より大きいかどうかをテストし
ます。
>=
GE
より大きい、または等しいかど
うかをテストします。
SUBQUERY を使用する比較演算子
Subquery とは、比較演算子の条件を満たすために使用する値を返す SELECT 文で
す。Subquery は、括弧で囲む必要があります。また、末尾にセミコロンを使いませ
ん。
Subquery は、少なくとも 1 つのテーブルを参照する必要があります。WHERE 句に
テーブルを指定した場合、そのテーブルが subquery の他の部分から参照されてい
なければ、その指定はこの条件に当てはまりません。
比較演算子は、修飾子を使うかどうかにかかわりなく、subquery と一緒に使用する
ことができます。ただし、修飾子を使用しない場合、subquery が複数の値を返す
と、エラー条件が発生します。
Subquery が値を返さない場合で、なおかつ修飾子を使用しない場合は、比較の結果
が偽になります。したがって、以下の形式を使用した場合、subquery は、値を返さ
ないか(その場合は比較が偽と評価されます)、1 つの値を返すことになります。
expression > (subquery)
以下の形式の場合、subquery は、式リストで指定する数と同じ数の式を選択する必
要があります。
SQL 関数、演算子、式および述部
431
第 10 章 比較演算子と関数
TRUE の結果を生じる比較
(
,
expression
)
comparison_operator
ALL
ANY
SOME
( subquery )
それぞれの式が等しければ、2 つの式リストは等しいことになります。
それぞれの式が等しくない場合、比較の結果は、比較が真ではない式の最初のペア
(左から見て)を比較することによって判別されます。
比較操作での subquery で SELECT AND CONSUME 文を指定することはできません。
例: ALL 数量詞を使って 2 つの式を比較する
以下の文は、ALL 修飾子を使って、subquery から返される値を含む 2 つの式を比較
して、最高給の社員グループの中で勤続年数の最も多い社員を調べます。
SELECT EmpNo, Name, DeptNo, JobTitle, Salary, YrsExp
FROM Employee
WHERE (Salary,YrsExp) >= ALL
(SELECT Salary,YrsExp FROM Employee) ;
関連トピック
詳細は、以下を参照してください。
• 「サポートされる比較演算子」
• 「比較オペランドの暗黙の型変換」
• 「ANY/ALL/SOME 数量詞」
TRUE の結果を生じる比較
条件
以下の表は、比較が TRUE の結果を生じる場合の条件を示しています。
分かりやすくするために、次のような構文を想定します。
expression_1 — operator — expression_2
expression_1 および
expression_2 の r 番目の構成要素が expression_1r および expression_2r となるよう
に、expression_1 と expression_2 には、r で表わされる同じ数のスカラー値と、1
から n 行までの範囲が含まれている必要があります。
expression_1 の δ 番目の構成要素が expression_1δ、expression_2 の δ 番目の構
成要素が expression_2δ と表記されるように、範囲内の δ 番目の項目は行 δ と表
記されます。
432
SQL 関数、演算子、式および述部
第 10 章 比較演算子と関数
TRUE の結果を生じる比較
expression_1 および expression_2 のデータ型には互換性がなければなりません。
式のデータ型が異なる場合、Teradata Database は一方の型から他方の型への暗黙の
変換を実行することがあります。
比較
TRUE になる条件
expression_1 =
expression_2
∀ r, expression_1r = expression_2r は TRUE
expression_1 <>
expression_2
∃ δ(expression_1δ <> expression_2δ は TRUE)
expression_1 <
expression_2
∃ δ(expression_1δ < expression_2δ は TRUE)、すべての
r < δ に対し、expression_1r = expression_2r は TRUE
expression_1 >
expression_2
∃ δ such that expression_1δ >expression_2δ is TRUE and
for all r > δ, expression_1r = expression_2r is TRUE.
expression_1 <=
expression_2
expression_1 < expression_2 は TRUE、または
expression_1 = expression_2 は TRUE
expression_1 =>
expression_2
expression_1 > expression_2 is TRUE or
expression_1 = expression_2 is TRUE.
NULL 式
比較におけるいずれかの式が null であると、比較の結果は不明です。
結果として NULL になる可能性のあるフィールドを比較する場合に比較で真の結果
を得るためには、その文で IS [NOT] NULL 演算子を使用しなければなりません。
浮動小数点値の式
浮動小数点値が関係する計算では、予想外の結果が出ることがあります。浮動小数
点値の計算を実行し、結果を予測値と比較すると、意図した結果にならない場合が
ほとんどです。
浮動小数点値の計算結果を比較する代わりに、エラーを参照して、結果が意図した
ものより大きいか小さいかを確認します。以下に例を示します。
SELECT i, SUM(a) as sum_a, SUM(b) as sum_b
FROM t1
GROUP BY i
HAVING ABS(sum_a - sum_b) > 1E-10;
関連トピック
詳細は、以下を参照してください。
SQL 関数、演算子、式および述部
433
第 10 章 比較演算子と関数
データ タイプの評価
• 比較操作での浮動小数点値に関連する潜在的な問題の詳細は、< SQL データ型と
リテラル、B035-1143>を参照してください。
• expression_1 および expression_2 の詳細については、比較オペランドの暗黙的
なタイプ変換を参照してください。
• 検索形式の CASE 式内の条件式での比較演算子の使用については、概要を参照し
てください。
• SELECT 文中の WHERE、ON、または HAVING 句内の条件式での比較演算子の使
用については、< SQL データ操作言語、B035-1146>の「 SELECT 文」を参照し
てください。
• ストアド プロシージャの IF、WHILE、または REPEAT 文中の条件式での比較演
算子の使用については、<SQL ストアード プロシージャと埋め込み SQL、
B035-1148>を参照してください。
• 以下を含む他の比較演算子の詳細:
• [NOT] EXISTS
• [NOT] IN
• LIKE
• IS [NOT] NULL
• [NOT] BETWEEN … AND …
概要を参照してください。
• 述部数量詞に関する詳細な情報:
• ALL
• ANY
• SOME
概要を参照してください。
データ タイプの評価
データ型が異なれば、等号と不等号の定義も異なります。次の表では、さまざまな
データ タイプを評価するときの基本について説明します。
データ型
評価方法
数値
代数学的に、負数は、その絶対値とは関係なくより小さいとみなされます。
バイト
左から右へとビットごとに評価されます。0 ビットは 1 ビットより小さくなり
ます。
• すべての対の比較が等しい場合、2 つのバイト列は等しいです。
• 対の比較がいずれも等しくない場合、その比較によって結果が判定されます。
• 長さが異なる 2 つのバイト列が比較される場合、長さが等しくなるように短
い方の文字列の右側に 2 進数のゼロが埋め込まれてから比較されます。
文字
434
左から右へと文字ごとに評価されます。正確な比較は割り当てられている照合
順序と、大文字と小文字を区別して比較するかどうかによって異なります。
SQL 関数、演算子、式および述部
第 10 章 比較演算子と関数
比較オペランドの暗黙的なタイプ変換
データ型
評価方法
使用可能な照合は、次のとおりです。
• ASCII
• EBCDIC
• MULTINATIONAL
• CHARSET_COLL
• JIS_COLL
すべての対の比較が等しい場合、2 つの文字列は等しいです。
対の比較がいずれも等しくない場合、その比較によって結果が判定されます。
文字比較の詳細は、「文字列の比較」を参照してください。
日時
年代順。
タイムゾーンが時間の比較にどのように影響するかについては、「タイムゾー
ンの整列順序」を参照してください。
間隔
符号および絶対値に従います。
期間
例えば、p1 および p2 が期間式または派生 PERIOD だとすると、期間比較述部
の評価には次のロジックを使用します。
IF BEGIN(p1) = BEGIN(p2) is TRUE, return END(p1) operator END(p2)
ELSE return (BEGIN(p1) operator BEGIN(p2))
BEGIN および END の詳細については、概要を参照してください。
UDT
UDT の順序付け定義に従います。
Teradata Database は、ソース タイプが LOB でない DISTINCT 型 UDT の順序付
け機能を生成します。STRUCTURED 型 UDT またはソース タイプが LOB であ
る DISTINCT 型 UDT の順序付け定義を作成するときや、システム生成の順序付
け機能を置き換えるときは、CREATE ORDERING を使用します。
CREATE ORDERING の詳細は、<SQL データ定義言語 - 構文規則および例、
B035-1144>を参照してください。
比較オペランドの暗黙的なタイプ変換
式のオペランドは、比較が行なわれる前に、同じデータ タイプになっていなければ
なりません。
SQL 関数、演算子、式および述部
435
第 10 章 比較演算子と関数
比較オペランドの暗黙的なタイプ変換
暗黙変換の実行対象になるデータ タイプ
オペランドのデータ型が異なる場合には、次の表に従って暗黙の変換が Teradata
Database によって実行されます。暗黙変換は、ANSI SQL:2011 規格の Teradata 拡
張機能です。
文字データ タイプと数値データ タイプの比較では、文字フィールドを数値に変換で
きることが必要です。
式のオペランド
もう一方の式のオペランド
Teradata Database によるデータの比較
内容
文字
文字
文字
詳細については、「文字列の比較」を参照
してください。
DATE
Date
Teradata Database により、GRAPHIC サー
バー文字セットを使った文字データに対し
てエラーが返されます。
CHAR(k)
VARCHAR(k))
BYTEINT
SMALLINT
INTEGER
FLOAT
FLOAT
期間
期間
BIGINT
DECIMAL(m,n)
FLOAT
DECIMAL(m,n)
FLOAT
このとき、m <= 16
Teradata Database により、GRAPHIC サー
バー文字セットを使った文字データに対し
てエラーが返されます。
BIGINT
DECIMAL(m,n)
Teradata Database により、エラーが返さ
れます。
このとき、k <=
16
CHAR(k)
VARCHAR(k)
このとき、k > 16
Teradata Database により、GRAPHIC サー
バー文字セットを使った文字データに対し
てエラーが返されます。
Teradata Database により、GRAPHIC サー
バー文字セットを使った文字データに対し
てエラーが返されます。
このとき、m > 16
CHAR(k)
VARCHAR(k)
436
NUMBER および k <= 16
FLOAT
Teradata Database により、GRAPHIC サー
バー文字セットを使った文字データに対し
てエラーが返されます。
SQL 関数、演算子、式および述部
第 10 章 比較演算子と関数
比較オペランドの暗黙的なタイプ変換
式のオペランド
もう一方の式のオペランド
Teradata Database によるデータの比較
内容
NUMBER および k > 16
Teradata Database により、エラーが返さ
れます。
BYTEINT
SMALLINT
SMALLINT
BYTEINT
SMALLINT
INTEGER
INTEGER
BYTEINT
SMALLINT
INTEGER
BIGINT
BIGINT
BIGINT
BYTEINT
DECIMAL(m,n)
DECIMAL(18,n)
m <= 18 および m-n >= 3
SMALLINT
DECIMAL(m,n)
m <= 18 および m-n >= 5
INTEGER
DECIMAL(m,n)
DATE
m <= 18 および m-n >= 10
BYTEINT
DECIMAL(m,n)
DECIMAL(38,n)
m > 18 または m-n < 3
SMALLINT
DECIMAL(m,n)
m > 18 または m-n < 5
INTEGER
DECIMAL(m,n)
DATE
m > 18 または m-n < 10
BIGINT
DECIMAL(m,n)
DECIMAL(m,n)
DECIMAL(k,j)
DECIMAL(18,max(j,n))
max(m-n,k-j) + max(j,n) <= 18
DECIMAL(k,j)
DECIMAL(38,max(j,n))
max(m-n,k-j) + max(j,n) > 18
BYTEINT
SMALLINT
INTEGER
BIGINT
DECIMAL(m,n)
NUMBER(m,n)
SQL 関数、演算子、式および述部
NUMBER(k,j)
NUMBER(k)
NUMBER(*,j)
NUMBER
NUMBER
437
第 10 章 比較演算子と関数
比較オペランドの暗黙的なタイプ変換
式のオペランド
もう一方の式のオペランド
Teradata Database によるデータの比較
内容
BYTEINT
SMALLINT
INTEGER
INTEGER
BIGINT
BIGINT
FLOAT
FLOAT
FLOAT
BYTEINT
SMALLINT
INTEGER
BIGINT
DECIMAL(m,n)
NUMBER(m,n)
NUMBER(m)
NUMBER(*,n)
NUMBER
FLOAT
期間
文字
期間
NUMBER(m)
NUMBER(*,n)
NUMBER
DATE
日時タイプの暗黙の変換
異なる日時オペランドが関与する比較では、Teradata Database は次のテーブルに
従って暗黙的変換を行ないます。
式のオペランド
もう一方の式のオペラ
ンド
Teradata Database によるデータの比較内容
TIMESTAMP
DATE
DATE
TIMESTAMP WITH ANSIDate 日付形式モー 「TIMESTAMP から DATE への暗黙的変換」を参照してください。
ドまたは IntegerDate 日
TIME ZONE
付形式モード
間隔
INTERVAL タイプ
はフィールドが 1
つだけ必要です(た
とえば、INTERVAL
YEAR)。
438
絶対数値
数値。
「INTERVAL から数値への暗黙的変換」を参照してください。
SQL 関数、演算子、式および述部
第 10 章 比較演算子と関数
USING 句内の ANSI の DateTime と Interval の比較
暗黙変換の実行対象にならないデータ タイプ
次の表に、Teradata Database によって暗黙的な型変換が実行されないデータ型を示
します。
タイプ
規則
バイト
バイト データ タイプは、バイト データ タイプとのみ比較できます。バ
イト タイプと別のタイプを比較しようとすると、エラーが発生します。
日時
Teradata Database は、DateTime データ型と INTERVAL データ型の組み
合わせを使用した比較演算のオペランドに対し、暗黙の型変換は実行し
ません。詳細については、データ タイプの互換性および USING 句内の
ANSI の DateTime と Interval の比較を参照してください。
間隔
TIME
TIMESTAMP
UDT
Teradata Database は、比較演算での TIME から TIMESTAMP へ、また
TIMESTAMP から TIME への暗黙の型変換を実行しません。
Teradata Database は、比較演算での UDT に対しては暗黙の型変換を実行
しません。UDT 値は、同じ UDT 型の別の値としか比較できないからです。
UDT を他のデータ タイプと比較するには、明示的なデータ タイプ変換を
使用する必要があります。詳細は、概要を参照してください。
USING 句内の ANSI の DateTime と Interval の比較
ANSI の日時および間隔データの外部値は、セッション用に指定されているクライア
ント文字セットの固定長の文字列で表わされます。
USING 句を使って ANSI の日時および間隔の値をインポートする場合、外部文字書
式から、比較に適した ANSI 日時および間隔タイプに明示的に CAST する必要があ
ります。
たとえば、次のような文を考慮してみます。TimeField 列のデータ タイプは TIME(2)
です。
USING (TimeVal CHARACTER(11), NumVal INTEGER)
UPDATE TABLE_1
SET TimeField=:TimeVal, NumField=:NumVal
WHERE CAST(:TimeVal AS TIME(2)) > TimeField;
割り当てのためにこの USING 句で TimeVal CHAR(11)を直接使用してもかまいませ
んが、TimeField は TIME(2)と定義されている ANSI TIME であるために、テーブル
内のフィールド値 TimeField を比較するには、列データ定義を明示的に TIME(2)に
CAST する必要があります。
SQL 関数、演算子、式および述部
439
第 10 章 比較演算子と関数
比較における DATE タイプの正しい形式
比較における DATE タイプの正しい形式
正しい比較を実行するには、DATE オペランドを正しい形式で指定する必要がありま
す。
作成される日付が有効な日付でない場合、DATE オペランドによる計算はエラーを出
します。したがって、比較の目的で日付値を整数形式で指定することがあるとして
も、日付データが入っている列は、INTEGER ではなく、DATE データ タイプとして
定義する必要があります。
DATE への入力として整数を使用した場合(この方法はお勧めしません)、2000 年の
最初の日付の入力は、1000101 となります。
詳細は、Teradata の日付および時刻の式を参照してください。
DATE オペランドを実行するための正しい形式は、以下のとおりです。
• 整数は、「(年-1900)*10000 + 月*100 + 日」という形式にします。YYMMDD 形
式は、1900 年~1999 年の間にのみ有効です。2000 年~2099 年については、
1YYMMDD という形式になります。
• 比較対象の日付または割り当てが実行される日付フィールドと同じ形式の文字列。
• 適切なデータ変換を定義するデータ タイプ句と、書式を定義する FORMAT 句で
修飾した文字列。
• どんな日付書式による日付比較でも常に有効な ANSI 日付定数。
例
以下の例では、Employee.DOB 列(DATE FORMAT 'MMMbDDbYYYY'として定義)の値
に対して比較演算子を使用し、DATE オペランドの正しい形式を示します。
例 1: オペランドを整数として入力する
最初の例では、オペランドを整数として入力します。
SELECT *
FROM Employee
WHERE DOB = 420327 ;
例 2: DOB 列フォーマットと一致した形式での文字列の入力
2 番目の例では、DOB 列の書式と一致した形式で文字列を入力します。
SELECT *
FROM Employee
WHERE DOB = 'Mar 27 1942';
例 3: 文字列をデータ型および FORMAT 句とともに入力する
3 番目の例では、文字列として値を入力し、データ タイプ句(DATE)と FORMAT 句の
両方と一緒にキャストします。
440
SQL 関数、演算子、式および述部
第 10 章 比較演算子と関数
文字列の比較
SELECT *
FROM Employee
WHERE DOB = CAST ('03/27/42' AS DATE FORMAT 'MM/DD/YY');
例 4: 値を ANSI データ リテラルとして入力する
4 番目の例では、列の日付形式が何であっても正しく動作する ANSI 日付定数とし
て値を入力します。
SELECT *
FROM Employee
WHERE DOB = DATE '1942-03-27';
文字列の比較
長さが等しくない文字列の比較
長さが等しくない文字列が比較される場合、比較の前に、短い方の文字列の右側に
埋め込み文字が埋められます。
文字列およびサーバー文字セット
文字列を比較するときには、データ文字のサーバー文字セットが同じでなければな
りません。そうでない場合は、文字から文字への暗黙的な変換で説明されている暗
黙変換規則を使って、システムが変換を行ないます 。
照合が文字列比較に与える影響
照合は文字の順序付けを制御します。文字の比較の結果は、使用している文字セッ
トの照合順序によって異なります。
デフォルトの照合を、セッションの文字セットと互換性のある順序に設定すること
ができます。現行セッションの照合の設定値を調べるには、HELP SESSION SQL 文
を使用してください。
発音符または日本語文字セットの可用性、およびデフォルトの照合順は、データベー
ス管理者の制御下にあります。
文字データの整列と比較を、クライアントが実行した操作と同じように動作させる
ためには、日本語文字サイトのユーザーは、照合を CHARSET_COLL に設定しなけ
ればなりません。
大文字小文字の区別
Teradata SQL 文の実行時にアクセスされたすべての文字データ (CLOB を除く) に
は、デフォルトによって、または明示的に指定することによって、CASESPECIFIC
SQL 関数、演算子、式および述部
441
第 10 章 比較演算子と関数
文字列の比較
または NOT CASESPECIFIC の属性が与えられます。文字列の比較では、この属性に
よって大文字と小文字を区別して比較を行なうかどうかを決定します。CLOB には大
文字小文字の区別が適用されません。
この属性は、ANSI SQL:2011 互換ではありません。ANSI では、すべての文字比較が
CASESPECIFIC と同等に行なわれます。
CASESPECIFIC 属性は、NOT CASESPECIFC に優先します。
条件
比較
どちらかの引数が CASESPECIFIC の場合
英大文字/英小文字を区別して行なわれます。
両方の引数が NOT CASESPECIFIC の場合
大文字小文字の区別なし
例外は GRAPHIC 文字データで、この場合は常に CASESPECIFIC になります。
次の方法で大文字小文字の区別の属性を文字列に適用します。
• セッション用のデフォルトの大文字小文字の区別を使用する。
セッション モード
大文字小文字の区別のデフォルト
ANSI
CASESPECIFIC
TERADATA
NOT CASESPECIFIC
例外は GRAPHIC 型の文字データで、この場合は必ず
CASESPECIFIC になります。
大文字小文字の区別のデフォルトは、リテラルを含め、すべての文字データに適
用されます。
• CREATE TABLE または ALTER TABLE 文で、文字の列に CASESPECIFIC または
NOT CASESPECIFIC 句を使用する。
以下に例を示します。
CREATE TABLE Students
(StudentID INTEGER
,Firstname CHAR(10) CASESPECIFIC
,Lastname CHAR(20) NOT CASESPECIFIC);
テーブルの列では、列が定義または変更されたときに、割り当てられた属性が伝
達されます。 ただし、アクセスにおいて CASESPECIFIC または NOT
CASESPECIFIC 句が使用される場合は異なります。
• 比較で、CASESPECIFIC または NOT CASESPECIFIC 句を文字式に適用する。
たとえば、次の文では CASESPECIFIC 句を文字リテラルに適用します。
SELECT *
FROM Students
WHERE Firstname = 'Ike' (CASESPECIFIC);
442
SQL 関数、演算子、式および述部
第 10 章 比較演算子と関数
文字列の比較
この方法は、文字データの大文字小文字の区別のデフォルトをオーバーライドす
る場合、あるいは文字の列が定義または変更されたときに割り当てられた大文字
小文字の区別属性をオーバーライドする場合に使用します。
大文字小文字を区別しない比較では、英小文字の 1 バイトのローマ字は英大文字に
変換されてから、比較が始まります。作成された文字列はバイトごとに比較され、
後ろに付けられた埋め込み文字は無視されます。
大文字小文字を区別しない比較では、小文字と大文字のキリル文字、ギリシャ文字、
および全角の ASCII 文字は常に同等とみなされます。小文字と大文字のキリル文字、
ギリシャ文字、および全角の ASCII 文字を区別するためには、明示的に
CASESPECIFIC の比較を宣言しなければなりません。
これらのオプションは KANJISJIS 文字セットに対して機能します。その際、そのデー
タがまず UNICODE 型に変換され、次いでオプションが適用されるかのように扱わ
れます。
大文字小文字を区別しない比較における UPPER の使用
UPPER 関数を使用して文字列の値に小文字の Latin 文字が含まれないようにするこ
とにより、大文字小文字を区別しない比較を行なうことができます。
UPPER 関数は、UPPERCASE 値を宣言することと同じではありません。
例: 大文字小文字が区別される名前の問合わせ
次の問合わせについて説明します。
SELECT *
FROM STUDENTS
WHERE Firstname = 'George';
この後のテーブルでは、さまざまな大文字/小文字区別属性やセッション モードに
おける比較 Firstname = 'George'の動作について説明します。
列 Firstname の 結果
属性
CASESPECIFIC
• セッション モードが ANSI である場合、「George」は CASESPECIFIC
となり、Firstname に「George」が含まれる行と一致する。
• セッション モードが Teradata である場合、「George」は NOT
CASESPECIFIC となり、Firstname に「George」が含まれる行と一致
する。
どちらかの文字列が CASESPECIFIC の場合、比較は大文字小文字を区別し
て行なわれる。
SQL 関数、演算子、式および述部
443
第 10 章 比較演算子と関数
KANJI1 文字の比較
列 Firstname の 結果
属性
NOT
CASESPECIFIC
• セッション モードが ANSI である場合、「George」は CASESPECIFIC
となり、Firstname に「George」が含まれる行と一致する。どちらか
の文字列が CASESPECIFIC の場合、比較は大文字小文字を区別して行
なわれる。
• セッション モードが Teradata である場合、「George」は NOT
CASESPECIFIC となり、「george」、「GEORGE」、「George」など
大文字と小文字を任意に組み合わせた George という名前が Firstname
に含まれる行と一致する。両方の文字列が NOT CASESPECIFIC の場
合、比較は大文字小文字を区別しないで行なわれる。
関連トピック
詳細は、以下を参照してください。
• <SQL データ定義言語 - 構文規則および例、B035-1144>の「SET SESSION
COLLATION」
• 国際文字セットのサポート、B035-1125
• < SQL データ操作言語、B035-1146>の「ORDER BY 句」
KANJI1 文字の比較
次の節では、Teradata Database による KANJI1 文字の比較方法について説明します。
注記: Teradata の国際化計画に従って、KANJI1 のサポートはサポート外になりました。この
サポートは、近い将来に廃止される予定です。KANJI1 はデフォルトの文字セットとし
て許可されません。システムはデフォルトの KANJI1 文字セットを UNICODE 文字セッ
トに変更します。KANJI1 の新規オブジェクトの作成は、高度に制限されています。
KANJI1 を使用する問合わせやアプリケーションの多くは、従来通り動作しますが、
KANJI1 を使用するサイトはできるだけ早く別の文字セットに変換する必要があります。
詳細については、<国際文字セットのサポート、B035-1125>の KANJI1 文字セットを参
照してください。
等価比較
文字列の比較には、1 バイト文字とマルチバイト文字が混在したデータが含まれて
いてもかまいません。次のように処理されます。
• expression_1 と expression_2 のサーバー文字セットが異なる場合、それらは同
じ型に変換されます。詳細については、「文字から文字への暗黙変換」を参照し
てください。
• expression_1 と expression_2 の長さが異なる場合には、同じ長さになるよう、
短い方の文字列に埋め込み文字が埋め込まれます。
444
SQL 関数、演算子、式および述部
第 10 章 比較演算子と関数
KANJI1 文字の比較
• セッション モードが識別されます。
適用される
モード
文字列の大文字小文字の区別のデフォルト
ANSI
CASESPECIFIC
TERADATA
NOT CASESPECIFIC
式の一方または両方に CASESPECIFIC 句を指定していない限り、
expression_1 および expression_2 の単純なローマ字は、比較の開始に
先立って英大文字に変換されます。
文字式の大文字小文字の区別のデフォルトをオーバーライドするには、
CASESPECIFIC または NOT CASESPECIFIC 句を適用します。
• 大文字小文字の区別が判別されます。
条件
比較
どちらかの引数が CASESPECIFIC の場合
英大文字/英小文字を区別して行なわれま
す。
両方の引数が NOT CASESPECIFIC の場合
大文字小文字の区別なし
• 末尾の埋め込み文字は無視されます。
不等価比較
不等価比較は、次のように処理されます。
1 expression_1 と expression_2 の長さが異なる場合には、同じ長さになるよう、
短い方の文字列に埋め込み文字が埋め込まれます。
2 セッション モードが識別されます。
適用される
モード
文字列の大文字小文字の区別のデフォルト
ANSI
CASESPECIFIC
TERADATA
NOT CASESPECIFIC
式の一方または両方に CASESPECIFIC 修飾子を指定していない限り、
expression_1 および expression_2 の単純なローマ字は、比較の開始に
先立って英大文字に変換されます。
文字式の大文字小文字の区別のデフォルトをオーバーライドするには、
CASESPECIFIC または NOT CASESPECIFIC 句を適用します。
3 現在の文字セット下で 1 バイト文字として識別されている文字は、セッション
で有効な照合順序に従って変換されます。
SQL 関数、演算子、式および述部
445
第 10 章 比較演算子と関数
述部における比較演算子と DEFAULT 関数
4 KanjiEUC 文字セット下の場合、ss3 の 0x8F 文字は、0xFF に変換されることに
注意する必要があります。これは、ユーザー定義の KanjiEUC コードセット 3 は、
他の KanjiEUC コードセットのように正しく整列されないことを意味します。
他の KanjiEUC コードセットでは、整列が正しく行なわれます。 つまり、整列
は、クライアント システムでの 2 進数の整列の場合と同じ順序になります。
5 作成された文字列はバイトごとに比較され、後ろに付けられた埋め込み文字は無
視されます。
不等価比較には、そのセッションで有効な照合が使用されます。使用可能な照合は、
5 つあります。
•
•
•
•
•
EBCDIC
ASCII
MULTINATIONAL
CHARSET_COLL
JIS_COLL
CREATE USER 文または MODIFY USER 文の COLLATION オプションを使用すれば、
照合をユーザー レベルで設定することができます。 また、[[.]SET]SESSION
COLLATION 文または CLIv2 CHARSET 呼出しを使用すれば、セッション レベルで設
定することができます。
MULTINATIONAL 照合順序が有効な場合には、日本語文字を使用するサイトでの照
合順序は、開始時に導入された照合の設定によって決定されます。
関連トピック
照合順序についての詳細は、<国際文字セットのサポート、B035-1125>を参照して
ください。
述部における比較演算子と DEFAULT 関数
DEFAULT 関数は、列のデフォルト値を返します。これには、 列名を指定する形式
と、列名を省略する形式があります。
比較演算子を使用した述部は、両方の形式の DEFAULT 関数をサポートしています
が、DEFAULT 関数が列名を省略した場合は、次の条件が TRUE になります。
• 比較には、単一の列参照のみを含めることができる。
• DEFAUL 関数は、式の一部にはできない。
たとえば、次の文は DEFAULT 関数を使用して Dept_No 列の値と Dept_No 列のデ
フォルト値を比較しています。比較操作には、単一の列参照が含まれるため、列名
が省略されていても、Teradata Database は DEFAULT 関数の列の文脈を派生できま
す。
SELECT * FROM Employee WHERE Dept_No < DEFAULT;
446
SQL 関数、演算子、式および述部
第 10 章 比較演算子と関数
DECODE
DEFAULT 関数が NULL と評価されると、述部は不明になり、WHERE 条件は FALSE
になります。
DECODE
目的
expr と各 search パラメータを比較します。このパラメータは、それに対応する結
果パラメータを持ちます。
構文
10
DECODE
( exp ,
search , result ,
default )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expr
数値または文字式。
• expr が search 引数のいずれかと等しい場合、この関数はそれに対応する result
値を返します。
• expr が search 引数のいずれとも等しくならない場合、この関数は default を返
します(デフォルト値が指定されている場合)。
• expr が NULL の場合、この関数は NULL である最初の検索パラメータの結果を
返します。
search
数値または文字式。
DECODE は、1~10 個までの search 引数をサポートします。この引数には、同じ
数の結果引数が関連付けられます。
result
数値または文字式。
DECODE は、1~10 個までの結果引数をサポートします。この引数には、同じ数の
search 引数が関連付けられます。
default
数値または文字式。
default が指定されていないときに一致がない場合、この関数は NULL を返します。
SQL 関数、演算子、式および述部
447
第 10 章 比較演算子と関数
DECODE
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
DECODE は埋め込みサービス システム関数です。埋め込みサービス関数の有効化と
呼び出しについて、詳細は埋め込みサービス システム関数 を参照してください。
引数のタイプと規則
この関数に渡される式は、次のいずれかのデータ タイプでなければなりません。
BYTEINT、SMALLINT、INTEGER、BIGINT、DECIMAL/NUMERIC、FLOAT/REAL/
DOUBLE PRECISION、NUMBER、CHAR、VARCHAR
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
結果のタイプ
DECODE は、関数に渡された結果パラメータに関連付けられたデータ タイプによっ
て戻り値のデータ タイプが異なるスカラー関数です。
• 結果または default が数値タイプの場合、DECODE は最も高い精度を持つ引数を
特定し、その他の結果または default 引数をそのデータ型に変換して、そのデー
タ型を返します。
そのデータ タイプが DECIMAL/NUMERIC であり、結果または default の引数の
精度とスケールが異なる場合、戻りタイプの精度とスケールは最大精度になるよ
うに設定されます。
例えば、結果/default 引数が DECIMAL(6,3)、DECIMAL(7,4)、および
DECIMAL(8,7)の場合、精度の低下を避けるために、戻りタイプは小数点の左が 3
桁、右が 7 桁必要になります。この場合、返されるデータ タイプは
DECIMAL(10,7)に設定されます。
最大精度を維持できない場合、データは DBS 制御の RoundHalfWayMagUp フィー
ルドに基づいて丸められます。例えば、結果および default 引数が DECIMAL(32,
8)と DECIMAL(30, 28)の場合、戻りタイプは DECIMAL(38,14)になります。これ
により、DECIMAL(32, 8)に必要な小数点の左側の 24 桁と、小数点の右側の 14
桁を用意します。DECIMAL(30,28)の結果または default 引数が最大値だとする
と、その値は小数点から右側の 14 桁目で丸められます。
448
SQL 関数、演算子、式および述部
第 10 章 比較演算子と関数
DECODE
データ タイプが固定小数点数の NUMBER で精度が 38 以下の場合、戻りタイプ
の精度とスケールは、DECIMAL/NUMERIC と同じメソッドを使用して計算され
ます。ただし、精度が 38 より大きい場合は、精度の低下を避けるために戻りタ
イプを NUMBER(*)に変更します。データ タイプが浮動小数点の NUMBER の場
合、戻りタイプは NUMBER(*)になります。
• 結果または default が文字データ タイプの場合、この関数は最初の result 引数の
文字セットで VARCHAR を返します。
例
例: ID のデコード
以下の問合わせを実行します。
SELECT DECODE(country_id, 1, 'United States',
2, 'England',
3, 'France',
'United States')
FROM customers;
次の結果が得られます。
•
•
•
•
country_id が 1 の場合、'United States'
country_id が 2 の場合、'England'
country_id が 3 の場合、'France'
country_id が 1、2、または 3 と等しくない場合、'United States'
例: NULL を使った ID のデコード
以下の問合わせを実行します。
SELECT DECODE(country_id, 1, 'United States',
2, 'England')
FROM customers;
次の結果が得られます。
• country_id が 1 の場合、'United States'
• country_id が 2 の場合、'England'
• country_id が 1~2 の範囲にない場合、NULL
例: ID が 1、2、または NULL に等しくない場合の ID のデコード
以下の問合わせを実行します。
SELECT DECODE(country_id, 1, 'United States',
2, 'England',
NULL, 'France')
FROM customers;
SQL 関数、演算子、式および述部
449
第 10 章 比較演算子と関数
GREATEST
次の結果が得られます。
•
•
•
•
country_id が 1 の場合、'United States'
country_id が 2 の場合、'England'
country_id が NULL の場合、NULL
country_id が 1、2、または NULL と等しくない場合、NULL
関連トピック
詳細は、以下を参照してください。
• 優先順位の順序の詳細については、<SQL 外部ルーチン プログラミング、
B035-1147>の「互換データ型」を参照してください。
• DOUBLE PRECISION のデフォルトのデータ タイプ書式については、< SQL データ
型とリテラル、B035-1143>を参照してください。
GREATEST
目的
入力引数のリストの最大値を返します。
構文
,
GREATEST
TD_SYSFNLIB.
10
( numeric_value )
,
10
( string_value )
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
numeric_value
数値式。
string_value
文字列の値。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
450
SQL 関数、演算子、式および述部
第 10 章 比較演算子と関数
GREATEST
呼出し
GREATEST は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡された式は、次のデータ タイプを持っている必要があります。
BYTEINT、SMALLINT、INTEGER、BIGINT、DECIMAL/NUMERIC、FLOAT/REAL/
DOUBLE PRECISION、NUMBER、CHAR、または VARCHAR
すべての入力引数は同じデータ タイプか、あるいはタイプに互換性がなければなり
ません。
結果のタイプ
入力引数が数値タイプの場合、関数は最も優先順位が高い引数を決定し、そのデー
タ タイプに他の引数を変換して、そのデータ タイプを返します。
そのデータ タイプが DECIMAL/NUMERIC であり、入力引数の精度とスケールが異
なる場合、戻りタイプの精度とスケールは最大精度になるように設定されます。た
とえば、入力引数が DECIMAL(6,3)、DECIMAL(7,4)、および DECIMAL(8,7)の場合、
精度の低下を避けるために、戻りタイプは小数点の左が 3 桁、右が 7 桁必要になり
ます。この場合、返されるデータ タイプは DECIMAL(10,7)に設定されます。
最大精度を維持できない場合、データは DBS 制御レコードの RoundHalfWayMagUp
フィールドに基づいて丸められます。たとえば、入力引数が DECIMAL(32, 8)と
DECIMAL(30, 28)の場合、戻りタイプは DECIMAL(38,14)になります。これにより、
小数点の左側の 24 桁(DECIMAL(32,8)の引数に必要)と、小数点の右側の 14 桁が用
意されます。DECIMAL(30,28)の入力引数が最大値だとすると、その値は小数点か
ら右側の 14 桁目で丸められます。
データ タイプが固定小数点数の NUMBER で精度が 38 以下の場合、戻りタイプの
精度とスケールは、DECIMAL/NUMERIC と同じメソッドを使用して計算されます。
ただし、精度が 38 より大きい場合は、精度の低下を避けるために戻りタイプを
NUMBER(*)に変更します。データ タイプが浮動小数点の NUMBER の場合、戻りタ
イプは NUMBER(*)になります。
入力引数が文字タイプの場合、この関数は 2 番目から 10 番目までの引数を最初の
引数のデータ タイプに変換して、それを最初の引数の文字セットで VARCHAR とし
てタイプを返します。
使用上の注意
引数が文字タイプの場合、文字列の比較に非埋め込み比較セマンティクスが使用さ
れます。文字の比較はその文字の数値コードに基づいてバイナリで実行されます。
SQL 関数、演算子、式および述部
451
第 10 章 比較演算子と関数
LEAST
文字列は、文字ごとに比較するのではなく、比較の際にはバイトの並びとして扱わ
れます。
いずれかの入力引数が NULL の場合、この関数は NULL を返します。
例
例 1: 入力引数のリストの最大値の問合わせ
以下の問合わせは結果として 13 を返します。
SELECT GREATEST(13, 6);
例 2: 特定のデータ型での GREATEST の問合わせ
次の問合わせでは、入力引数のデータ タイプが DECIMAL(4,2)と DECIMAL(5,4)の場
合、返されるデータ タイプは DECIMAL(6,4)になり、結果値は 13.1200 になります。
SELECT GREATEST(13.12, 6.1234);
例 3: GREATEST の問合わせ
以下の問合わせは結果として'apples'を返します。
SELECT GREATEST('apples', 'alpha');
関連トピック
詳細は、以下を参照してください。
• 埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービ
ス システム関数 」を参照してください。
• デフォルトのデータ タイプ書式については、< SQL データ型とリテラル、
B035-1143>を参照してください。
• 優先順位の順序の詳細については、SQL 外部ルーチン プログラミング、B035-1147
の「互換データ型」を参照してください。
LEAST
目的
numeric_values または string_values のリストから、最小値を返します。
構文
,
LEAST
TD_SYSFNLIB.
10
( numeric_value )
,
10
( string_value )
452
SQL 関数、演算子、式および述部
第 10 章 比較演算子と関数
LEAST
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
numeric_value
数値式。
LEAST は 1~10 の数値をサポートします。
最初の引数データ型が numeric_value の場合、返されるデータ型は数値になります。
入力リスト内の残りの引数は、それと同じ型か互換型になります。どちらかの入力
パラメータが NULL の場合は NULL が返されます。
string_value
文字の引数。
LEAST は 1~10 の文字列の値をサポートします。
最初の引数のデータ タイプが string_value の場合、返されるデータ タイプは文字
列になります。
文字列の比較には、非埋め込み比較セマンティクスが使用されます。文字の比較は
文字の数値コードに基づいてバイナリで実行されます。また、文字列は、文字ごと
に比較するのではなく、比較の際にはバイトの並びとして扱われます。
入力リスト内の残りの引数は、それと同じ型か互換型になります。どちらかの入力
パラメータが NULL の場合は NULL が返されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
LEAST は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡された式は、次のデータ タイプを持っている必要があります。
• numeric_value = BYTEINT、SMALLINT、INTEGER、BIGINT、DECIMAL/
NUMERIC、FLOAT/REAL/DOUBLE PRECISION、または NUMBER
• string_value = CHAR または VARCHAR
SQL 関数、演算子、式および述部
453
第 10 章 比較演算子と関数
LEAST
結果のタイプ
LEAST は、関数に渡された numeric_value または string_value に関連付けられたデー
タ タイプによって戻り値のデータ タイプが異なるスカラー関数です。
• numeric_value が数値データ型の場合、LEAST は最も優先順位が高い引数を決定
し、そのデータ型に他の引数を変換して、そのデータ型を返します。
そのデータ タイプが DECIMAL/NUMERIC であり、入力引数の精度とスケールが
異なる場合、返されるデータ タイプの精度とスケールは最大精度になるように設
定されます。たとえば、入力引数が DECIMAL(6,3)、DECIMAL(7,4)、および
DECIMAL(8,7)の場合、精度の低下を避けるために、返されるデータ タイプは小
数点の左が 3 桁、右が 7 桁必要になります。この場合、返されるデータ タイプ
は DECIMAL(10,7)に設定されます。
最大精度を維持できない場合、データは DBS 制御レコードの
RoundHalfWayMagUp フィールドに基づいて丸められます。たとえば、入力引数
が DECIMAL(32, 8)と DECIMAL(30, 28)の場合、返されるデータ タイプは
DECIMAL(38,14)になります。これにより、小数点の左側の 24 桁(DECIMAL(32,8)
のパラメータに必要)と、小数点の右側の 14 桁が用意されます。DECIMAL(30,28)
の入力引数が最小値だとすると、その値は小数点から右側の 14 桁目で丸められ
ます。
データ タイプが固定小数点数の NUMBER で精度が 38 以下の場合、戻りタイプ
の精度とスケールは、DECIMAL/NUMERIC と同じメソッドを使用して計算されま
す。ただし、精度が 38 より大きい場合は、精度の低下を避けるために戻りタイ
プを NUMBER(*)に変更します。データ タイプが浮動小数点の NUMBER の場合、
戻りタイプは NUMBER(*)になります。
• string_value が文字データ タイプの場合、LEAST は 2 番目から 10 番目までの引
数を、最初の引数のデータ タイプに変換して、それを最初の引数の文字セットで
VARCHAR としての値を返します。
例
例 1: LEAST の問合わせ
以下の問合わせは 6 を返します。
SELECT LEAST(13, 6);
例 2: 特定のデータ型での LEAST の問合わせ
次の問合わせでは、入力引数のデータ タイプが DECIMAL(5,4)と DECIMAL(4,2)の場
合、返されるデータ タイプは DECIMAL(6,4)になり、戻り値は 1.1234 になります。
SELECT LEAST(1.1234, 36.12);
例 3: LEAST アルファベットの問合わせ
以下の問合わせは'alpha'を返します。
454
SQL 関数、演算子、式および述部
第 10 章 比較演算子と関数
LEAST
SELECT LEAST('apples', 'alpha');
関連トピック
詳細は、以下を参照してください。
• 埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービ
ス システム関数 」を参照してください。
• 優先順位の順序の詳細については、<SQL 外部ルーチン プログラミング、
B035-1147>の「互換データ型」を参照してください。
SQL 関数、演算子、式および述部
455
第 10 章 比較演算子と関数
LEAST
456
SQL 関数、演算子、式および述部
第 11 章
圧縮関数/圧縮解除関数
概要
この章では、文字またはバイト タイプの列データを圧縮および圧縮解除するため
に、アルゴリズム圧縮(ALC)と連携して使用可能な関数について説明します。データ
の圧縮により、領域の使用率とディスク入出力のサイズを減らします。
この章で説明する圧縮関数と圧縮解除関数が、使用目的に適っていない場合は、テー
ブルの列を圧縮または圧縮解除する独自のユーザー定義関数(UDF)を作成してくだ
さい。
注: ALC をブロック レベル圧縮(BLC)と一緒に使用するとパフォーマンスが低下する
ことがあるため、この方法はお勧めしません。
前提条件
この章で取り上げる関数は、埋め込みサービス システム関数です 。埋め込みサービ
ス関数の有効化と呼び出しについて、詳細は「埋め込みサービス システム関数」を
参照してください。
詳細情報
参照先
ALC
• <SQL データ定義言語 - 構文規則および例、
B035-1144>の「COMPRESS 句と
DECOMPRESS 句」および「CREATE TABLE」 。
ALC 用 UDF の作成
• <SQL 外部ルーチン プログラミング 、
B035-1147>の「アルゴリズム圧縮に対応した関
数の定義」。
Teradata Database でサポートされる圧 • <データベース設計 、B035-1094>の「データの
縮方式、およびさまざまな圧縮方式の
圧縮の使用」。
比較
• <データベース設計、B035-1094>の付録「圧縮
方法」。
SQL 関数、演算子、式および述部
457
第 11 章 圧縮関数/圧縮解除関数
CAMSET
CAMSET
目的
指定した Unicode 文字データを専用の Teradata アルゴリズムを使用して、以下の可
能な値に圧縮します。
• 部分バイトの値(たとえば、4 ビットの数字、または 5 ビットの英文字)
• 1 バイトの値(たとえば、上記と Latin 文字)
• 2 バイトの値(たとえば、上記と Unicode 文字)
構文
CAMSET (Unicode_string)
TD_SYSFNLIB.
注:
この関数は、COMPRESS USING 句または DECOMPRESS USING 句の一部として使用
される場合は引数をとりません。
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
Unicode_string
Unicode の文字列または列式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプと規則
この関数には、データ型が VARCHAR(n) CHARACTER SET UNICODE の式を渡さなけ
ればなりません。この(n)の最大対応サイズは 32000 です。UDF に適用される暗黙
のデータ型変換規則を使用して VARCHAR(32000) CHARACTER SET UNICODE に変
換できる、データ型の引数も渡すことができます。たとえば、CAMSET(CHAR)は可
能です。暗黙的に CAMSET(VARCHAR)に変換できるからです。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って VARCHAR に変換で
きない引数は、明示的にキャストする必要があります。
この関数への入力は Unicode 文字データでなければなりません。
入力として NULL を指定した場合、この関数は NULL を返します。
458
SQL 関数、演算子、式および述部
第 11 章 圧縮関数/圧縮解除関数
CAMSET
結果のタイプ
結果のデータ型は VARBYTE(64000)になります。
使用上の注意
Unicode 文字データを格納する場合、圧縮解除された Teradata Database 内の文字
データには 1 文字ごとに 2 バイトが必要になります。CAMSET は Unicode 文字の入
力を受け取り、それを部分バイト、1 バイトまたは 2 バイトの値に圧縮し、圧縮し
た結果を返します。
CAMSET は、次に示す内容の中程度以下の長さの Unicode 文字列に対して最良の結
果が得られます。
• 主に英数文字が含まれる。
• 以下に示す組み合わせの切り替えが頻繁に発生しない。
• 大文字と小文字。
• 数字と文字。
• Latin 文字と非 Latin 文字。
この関数を直接呼び出すこともできますが、通常、CAMSET はアルゴリズム圧縮
(ALC)を使用してテーブルの列を圧縮します。CAMSET を ALC で使用すると、列が
NULL 受入可能ならば NULL も圧縮されます。
制約事項
CAMSET は現在、U+0000~U+00FF の Unicode 文字のみを圧縮します。
CAMSET で圧縮されたデータの圧縮解除
CAMSET を使用して圧縮された Unicode データを圧縮解除するには、DECAMSET
関数を使用します。
例
例: UNICODE 値の圧縮
この例では、ALC で CAMSET 関数を使用して、Description 列の Unicode 値を圧縮
します。DECAMSET 関数は、直前に圧縮された値を圧縮解除します。
CREATE MULTISET TABLE Pendants
(ItemNo INTEGER,
Gem CHAR(10) UPPERCASE CHARACTER SET UNICODE,
Description VARCHAR(1000) CHARACTER SET UNICODE
COMPRESS USING TD_SYSFNLIB.CAMSET
DECOMPRESS USING TD_SYSFNLIB.DECAMSET);
SQL 関数、演算子、式および述部
459
第 11 章 圧縮関数/圧縮解除関数
CAMSET_L
例: 圧縮値の問合わせ
次のテーブル定義があるとします。
CREATE TABLE Pendants
(ItemNo INTEGER,
Description VARCHAR(100) CHARACTER SET UNICODE);
次の問合わせは Description 列の圧縮された値を返します。
SELECT TD_SYSFNLIB.CAMSET(Pendants.Description);
関連トピック
詳細は、以下を参照してください。
• COMPRESS/DECOMPRESS 句の詳細については、< SQL データ型とリテラル、
B035-1143>を参照してください。
• UDF の暗黙のタイプ変換規則の詳細については、<SQL 外部ルーチン プログラミ
ング 、B035-1147>の「互換データ型」を参照してください。
• DECAMSET 関数について、詳細は DECAMSET を参照してください。
• Teradata 提供の各圧縮関数の比較と、圧縮関数を選択する際のガイドラインにつ
いての詳細は、<データベース設計、B035-1094>を参照してください。
CAMSET_L
目的
指定した Latin 文字データを専用の Teradata アルゴリズムを使用して、以下の可能
な値に圧縮します。
• 部分バイトの値(たとえば、4 ビットの数字、または 5 ビットの英文字)
• 1 バイトの値(たとえば、上記と Latin 文字)
構文
CAMSET_L (Latin_string)
TD_SYSFNLIB.
注:
この関数は、COMPRESS USING 句または DECOMPRESS USING 句の一部として使用
される場合は引数をとりません。
460
SQL 関数、演算子、式および述部
第 11 章 圧縮関数/圧縮解除関数
CAMSET_L
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
Latin_string
Latin の文字列または列式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプと規則
この関数には、データ型が VARCHAR(n) CHARACTER SET LATIN の式を渡さなけれ
ばなりません。この(n)の最大対応サイズは 64000 です。UDF に適用される暗黙の
データ型変換規則を使用して VARCHAR(64000) CHARACTER SET LATIN に変換で
きる、データ型の引数も渡すことができます。たとえば、CAMSET_L(CHAR)は可能
です。暗黙的に CAMSET_L(VARCHAR)に変換できるからです。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って VARCHAR に変換で
きない引数は、明示的にキャストする必要があります。
この関数への入力は Latin 文字データでなければなりません。
入力として NULL を指定した場合、この関数は NULL を返します。
結果のタイプ
結果のデータ型は VARBYTE(64000)になります。
使用上の注意
Latin 文字データを格納する場合、圧縮解除された Teradata Database 内の文字デー
タには 1 文字ごとに 1 バイトが必要になります。CAMSET_L は、Latin 文字の入力
を受け取り、それを部分バイト、1 バイトの値に圧縮し、圧縮された結果を返します。
CAMSET_L は、次に示す内容の中程度以下の長さの Latin 文字列に対して最高の結
果が得られます。
• 主に英数文字が含まれる。
• 以下に示す組み合わせの切り替えが頻繁に発生しない。
• 大文字と小文字。
• 数字と文字。
SQL 関数、演算子、式および述部
461
第 11 章 圧縮関数/圧縮解除関数
CAMSET_L
この関数を直接呼び出すこともできますが、通常、CAMSET_L はアルゴリズム圧縮
(ALC)を使用してテーブルの列を圧縮します。CAMSET_L を ALC で使用すると、列
が NULL 受入可能ならば NULL も圧縮されます。
CAMSET_L で圧縮されたデータの圧縮解除
CAMSET_L を使用して圧縮された Latin 文字データを圧縮解除するには、
DECAMSET_L 関数を使用します。
例
例: Latin 値の圧縮
この例では、ALC で CAMSET_L 関数を使用して、Description 列の Latin 値を圧縮し
ます。DECAMSET_L 関数は、直前に圧縮された値を圧縮解除します。
CREATE MULTISET TABLE Pendants
(ItemNo INTEGER,
Gem CHAR(10) UPPERCASE CHARACTER SET LATIN,
Description VARCHAR(1000) CHARACTER SET LATIN
COMPRESS USING TD_SYSFNLIB.CAMSET_L
DECOMPRESS USING TD_SYSFNLIB.DECAMSET_L);
例: 圧縮された Latin 値の問合わせ
次のテーブル定義があるとします。
CREATE TABLE Pendants
(ItemNo INTEGER,
Description VARCHAR(100) CHARACTER SET LATIN);
次の問合わせは Description 列の圧縮された値を返します。
SELECT TD_SYSFNLIB.CAMSET_L(Pendants.Description);
関連トピック
詳細は、以下を参照してください。
• COMPRESS/DECOMPRESS 句の詳細については、< SQL データ型とリテラル、
B035-1143>を参照してください。
• ALC の詳細については、< SQL データ型とリテラル、B035-1143>の「COMPRESS
句と DECOMPRESS 句」を参照してください。
• UDF の暗黙のタイプ変換規則の詳細については、<SQL 外部ルーチン プログラミ
ング 、B035-1147>の「互換データ型」を参照してください。
• DECAMSET 関数について、詳細は DECAMSET を参照してください。
462
SQL 関数、演算子、式および述部
第 11 章 圧縮関数/圧縮解除関数
DECAMSET
• CAMSET_L を使用して圧縮された Latin 文字データを圧縮解除するには、
DECAMSET_L 関数を使用します。DECAMSET_L を参照してください。
• Teradata 提供の各圧縮関数の比較と、圧縮関数を選択する際のガイドラインにつ
いての詳細は、<データベース設計、B035-1094>を参照してください。
DECAMSET
目的
CAMSET 関数を使用して圧縮された Unicode データを圧縮解除します。
構文
DECAMSET (compressed_string)
TD_SYSFNLIB.
注:
この関数は、COMPRESS USING 句または DECOMPRESS USING 句の一部として使用
される場合は引数をとりません。
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
compressed_string
CAMSET 関数を使用して圧縮された Unicode 文字データ。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプと規則
この関数には、データ タイプが VARBYTE(n)の式を渡さなければなりません。この
(n)の最大対応サイズは 64000 です。
この関数への入力は、CAMSET 関数の出力結果でなければなりません。
入力として NULL を指定した場合、この関数は NULL を返します。
結果のタイプ
結果のデータ型は VARCHAR(32000) CHARACTER SET UNICODE になります。
SQL 関数、演算子、式および述部
463
第 11 章 圧縮関数/圧縮解除関数
DECAMSET_L
使用上の注意
DECAMSET は、CAMSET 関数で圧縮された Unicode データを受け取り、それを圧縮
解除します。その後で、圧縮解除した Unicode 文字列を結果として返します。
この関数を直接呼び出すこともできますが、通常、DECAMSET はアルゴリズム圧縮
(ALC)を使用して、事前に CAMSET で圧縮されたテーブルの列を圧縮解除します。
例: UNICODE 値の圧縮
この例では、ALC で CAMSET 関数を使用して、Description 列の Unicode 値を圧縮
します。DECAMSET 関数は、直前に圧縮された値を圧縮解除します。
CREATE MULTISET TABLE Pendants
(ItemNo INTEGER,
Gem CHAR(10) UPPERCASE CHARACTER SET UNICODE,
Description VARCHAR(1000) CHARACTER SET UNICODE
COMPRESS USING TD_SYSFNLIB.CAMSET
DECOMPRESS USING TD_SYSFNLIB.DECAMSET);
DECAMSET 関数、関連トピック
詳細は、以下を参照してください。
• COMPRESS/DECOMPRESS 句の詳細については、< SQL データ型とリテラル、
B035-1143>を参照してください。
• ALC の詳細については、< SQL データ型とリテラル、B035-1143>の「COMPRESS
句と DECOMPRESS 句」を参照してください。
DECAMSET_L
目的
CAMSET_L を使用して圧縮された Latin データを圧縮解除します。
構文
DECAMSET_L (compressed_string)
TD_SYSFNLIB.
注:
この関数は、COMPRESS USING 句または DECOMPRESS USING 句の一部として使用
される場合は引数をとりません。
464
SQL 関数、演算子、式および述部
第 11 章 圧縮関数/圧縮解除関数
DECAMSET_L
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
compressed_string
CAMSET_L 関数を使用して圧縮された Latin 文字データ。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプと規則
この関数には、データ タイプが VARBYTE(n)の式を渡さなければなりません。この
(n)の最大対応サイズは 64000 です。
この関数への入力は、CAMSET_L 関数の出力結果でなければなりません。
入力として NULL を指定した場合、この関数は NULL を返します。
結果のタイプ
結果のデータ タイプは VARCHAR(64000) CHARACTER SET LATIN です。
使用上の注意
DECAMSET_L は、CAMSET_L 関数で圧縮された Latin データを受け取り、それを圧
縮解除します。その後で、圧縮解除した Latin 文字列を結果として返します。
この関数を直接呼び出すこともできますが、通常、DECAMSET_L はアルゴリズム圧
縮(ALC)を使用して、事前に CAMSET_L で圧縮されたテーブルの列を圧縮解除します。
例
この例では、ALC で CAMSET_L 関数を使用して、Description 列の Latin 値を圧縮
します。DECAMSET_L 関数は、直前に圧縮された値を圧縮解除します。
CREATE MULTISET TABLE Pendants
(ItemNo INTEGER,
Gem CHAR(10) UPPERCASE CHARACTER SET LATIN,
Description VARCHAR(1000) CHARACTER SET LATIN
COMPRESS USING TD_SYSFNLIB.CAMSET_L
DECOMPRESS USING TD_SYSFNLIB.DECAMSET_L);
SQL 関数、演算子、式および述部
465
第 11 章 圧縮関数/圧縮解除関数
JSON_COMPRESS
関連トピック
詳細は、以下を参照してください。
• COMPRESS/DECOMPRESS 句の詳細については、< SQL データ型とリテラル、
B035-1143>を参照してください。
• ALC の詳細については、< SQL データ型とリテラル、B035-1143>の「COMPRESS
句と DECOMPRESS 句」を参照してください。
JSON_COMPRESS
目的
JSON データ タイプ値を圧縮します。
構文
JSON_COMPRESS
( JSON_expr )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
JSON_expr
JSON データ型と評価される式。
注:
この関数は、COMPRESS USING 句または DECOMPRESS USING 句の一部として使用
される場合は引数をとりません。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプと規則
この関数は、JSON データ タイプのみを圧縮します。その他のデータ タイプの圧縮
に使用することはできません。ユーザーは JSON データを圧縮するための独自の UDF
を作成することはできません。
466
SQL 関数、演算子、式および述部
第 11 章 圧縮関数/圧縮解除関数
JSON_DECOMPRESS
結果のタイプ
関数は TD_ANYTYPE を入力として受け取り、任意の JSON データ タイプの形式で
使用できるように TD_ANYTYPE を返します。
TD_LZ_COMPRESS 関数を使用して JSON データを圧縮できます。ただし、
JSON_COMPRESS 関数は JSON データの圧縮用に最適化されているため、代わりに
JSON_COMPRESS を使用することを推奨します。
例: JSON データ型の圧縮
この関数を直接呼び出すこともできますが、多くの場合、JSON_COMPRESS は
COMPRESS USING 句で使用してテーブルの列を圧縮します。以下の表では、 json_col
列の JSON データが JSON_COMPRESS 関数を使用して圧縮されます。
CREATE TABLE temp (
id
INTEGER,
json_col JSON(1000)
CHARACTER SET LATIN
COMPRESS USING JSON_COMPRESS
DECOMPRESS USING JSON_DECOMPRESS);
関連トピック
詳細は、以下を参照してください。
• COMPRESS USING 句の詳細については、< SQL データ型とリテラル、
B035-1143>を参照してください。
• COMPRESS/DECOMPRESS 句の詳細については、< SQL データ型とリテラル、
B035-1143>を参照してください。
JSON_DECOMPRESS
目的
JSON_COMPRESS 関数を使用して前に圧縮された JSON データを圧縮解除します。
構文
JSON_DECOMPRESS
( compressed_JSON_data )
TD_SYSFNLIB.
注:
この関数は、COMPRESS USING 句または DECOMPRESS USING 句の一部として使用
される場合は引数をとりません。
SQL 関数、演算子、式および述部
467
第 11 章 圧縮関数/圧縮解除関数
JSON_DECOMPRESS
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
compressed_JSON_data
JSON_COMPRESS 関数を使用して圧縮された JSON データ。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプと規則
この関数は、JSON データ タイプのみを圧縮解除します。その他のデータ タイプの
圧縮解除に使用することはできません。ユーザーは JSON データを圧縮および圧縮
解除するための独自の UDF を作成することはできません。
結果のタイプ
関数の戻りデータ タイプは JSON です。
例: JSON データ型の圧縮解除
この関数を直接呼び出すこともできますが、多くの場合、JSON_DECOMPRESS は
DECOMPRESS USING 句で使用してテーブルの列を圧縮解除します。以下の表では、
json_col 列の JSON データが JSON_DECOMPRESS 関数を使用して圧縮解除されます。
CREATE TABLE temp (
id
INTEGER,
json_col JSON(1000)
CHARACTER SET LATIN
COMPRESS USING JSON_COMPRESS
DECOMPRESS USING JSON_DECOMPRESS);
関連トピック
詳細は、以下を参照してください。
• DECOMPRESS USING 句の詳細については、< SQL データ型とリテラル、
B035-1143>を参照してください。
• COMPRESS/DECOMPRESS 句の詳細については、< SQL データ型とリテラル、
B035-1143>を参照してください。
468
SQL 関数、演算子、式および述部
第 11 章 圧縮関数/圧縮解除関数
LZCOMP
LZCOMP
目的
指定された Unicode 文字データを、Lempel-Ziv アルゴリズムを使用して圧縮します。
構文
LZCOMP (Unicode_string)
TD_SYSFNLIB.
注: この関数は、COMPRESS USING 句または DECOMPRESS USING 句の一部として
使用される場合は引数をとりません。
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
Unicode_string
Unicode の文字列または列式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプと規則
この関数には、データ型が VARCHAR(n) CHARACTER SET UNICODE の式を渡さな
ければなりません。この(n)の最大対応サイズは 32000 です。UDF に適用される暗
黙のデータ型変換規則を使用して VARCHAR(32000) CHARACTER SET UNICODE に
変換できる、データ型の引数も渡すことができます。たとえば、LZCOMP(CHAR)は
可能です。暗黙的に LZCOMP(VARCHAR)に変換できるからです。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って VARCHAR に変換で
きない引数は、明示的にキャストする必要があります。
詳細については、<SQL 外部ルーチン プログラミング 、B035-1147>の「互換デー
タ型」を参照してください。
この関数への入力は Unicode 文字データでなければなりません。
入力として NULL を指定した場合、この関数は NULL を返します。
SQL 関数、演算子、式および述部
469
第 11 章 圧縮関数/圧縮解除関数
LZCOMP
結果のタイプ
結果のデータ型は VARBYTE(64000)になります。
使用上の注意
Unicode 文字データを格納する場合、圧縮解除された Teradata Database 内の文字
データには 1 文字ごとに 2 バイトが必要になります。LZCOMP は Unicode 文字の入
力を受け取り、それを Lempel-Ziv アルゴリズムを使用して圧縮し、圧縮された結果
を返します。
LZCOMP は、長い Unicode 文字列に対しては良好な圧縮結果を得られますが、短い
文字列に対してはそれほどの効果が得られないことがあります。頻繁に繰り返され
る文字が存在する中程度の文字列に対しても、良好な結果が得られることがあります。
この関数を直接呼び出すこともできますが、通常、LZCOMP はアルゴリズム圧縮
(ALC)を使用してテーブルの列を圧縮します。LZCOMP を ALC で使用すると、列が
NULL 受入可能ならば NULL も圧縮されます。
LZCOMP で圧縮されたデータの圧縮解除
LZCOMP を使用して圧縮された Unicode データを圧縮解除するには、LZDECOMP
関数を使用します。
例
例: UNICODE 値の圧縮
この例では、ALC で LZCOMP 関数を使用して、Description 列の Unicode 値を圧縮
します。LZDECOMP 関数は、直前に圧縮された値を圧縮解除します。
CREATE MULTISET TABLE Pendants
(ItemNo INTEGER,
Gem CHAR(10) UPPERCASE CHARACTER SET UNICODE,
Description VARCHAR(1000) CHARACTER SET UNICODE
COMPRESS USING TD_SYSFNLIB.LZCOMP
DECOMPRESS USING TD_SYSFNLIB.LZDECOMP);
例: Description 列の圧縮された UNICODE 値の問合わせ
次のテーブル定義があるとします。
CREATE TABLE Pendants
(ItemNo INTEGER,
Description VARCHAR(100) CHARACTER SET UNICODE);
次の問合わせは Description 列の圧縮された値を返します。
470
SQL 関数、演算子、式および述部
第 11 章 圧縮関数/圧縮解除関数
LZCOMP_L
SELECT TD_SYSFNLIB.LZCOMP(Pendants.Description);
関連トピック
詳細は、以下を参照してください。
• COMPRESS/DECOMPRESS 句の詳細については、< SQL データ型とリテラル、
B035-1143>を参照してください。
• ALC の詳細については、< SQL データ型とリテラル、B035-1143>の「COMPRESS
句と DECOMPRESS 句」を参照してください。
• Teradata 提供の各圧縮関数の比較と、圧縮関数を選択する際のガイドラインにつ
いての詳細は、<データベース設計、B035-1094>を参照してください。
• LZCOMP で使用する圧縮アルゴリズムについて、詳細は http://zlib.net を参照し
てください。
• LZCOMP を使用して圧縮された Unicode データを圧縮解除するには、LZDECOMP
関数を使用します。LZDECOMP を参照してください。
LZCOMP_L
目的
指定された Latin 文字データを、Lempel-Ziv アルゴリズムを使用して圧縮します。
構文
LZCOMP_L (Latin_string)
TD_SYSFNLIB.
注:
この関数は、COMPRESS USING 句または DECOMPRESS USING 句の一部として使用
される場合は引数をとりません。
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
Latin_string
Latin の文字列または列式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
SQL 関数、演算子、式および述部
471
第 11 章 圧縮関数/圧縮解除関数
LZCOMP_L
引数のタイプと規則
この関数には、データ型が VARCHAR(n) CHARACTER SET LATIN の式を渡さなけれ
ばなりません。この(n)の最大対応サイズは 64000 です。UDF に適用される暗黙の
データ型変換規則を使用して VARCHAR(64000) CHARACTER SET LATIN に変換でき
る、データ型の引数も渡すことができます。たとえば、LZCOMP_L(CHAR)は可能で
す。暗黙的に LZCOMP_L(VARCHAR)に変換できるからです。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って VARCHAR に変換で
きない引数は、明示的にキャストする必要があります。
この関数への入力は Latin 文字データでなければなりません。
入力として NULL を指定した場合、この関数は NULL を返します。
結果のタイプ
結果のデータ型は VARBYTE(64000)になります。
使用上の注意
Latin 文字データを格納する場合、圧縮解除された Teradata Database 内の文字デー
タには 1 文字ごとに 1 バイトが必要になります。LZCOMP_L は Latin 文字の入力を
受け取り、それを Lempel-Ziv アルゴリズムを使用して圧縮し、圧縮された結果を返
します。
LZCOMP_L は、長い Unicode 文字列に対しては良好な圧縮結果を得られますが、短
い文字列に対してはそれほどの効果が得られないことがあります。頻繁に繰り返さ
れる文字が存在する中程度の文字列に対しても、良好な結果が得られることがあり
ます。
この関数を直接呼び出すこともできますが、通常、LZCOMP_L はアルゴリズム圧縮
(ALC)を使用してテーブルの列を圧縮します。LZCOMP_L を ALC で使用すると、列
が NULL 受入可能ならば NULL も圧縮されます。
LZCOMP_L で圧縮されたデータの圧縮解除
LZCOMP_L を使用して圧縮された Latin データを圧縮解除するには、LZDECOMP_L
関数を使用します。
例
例: Latin 値の圧縮
この例では、ALC で LZCOMP_L 関数を使用して、Description 列の Latin 値を圧縮し
ます。LZDECOMP_L 関数は、直前に圧縮された値を圧縮解除します。
472
SQL 関数、演算子、式および述部
第 11 章 圧縮関数/圧縮解除関数
LZDECOMP
CREATE MULTISET TABLE Pendants
(ItemNo INTEGER,
Gem CHAR(10) UPPERCASE CHARACTER SET LATIN,
Description VARCHAR(1000) CHARACTER SET LATIN
COMPRESS USING TD_SYSFNLIB.LZCOMP_L
DECOMPRESS USING TD_SYSFNLIB.LZDECOMP_L);
例: Description 列の圧縮された Latin 値の問合わせ
次のテーブル定義があるとします。
CREATE TABLE Pendants
(ItemNo INTEGER,
Description VARCHAR(100) CHARACTER SET LATIN);
次の問合わせは Description 列の圧縮された値を返します。
SELECT TD_SYSFNLIB.LZCOMP_L(Pendants.Description);
関連トピック
詳細は、以下を参照してください。
• COMPRESS/DECOMPRESS 句の詳細については、< SQL データ型とリテラル、
B035-1143>を参照してください。
• ALC の詳細については、< SQL データ型とリテラル、B035-1143>の「COMPRESS
句と DECOMPRESS 句」を参照してください。
• LZCOMP_L を使用して圧縮された Latin データを圧縮解除するには、
LZDECOMP_L 関数を使用します。「LZDECOMP_L」を参照してください。
• LZCOMP_L で使用する圧縮アルゴリズムについて、詳細は http://zlib.net を参照
してください。
• Teradata 提供の各圧縮関数の比較と、圧縮関数を選択する際のガイドラインにつ
いての詳細は、<データベース設計、B035-1094>を参照してください。
• 詳細については、<SQL 外部ルーチン プログラミング、B035-1147>の「互換デー
タ型」を参照してください。
LZDECOMP
目的
LZCOMP 関数を使用して圧縮された Unicode データを圧縮解除します。
構文
LZDECOMP (compressed_string)
TD_SYSFNLIB.
SQL 関数、演算子、式および述部
473
第 11 章 圧縮関数/圧縮解除関数
LZDECOMP
注:
この関数は、COMPRESS USING 句または DECOMPRESS USING 句の一部として使用
される場合は引数をとりません。
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
compressed_string
LZCOMP 関数を使用して圧縮された Unicode 文字データ。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプと規則
この関数には、データ タイプが VARBYTE(n)の式を渡さなければなりません。この
(n)の最大対応サイズは 64000 です。
この関数への入力は、LZCOMP 関数の出力結果でなければなりません。
入力として NULL を指定した場合、この関数は NULL を返します。
結果のタイプ
結果のデータ型は VARCHAR(32000) CHARACTER SET UNICODE になります。
使用上の注意
LZDECOMP は、LZCOMP 関数で圧縮された Unicode データを受け取り、それを圧
縮解除します。その後で、圧縮解除した Unicode 文字列を結果として返します。
この関数を直接呼び出すこともできますが、通常、LZDECOMP はアルゴリズム圧縮
(ALC)を使用して、事前に LZCOMP で圧縮されたテーブルの列を圧縮解除します。
例: LZCOMP での UNICODE 値の圧縮
この例では、ALC で LZCOMP 関数を使用して、Description 列の Unicode 値を圧縮
します。LZDECOMP 関数は、直前に圧縮された値を圧縮解除します。
CREATE MULTISET TABLE Pendants
(ItemNo INTEGER,
Gem CHAR(10) UPPERCASE CHARACTER SET UNICODE,
474
SQL 関数、演算子、式および述部
第 11 章 圧縮関数/圧縮解除関数
LZDECOMP_L
Description VARCHAR(1000) CHARACTER SET UNICODE
COMPRESS USING TD_SYSFNLIB.LZCOMP
DECOMPRESS USING TD_SYSFNLIB.LZDECOMP);
関連トピック
詳細は、以下を参照してください。
• COMPRESS/DECOMPRESS 句の詳細については、< SQL データ型とリテラル、
B035-1143>を参照してください。
• ALC の詳細については、< SQL データ型とリテラル、B035-1143>の「COMPRESS
句と DECOMPRESS 句」を参照してください。
• LZDECOMP で使用する圧縮解除アルゴリズムについて、詳細は http://zlib.net を
参照してください。
LZDECOMP_L
目的
LZCOMP_L 関数を使用して圧縮された Latin データを圧縮解除します。
構文
LZDECOMP_L (compressed_string)
TD_SYSFNLIB.
注:
この関数は、COMPRESS USING 句または DECOMPRESS USING 句の一部として使用
される場合は引数をとりません。
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
compressed_string
LZCOMP_L 関数を使用して圧縮された Latin データ。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
SQL 関数、演算子、式および述部
475
第 11 章 圧縮関数/圧縮解除関数
LZDECOMP_L
引数のタイプと規則
この関数には、データ タイプが VARBYTE(n)の式を渡さなければなりません。この
(n)の最大対応サイズは 64000 です。
この関数への入力は、LZCOMP_L 関数の出力結果でなければなりません。
入力として NULL を指定した場合、この関数は NULL を返します。
結果のタイプ
結果のデータ タイプは VARCHAR(64000) CHARACTER SET LATIN です。
使用上の注意
LZDECOMP_L は、LZCOMP_L 関数で圧縮された Latin データを受け取り、それを圧
縮解除します。その後で、圧縮解除した Latin 文字列を結果として返します。
この関数を直接呼び出すこともできますが、通常、LZDECOMP_L はアルゴリズム圧
縮(ALC)を使用して、事前に LZCOMP_L で圧縮されたテーブルの列を圧縮解除します。
例: LZCOMP_L での Latin 値の圧縮
この例では、ALC で LZCOMP_L 関数を使用して、Description 列の Latin 値を圧縮し
ます。LZDECOMP_L 関数は、直前に圧縮された値を圧縮解除します。
CREATE MULTISET TABLE Pendants
(ItemNo INTEGER,
Gem CHAR(10) UPPERCASE CHARACTER SET LATIN,
Description VARCHAR(1000) CHARACTER SET LATIN
COMPRESS USING TD_SYSFNLIB.LZCOMP_L
DECOMPRESS USING TD_SYSFNLIB.LZDECOMP_L);
関連トピック
詳細は、以下を参照してください。
• COMPRESS/DECOMPRESS 句の詳細については、< SQL データ型とリテラル、
B035-1143>を参照してください。
• ALC の詳細については、< SQL データ型とリテラル、B035-1143>の「COMPRESS
句と DECOMPRESS 句」を参照してください。
• LZDECOMP_L で使用する圧縮解除アルゴリズムについて、詳細は http://zlib.net
を参照してください。
476
SQL 関数、演算子、式および述部
第 11 章 圧縮関数/圧縮解除関数
TD_LZ_COMPRESS
TD_LZ_COMPRESS
目的
Lempel-Ziv アルゴリズムを使用して、サポートされているすべての ALC データ型ま
たは事前定義型のデータを圧縮します。
構文
TD_LZ_COMPRESS ( expression )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression
• 列に対する ALC 用圧縮ルーチンとして関数を使用する場合に、サポートされる
ALC データ型。
• 関数を呼び出す場合に、サポートされる ALC データ型、すべての事前定義デー
タ型、および DISTINCT 型 UDT。
注:
この関数は、COMPRESS USING 句または DECOMPRESS USING 句の一部として使用
される場合は引数をとりません。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプと規則
この関数に渡される式には、次のいずれかのデータ タイプが含まれている必要があ
ります。
•
•
•
•
•
•
•
•
•
BYTE
VARBYTE
CHARACTER
VARCHAR
JSON
TIME
TIMESTAMP
ST_Geometry や XML などのシステム定義の UDT。
LOB UDT、ARRAY、Period データ タイプなどの DISTINCT 型 UDT。
SQL 関数、演算子、式および述部
477
第 11 章 圧縮関数/圧縮解除関数
TD_LZ_COMPRESS
データ タイプは、対応する圧縮解除関数 TD_LZ_DECOMPRESS の結果のデータ タ
イプに一致する必要があります。
結果のタイプ
結果のデータ タイプは VARBYTE または BLOB です。
使用上の注意
数値データ タイプは、SQL 文で関数を呼び出す場合は有効ですが、列に対する ALC
用の関数として使用する場合には有効ではありません。
TD_LZ_COMPRESS を ALC で使用すると、列が NULL 受入可能ならば NULL も圧縮
されます。
TD_LZ_COMPRESS 関数を使用して JSON データを圧縮できます。ただし、
JSON_COMPRESS 関数は JSON データの圧縮用に最適化されているため、代わりに
JSON_COMPRESS を使用することを推奨します。
TD_LZ_COMPRESS で圧縮されたデータの圧縮解除
TD_LZ_COMPRESS を使用して圧縮されたデータを圧縮解除するには、
「TD_LZ_DECOMPRESS」を使用します。
関連トピック
詳細は、以下を参照してください。
• COMPRESS/DECOMPRESS 句の詳細については、< SQL データ型とリテラル、
B035-1143>を参照してください。
• ALC の詳細については、< SQL データ型とリテラル、B035-1143>の「COMPRESS
句/DECOMPRESS 句」を参照してください。
• UDF の暗黙のタイプ変換規則の詳細については、<SQL 外部ルーチン プログラミ
ング 、B035-1147>の「互換データ型」を参照してください。
• Lempel-ziv アルゴリズムの詳細については、http://zlib.net を参照してください。
• DECAMSET 関数について、詳細は DECAMSET を参照してください。
• Teradata 提供の各圧縮関数の比較と、圧縮関数を選択する際のガイドラインにつ
いての詳細は、<データベース設計、B035-1094>を参照してください。
• TD_LZ_COMPRESS を使用して圧縮されたデータを圧縮解除するには、
TD_LZ_DECOMPRESS を使用します。
478
SQL 関数、演算子、式および述部
第 11 章 圧縮関数/圧縮解除関数
TD_LZ_DECOMPRESS
TD_LZ_DECOMPRESS
目的
TD_LZ_COMPRESS 関数を使用して圧縮されたデータを圧縮解除します。
構文
TD_LZ_DECOMPRESS ( expression )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expression
VARBYTE か BLOB、またはこの 2 つの組み合わせとして表現される、
TD_LZ_COMPRESS 関数を使用して圧縮されたデータ。
注:
この関数は、COMPRESS USING 句または DECOMPRESS USING 句の一部として使用
される場合は引数をとりません。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプと規則
この関数に渡される式では、データ タイプが対応する圧縮関数 TD_LZ_COMPRESS
のものと同じである必要があります。入力のタイプは、VARBYTE か BLOB、または
この 2 つの組み合わせにします。
結果のタイプ
結果のデータ タイプは、常に ALC で使用可能なデータ タイプに一致します。
使用上の注意
TD_LZ_DECOMPRESS は通常、以前に TD_LZ_COMPRESS で圧縮されたテーブルの
列を圧縮解除するために、ALC で使用します。
SQL 関数、演算子、式および述部
479
第 11 章 圧縮関数/圧縮解除関数
TS_COMPRESS
この関数を直接呼び出すには、RETURNS 句を使用して目的の結果のデータ タイプ
を指定する必要があります。LOB などサイズの大きなデータ タイプに対して、この
関数を直接呼び出すことは推奨しません。
関連トピック
詳細は、以下を参照してください。
• COMPRESS/DECOMPRESS 句の詳細については、< SQL データ型とリテラル、
B035-1143>を参照してください。
• 指定されたデータ型を返す RETURN 句の使用例については、< SQL データ型とリ
テラル、B035-1143>の「パラメータ データ型」の TD_ANYTYPE データ型を参
照してください。
• TD_LZ_DECOMPRESS で使用する圧縮解除アルゴリズムについて、詳細は http://
zlib.net を参照してください。
• ALC の詳細については、< SQL データ型とリテラル、B035-1143>の「COMPRESS
句と DECOMPRESS 句」を参照してください。
TS_COMPRESS
目的
タイムゾーンのある(またはない) TIME および TIMESTAMP を最小バイト数に圧縮し
ます。
構文
TS_COMPRESS
( td_anytype )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
td_anytype
この関数では、タイムゾーン データ型のある(またはない)TIME または TIMESTAMP。
注:
この関数は、COMPRESS USING 句または DECOMPRESS USING 句の一部として使用
される場合は引数をとりません。
480
SQL 関数、演算子、式および述部
第 11 章 圧縮関数/圧縮解除関数
TS_COMPRESS
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプと規則
この関数の出力は、TS_DECOMPRESS 関数への入力となります。
入力引数の型は td_anytype ですが、この関数のアルゴリズムでは TIME および
TIMESTAMP データ型のみがサポートされています。TIME および TIMESTAMP の
各値(たとえば、年、月、または日)は、最小ビット数に個別に圧縮されてから連結
されます。
結果のタイプ
結果のデータ型は VARBYTE(20)になります。
使用上の注意
アルゴリズム圧縮(ALC)列を作成するときには、列を圧縮および圧縮解除する圧縮関
数および圧縮解除関数をそれぞれ含める必要があります。
データを ALC 列に挿入すると、データが圧縮されます。ALC 列を選択すると、デー
タが圧縮解除されます。
圧縮解除されるデータのデータ タイプ
必要なバイト数
TIME
6
TIMESTAMP
10
TIME WITH TIME ZONE
8
TIMESTAMP WITH TIME ZONE
12
例
例: TIME データ型の圧縮
TIME データ タイプのデータを圧縮解除するには、6 バイト必要です。次の表に、
そのバイトを分解し、それぞれの有効範囲と最小ビット数を示します。
時間
バイト
有効範囲
最小ビット数
時間
1
00 23
5
分
1
00 59
6
SQL 関数、演算子、式および述部
481
第 11 章 圧縮関数/圧縮解除関数
TS_DECOMPRESS
時間
バイト
有効範囲
最小ビット数
秒
4
00 000000 61.999999
6~26 (秒精度によって異な
ります)
TIME の次の値を挿入するとします。
INSERT into t1(1, TIME'03:38:06');
次の SQL 文が指定されていたとします。
CREATE TABLE table t1(pk int, col1 time(0) compress using ts_compress
decompress using ts_decompress);
必要なビット数は次のとおりです。
• 3 時= 5
• 38 分= 6
• 6 秒= 6
TIME を表わすために必要なビットの総数は 17 です。最小バイト数は 3 です。TIME
(TIMEZONE なし)では 6 バイトを使用するため、TS_COMPRESS は 6 バイトを 3 バ
イトに圧縮します。この関数によって、3 バイトが節約されます。
例: TIMESTAMP データ型の圧縮
次の SQL 文は、圧縮状態で格納された可能性のある t_timestamp の TIMESTAMP 列
を作成します。
CREATE TABLE table t_timestamp(i int, j timestamp(0) compress using
td_sysfnlib.ts_compress decompress using td_sysfnlib.ts_decompress);
関連トピック
詳細は、以下を参照してください。
• ACL の詳細については、「SQL データ タイプおよびリテラル」を参照してくださ
い。
• COMPRESS/DECOMPRESS 句の詳細については、 SQL データ型とリテラル、
B035-1143 を参照してください。
TS_DECOMPRESS
目的
TS_COMPRESS 関数で圧縮したタイムゾーンのある(またはない) TIME データおよび
TIMESTAMP データを圧縮解除します。
482
SQL 関数、演算子、式および述部
第 11 章 圧縮関数/圧縮解除関数
TS_DECOMPRESS
構文
TS_DECOMPRESS
( compressed_string )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
compressed_string
TS_COMPRESS で圧縮されたデータ。
注:
この関数は、COMPRESS USING 句または DECOMPRESS USING 句の一部として使用
される場合は引数をとりません。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプと規則
この関数には、データ タイプが VARBYTE(n)の式を渡さなければなりません。この
(n)の最大対応サイズは 20 です。
この関数への入力は、TS_COMPRESS 関数の出力結果でなければなりません。
結果のタイプ
結果のデータ タイプは td_anytype です。
例: 圧縮された TIME 列の作成
次の SQL 文は、ストレージから取り出すとき格納および圧縮解除された際に圧縮さ
れる t_time の TIME 列を作成します。
CREATE table t_time(i int, j time(6) compress using
td_sysfnlib.ts_compress decompress using td_sysfnlib.ts_decompress);
次の TIME 値を列 j に挿入するとします。
INSERT into t_time(1, TIME'06:26:44.820000');
INSERT into t_time(2, TIME'10:26:44.820000');
次の SQL 文を実行します。
SQL 関数、演算子、式および述部
483
第 11 章 圧縮関数/圧縮解除関数
TransUnicodeToUTF8
SELECT j from t_time;
t_time テーブルに値を挿入したときに圧縮された 2 つの TIME 値が圧縮解除されて
返されます。
関連トピック
COMPRESS/DECOMPRESS 句の詳細については、< SQL データ型とリテラル、
B035-1143>を参照してください。
TransUnicodeToUTF8
目的
指定された Unicode 文字データを UTF8 形式に圧縮します。
構文
TransUnicodeToUTF8 ( Unicode_string)
TD_SYSFNLIB.
注:
この関数は、COMPRESS USING 句または DECOMPRESS USING 句の一部として使用
される場合は引数をとりません。
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
Unicode_string
Unicode の文字列または列式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプと規則
この関数には、データ型が VARCHAR(n) CHARACTER SET UNICODE の式を渡さなけ
ればなりません。この(n)の最大対応サイズは 32000 です。UDF に適用される暗黙
のデータ型変換規則を使用して VARCHAR(32000) CHARACTER SET UNICODE に変
換できる、データ型の引数も渡すことができます。たとえば、
484
SQL 関数、演算子、式および述部
第 11 章 圧縮関数/圧縮解除関数
TransUnicodeToUTF8
TransUnicodeToUTF8(CHAR)は可能です。暗黙的に
TransUnicodeToUTF8(VARCHAR)に変換できるからです。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って VARCHAR に変換で
きない引数は、明示的にキャストする必要があります。
この関数への入力は Unicode 文字データでなければなりません。
入力として NULL を指定した場合、この関数は NULL を返します。
結果のタイプ
結果のデータ型は VARBYTE(64000)になります。
使用上の注意
TransUnicodeToUTF8 は指定された Unicode 文字データを UTF8 形式に圧縮しま
す。その後で、圧縮した結果を返します。この関数は、入力データの大部分が Latin
文字の場合に役立ちます。これは、Unicode は Latin 文字を表現するために 2 バイ
ト使用しますが、UTF8 は 1 バイトで表現するためです。
TransUnicodeToUTF8 は、長さにかかわらず Unicode 文字列の圧縮に対して良好な
結果が得られます。以下の状況での使用が最適です。
• ほとんどが US-ASCII 文字を格納する Unicode 列に対する使用
• 以下の組み合わせで、データが頻繁に切り替わる場合
• 大文字と小文字
• 数字と文字
• Latin 文字と非 Latin 文字
• データが非常に動的な場合(頻繁な更新)
この関数を直接呼び出すこともできますが、通常、TransUnicodeToUTF8 はアルゴ
リズム圧縮(ALC)を使用してテーブルの列を圧縮します。TransUnicodeToUTF8 を
ALC で使用すると、列が NULL 受入可能ならば NULL も圧縮されます。
制約事項
TransUnicodeToUTF8 が圧縮できる文字値は、7 ビットの ASCII 文字(U+0000 から
U+007F)の範囲だけです。これは US-ASCII とも呼ばれています。
例: TransUnicodeToUTF8 で圧縮されたデータの圧縮解除
TransUnicodeToUTF8 を使用して圧縮された Unicode データを圧縮解除するには、
TransUTF8ToUnicode 関数を使用します。
SQL 関数、演算子、式および述部
485
第 11 章 圧縮関数/圧縮解除関数
TransUTF8ToUnicode
この例では、デフォルトのサーバー文字セットを UNICODE と仮定します。
Description 列の値は、ALC で TransUnicodeToUTF8 関数を使用して圧縮されます。
この関数は、Unicode の入力を UTF8 形式で格納します。TransUTF8ToUnicode 関
数は、直前に圧縮した値を圧縮解除します。
CREATE TABLE Pendants
(ItemNo INTEGER,
Gem CHAR(10) UPPERCASE,
Description VARCHAR(1000)
COMPRESS USING TD_SYSFNLIB.TransUnicodeToUTF8
DECOMPRESS USING TD_SYSFNLIB.TransUTF8ToUnicode);
関連トピック
詳細は、以下を参照してください。
• COMPRESS/DECOMPRESS 句の詳細については、< SQL データ型とリテラル、
B035-1143>を参照してください。
• ALC の詳細については、< SQL データ型とリテラル、B035-1143>の「COMPRESS
句と DECOMPRESS 句」を参照してください。
• 詳細については、<SQL 外部ルーチン プログラミング、B035-1147>の「互換デー
タ型」を参照してください。
• TransUnicodeToUTF8 を使用して圧縮された Unicode データを圧縮解除するに
は、TransUTF8ToUnicode 関数を使用します。TransUnicodeToUTF8 を参照して
ください。
• Teradata 提供の各圧縮関数の比較と、圧縮関数を選択する際のガイドラインにつ
いての詳細は、<データベース設計、B035-1094>を参照してください。
TransUTF8ToUnicode
目的
TransUnicodeToUTF8 関数を使用して圧縮された Unicode データを圧縮解除します。
構文
TransUTF8ToUnicode ( compressed_string)
TD_SYSFNLIB.
注:
この関数は、COMPRESS USING 句または DECOMPRESS USING 句の一部として使用
される場合は引数をとりません。
486
SQL 関数、演算子、式および述部
第 11 章 圧縮関数/圧縮解除関数
TransUTF8ToUnicode
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
compressed_string
TransUnicodeToUTF8 関数を使用して圧縮された Unicode 文字データです。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプと規則
この関数には、データ タイプが VARBYTE(n)の式を渡さなければなりません。この
(n)の最大対応サイズは 64000 です。
この関数への入力は、TransUnicodeToUTF 関数の出力結果でなければなりません。
入力として NULL を指定した場合、この関数は NULL を返します。
結果のタイプ
結果のデータ タイプは VARCHAR(32000) CHARACTER SET UNICODE です。
使用上の注意
TransUnicodeToUTF8 は指定された Unicode 文字データを UTF8 形式に圧縮しま
す。その後で、圧縮した結果を返します。この関数は、入力データの大部分が Latin
文字の場合に役立ちます。これは、Unicode は Latin 文字を表現するために 2 バイ
ト使用しますが、UTF8 は 1 バイトで表現するためです。
TransUnicodeToUTF8 は、長さにかかわらず Unicode 文字列の圧縮に対して良好な
結果が得られます。以下の状況での使用が最適です。
• ほとんどが US-ASCII 文字を格納する Unicode 列に対する使用
• 以下の組み合わせで、データが頻繁に切り替わる場合
• 大文字と小文字
• 数字と文字
• Latin 文字と非 Latin 文字
• データが非常に動的な場合(頻繁な更新)
この関数を直接呼び出すこともできますが、通常、TransUnicodeToUTF8 はアルゴ
リズム圧縮(ALC)を使用してテーブルの列を圧縮します。TransUnicodeToUTF8 を
ALC で使用すると、列が NULL 受入可能ならば NULL も圧縮されます。
SQL 関数、演算子、式および述部
487
第 11 章 圧縮関数/圧縮解除関数
TransUTF8ToUnicode
例: TransUTF8ToUnicode での UNICODE 値の圧縮解除
この例では、デフォルトのサーバー文字セットを UNICODE と仮定します。
Description 列の値は、ALC で TransUnicodeToUTF8 関数を使用して圧縮されます。
この関数は、Unicode の入力を UTF8 形式で格納します。TransUTF8ToUnicode 関
数は、直前に圧縮した値を圧縮解除します。
CREATE TABLE Pendants
(ItemNo INTEGER,
Gem CHAR(10) UPPERCASE,
Description VARCHAR(1000)
COMPRESS USING TD_SYSFNLIB.TransUnicodeToUTF8
DECOMPRESS USING TD_SYSFNLIB.TransUTF8ToUnicode);
関連トピック
詳細は、以下を参照してください。
• COMPRESS/DECOMPRESS 句の詳細については、< SQL データ型とリテラル、
B035-1143>を参照してください。
• ALC の詳細については、< SQL データ型とリテラル、B035-1143>の「COMPRESS
句と DECOMPRESS 句」を参照してください。
488
SQL 関数、演算子、式および述部
第 12 章
CASE 式
概要
この章では、SQL CASE 式について説明します。
CASE
目的
TRUE と評価される等価比較および条件に基づいて、条件式または式に代替値を指
定します。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
概要
CASE を使用すれば、アプリケーション開発者がデータの表現を変更するための効
率の良い強力な方法が得られます。CASE によって、ホスト プログラムの介入を必
要とせずにデータ変換を行なうことができます。
たとえば、従業員のステータスをそれぞれフルタイムまたはパートタイムを意味す
る 1 または 2 と符号化することを想定します。効率化のためにシステムは数値コー
ドを格納しますが、読み取り側のためには、システムは 、レポート内の対応する語
をプリントまたは表示します。この格納および変換は、Teradata Database によって
管理されます。
さらに、CASE を使用することによって、アプリケーションでデータベースからの
情報に基づいて NULL 値を生成することができます。その際にホスト プログラムを
介する必要はありません。これとは逆に、CASE を使用して、NULL を値に変換する
ことができます。
CASE 式の 2 つの形式
CASE 式は、次の書式で指定します。
SQL 関数、演算子、式および述部
489
第 12 章 CASE 式
値形式の CASE 式
• 値形式の CASE は、「値形式の CASE 式」で説明しています。
• 検索形式の CASE は、「検索形式の CASE 式」で説明しています。
NULL の処理のための CASE 簡略形式
CASE の 2 つの簡略形式は、null を処理するために提供されます。
• COALESCE については、「COALESCE 式」で説明しています。
• NULLIF については、「NULLIF 式」で説明しています。
値形式の CASE 式
目的
テスト式によって一連の式の等価性を評価し、テスト式の値と値が一致する値を持
つ最初の WHEN 句に定義されたスカラー式の値を結果として戻します。等価式がな
い場合には、任意指定の ELSE 句によって定義されたスカラー値を戻すか、または等
価式が省略されている場合には、NULL を戻します。
構文
CASE
A
WHEN
value_expression_1
value_expression_n
A
THEN
scalar_expression_n
B
END
B
ELSE scalar_expression_m
構文要素
value_expression_1
value_expression_n と値の等価性をテストされる式。
value_expression_n
value_expression_1 の値に対する等価性をテストする一連の式。
scalar_expression_n
value_expression_1 と value_expression_n の最初の等価比較で値が戻される式。
scalar_expression_m
評価が ELSE 句になる場合に値が戻される式。
490
SQL 関数、演算子、式および述部
第 12 章 CASE 式
値形式の CASE 式
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
Teradata Database では、value_expression_1 は確定的な関数でなければならない
という ANSI の制限事項は施行されていません。特に、Teradata Database では関数
RANDOM を value_expression_1 内で使用することができます。
RANDOM を使用すると、value_expression_1 と比較するたびに value_expression_n
が再計算されるかどうかによって、非確定的な動作が生じる可能性があることに注
意してください。
使用上の注意
WHEN 句は、順番に処理されます。
value_expression_1 に等しい最初の WHEN 句 value_expression_n は、それに関連
した scalar_expression_n の値を結果として戻します。これで、この評価プロセスは
終了します。
value_expression_n に等しい value_expression_1 が存在しない場合は、ELSE 句の
引数である scalar_expression_m が結果となります。
ELSE 句が定義されていない場合には、結果はデフォルトの NULL になります。
value_expression_1 のデータ タイプは、すべての value_expression_n 値のデータ
タイプと比較可能でなければなりません。
CASE 式の結果データ タイプの詳細については、CASE 式結果タイプの規則を参照し
てください。
スカラー subquery は、CASE 式の WHEN 句、THEN 句、および ELSE 句で使用でき
ます。非スカラーの subquery(複数の行を返す subquery)を使用すると、実行時エ
ラーが返されます。
推奨事項: 組み込み関数 CURRENT_DATE または CURRENT_TIMESTAMP は、パー
ティション基本索引(PPI)のパーティション化式で指定された CASE 式では使用でき
ません。この場合、調整処理の間にすべての行がスキャンされます。
デフォルト タイトル
CASE 式のデフォルト タイトルは、次のようになります。
<CASE expression>
CASE 式におけるデータ タイプに対する制限事項
以下の制限事項が、CASE 式中の CLOB、BLOB、および UDT タイプに対して適用さ
れます。
SQL 関数、演算子、式および述部
491
第 12 章 CASE 式
値形式の CASE 式
データ タ 制約事項
イプ
BLOB
value_expression_1、value_expression_n、scalar_expression_m、または
scalar_expression_n の中で BLOB を使えるのは、これが BYTE または VARBYTE
にキャストされる場合だけです。
CLOB
value_expression_1、value_expression_n、scalar_expression_m、または
scalar_expression_n の中で CLOB を使えるのは、これが CHAR または
VARCHAR にキャストされる場合だけです。
UDT
1 つの CASE 式で、複数の UDT を使用できます。ただし、次の制限があります。
• value_expression_1 から value_expression_n までのデータ型は、いずれかが
UDT データ型である場合には、同一の UDT データ型である必要があります。
• scalar_expression_n と scalar_expression_m のいずれかが UDT データ型で
ある場合、どちらも同じ UDT データ型である必要があります。
Teradata Database は、CASE 式での UDT に対しては暗黙の型変換を実行しませ
ん。この制限事項に対する対処策としては、CREATE CAST を使用して、UDT ど
うしの間でキャストを行なう CAST を定義してから、CASE 式内で明示的に CAST
関数を呼び出します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規
則および例、B035-1144>を参照してください。
例
例: 費用の端数の計算
次の例は、値形式の CASE 式を使用して、タイプ「1」のパーツで表わされた品目の
総費用に対する費用の比を計算します。
SELECT SUM(CASE part
WHEN '1'
THEN cost
ELSE 0
END
)/SUM(cost)
FROM t;
例: CASE 式の使用
CASE 式は、任意の value-expression の代わりに使用することができます。
SELECT *
FROM t
WHERE x = CASE y
WHEN 2
THEN 1001
WHEN 5
492
SQL 関数、演算子、式および述部
第 12 章 CASE 式
値形式の CASE 式
THEN 1002
END;
例: CASE 式と連結演算子の組合わせ
以下の例は、CASE 式を連結演算子と組み合わせする方法を示しています。
SELECT prodID, CASE prodSTATUS
WHEN 1
THEN 'SENT'
ELSE 'BACK ORDER'
END || ' STATUS'
FROM t1;
例: 値式での UDT データ型の使用
value_expression_1 から value_expression_n までを使用して、値形式の CASE 式
で、等価性をテストします。
これらの例のために、次のようにテーブルを定義します。
create table udtval038_t1(id integer, udt1 testcircleudt, udt2
testrectangleudt) PRIMARY INDEX (id);
次の例では、値形式の CASE 式を示します。すべての値式が同じ UDT データ タイ
プとなっています。
SELECT CASE udt1
WHEN
THEN
WHEN
THEN
WHEN
THEN
ELSE
END
new testcircleudt('1,1,2,yellow,circ')
'Row 1'
new testcircleudt('2,2,4,purple,circ')
'Row 2'
new testcircleudt('3,3,9,green,circ')
'Row 3'
'Row is NULL'
FROM t1;
*** Query completed. 4 rows found. One column returned.
<CASE expression>
-----------------Row 3
Row 1
Row is NULL
Row 2
ただし、次の例は、testrectangleudt が他の UDT データ タイプに一致しないため、
正常に完了しません。
SQL 関数、演算子、式および述部
493
第 12 章 CASE 式
値形式の CASE 式
SELECT CASE udt1
WHEN
THEN
WHEN
THEN
WHEN
THEN
ELSE
END
new testcircleudt('1,1,2,yellow,circ')
'Row 1'
new testrectangleudt('2,2,4,4,purple,rect')
'Row 2'
new testcircleudt('3,3,9,green,circ')
'Row 3'
'Row is NULL'
FROM t1;
例 1: スカラー式での UDT データ型の使用
値形式または検索形式の CASE 式での等価比較が、TRUE に評価された場合に返す式
として、または、ELSE 条件で返す値として、scalar_expression_n および
scalar_expression_m を使用します。
これらの例のために、次のようにテーブルを定義します。
create table udtval038_t1(id integer, udt1 testcircleudt, udt2
testrectangleudt) PRIMARY INDEX (id);
次に、検索形式の CASE 式の例を示します。すべてのスカラー式が同じ UDT デー
タ タイプとなっています。
注: search_condition_n は、scalar_expression_n と異なる UDT データ型にすること
ができます。 SELECT * FROM udtval038_t1
WHERE udt1 = CASE
WHEN udt2 <> new testrectangleudt('2,2,4,4,pink,rect')
THEN new testcircleudt('1,1,2,blue,circ')
ELSE new testcircleudt('2,2,4,purple,circ')
*** Query completed. 2 rows found. 3 columns returned.
END;
id udt1
----------- ----------------------------------------------1 1, 1, 2, yellow, circ
2 2, 2, 4, purple, circ
ただし、次の例は、スカラー式に異なるデータ タイプがあるため、正常に完了しま
せん。
SELECT * FROM udtval038_t1
WHERE udt1 = CASE
WHEN udt2 <> new testrectangleudt('2,2,4,4,pink,rect')
THEN new testcircleudt('1,1,2,blue,circ')
ELSE new testrectangleudt('2,2,4,4,purple,rect')
END;
494
SQL 関数、演算子、式および述部
第 12 章 CASE 式
検索形式の CASE 式
関連トピック
詳細は、以下を参照してください。
• エラー条件については、「エラー条件」を参照してください。
• CASE 式の結果データ型の詳細については、「CASE 式結果タイプの規則」を参照
してください。
• CASE 式の結果の形式については、「CASE 式の書式」を参照してください。
• null と CASE 式については、「CASE と NULL」を参照してください。
検索形式の CASE 式
目的
検索条件を評価し、TRUE の値が見つかると、WHEN 句で定義されたスカラー値の
集合の 1 つを戻します。TRUE テストがない場合には、ELSE 句によって定義された
スカラー値を戻すか、または省略されている場合には、NULL を戻します。
構文
CASE
WHEN
search_condition_n
THEN
scalar_expression_n
A
END
A
ELSE
scalar_expression_m
構文要素
search_condition_n
真偽をテストする述部条件。
scalar_expression_n
search_condition_n が、TRUE と評価される最初の検索条件である場合に値が戻さ
れるスカラー式。
scalar_expression_m
どの search_condition_n も TRUE と評価されない場合に値が戻されるスカラー式。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
SQL 関数、演算子、式および述部
495
第 12 章 CASE 式
検索形式の CASE 式
使用上の注意
WHEN 句は、順番に処理されます。
TRUE になる最初の WHEN 句である search_condition_n は、関連する
scalar_expression_n の値を結果として戻します。これで、この評価プロセスは終了
します。
どの search_condition_n も TRUE でない場合、ELSE 句の引数である
scalar_expression_m が結果となります。
ELSE 句が定義されていない場合、結果はデフォルトの NULL になります。
スカラー subquery は、CASE 式の WHEN 句、THEN 句、および ELSE 句で使用でき
ます。非スカラーの subquery(複数の行を返す subquery)を使用すると、実行時エ
ラーが返されます。
推奨事項: 組み込み関数 CURRENT_DATE または CURRENT_TIMESTAMP は、パー
ティション基本索引(PPI)のパーティション化式で指定された CASE 式では使用でき
ません。この場合、調整処理の間にすべての行がスキャンされます。
デフォルト タイトル
CASE 式のデフォルト タイトルは、次のようになります。
<CASE expression>
WHEN 検索条件の規則
WHEN 検索条件には、次のような特性があります。
•
•
•
•
LIKE、=、または<>などの任意の比較演算子の形式をとることができます。
ALL または ANY などの限定述部にすることができます。
スカラー subquery を 1 つ含めることができます。
結合した 2 つのテーブルを含めることができます。
以下に例を示します。
SELECT CASE
WHEN t1.x=t2.x THEN t1.y
ELSE t2.y
END FROM t1,t2;
• SELECT 文を含めることはできません。
CASE 式におけるデータ タイプに対する制限事項
以下の制限事項が、CASE 式中の CLOB、BLOB、および UDT タイプに対して適用さ
れます。
496
SQL 関数、演算子、式および述部
第 12 章 CASE 式
検索形式の CASE 式
データ タ 制約事項
イプ
BLOB
value_expression_1、value_expression_n、scalar_expression_m、または
scalar_expression_n の中で BLOB を使えるのは、これが BYTE または VARBYTE
にキャストされる場合だけです。
CLOB
value_expression_1、value_expression_n、scalar_expression_m、または
scalar_expression_n の中で CLOB を使えるのは、これが CHAR または
VARCHAR にキャストされる場合だけです。
UDT
1 つの CASE 式で、複数の UDT を使用できます。ただし、次の制限があります。
• value_expression_1 から value_expression_n までのデータ型は、いずれかが
UDT データ型である場合には、同一の UDT データ型である必要があります。
• scalar_expression_n と scalar_expression_m のいずれかが UDT データ型で
ある場合、どちらも同じ UDT データ型である必要があります。
Teradata Database は、CASE 式での UDT に対しては暗黙の型変換を実行しませ
ん。この制限事項に対する対処策としては、CREATE CAST を使用して、UDT ど
うしの間でキャストを行なう CAST を定義してから、CASE 式内で明示的に CAST
関数を呼び出します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規
則および例、B035-1144>を参照してください。
例
例: 検索条件の評価
次の文は、「例」にある CASE の値形式の最初の例と同じです。
SELECT SUM(CASE
WHEN part='1'
THEN cost
ELSE 0
END
) / SUM(cost)
FROM t;
例: CASE 式の使用
CASE 式は、任意の value-expression の代わりに使用することができます。
以下の例では、ELSE 句を指定していないことに注意してください。CASE 式の ELSE
句は常にオプションです。ELSE 句を省いたときにどの WHEN 条件も TRUE でなけ
れば、null が戻されます。
SELECT *
FROM t
WHERE x = CASE
SQL 関数、演算子、式および述部
497
第 12 章 CASE 式
検索形式の CASE 式
WHEN
THEN
WHEN
THEN
END;
y=2
1
(z=3 AND y=5)
2
例: ELSE 句の使用
次の例では、ELSE 句を使用しています。
SELECT *
FROM t
WHERE x = CASE
WHEN y=2
THEN 1
ELSE 2
END;
例: CASE 式を使ってパフォーマンスを強化する
次の例は、性能を飛躍的に向上させるために、CASE 式を使用してデータから複数の
パスを削除する方法を示しています。CASE を使用しなければ、それぞれの領域に対
して複数の問合わせを実行し、個々の問合わせに対する応答を最終報告にまとめな
ければなりません。
SELECT SalesMonth, SUM(CASE
WHEN Region='NE'
THEN Revenue
ELSE 0
END),
SUM(CASE
WHEN Region='NW'
THEN Revenue
ELSE 0
END),
SUM(CASE
WHEN Region LIKE 'N%'
THEN Revenue
ELSE 0
END)
AS NorthernExposure, NorthernExposure/SUM(Revenue),
SUM(Revenue)
FROM Sales
GROUP BY SalesMonth;
例: 従業員の給与を示すレポートの作成
給与が$40000 よりも少ない従業員はすべて、昇給対象者になります。
498
SQL 関数、演算子、式および述部
第 12 章 CASE 式
検索形式の CASE 式
給与の上限
勤続年数の下限
昇給の割合
$30000.00
8
15
$35000.00
10
10
$40000.00
5
次の SELECT 文は、CASE 式を使用して給与が$40000 より少ない従業員すべてを表
示するレポートを作成し、名字の最初の 15 文字、給与総額($と句読点を使用した
書式)、現在の日付を基にした勤続年数(On_The_Job の列)、および「15%昇給」、
「10%昇給」、「05%昇給」、「資格なし」の 4 つのカテゴリのどの資格を有するの
かを表示します。
SELECT CAST(last_name AS CHARACTER(15))
,salary_amount (FORMAT '$,$$9,999.99')
,(date - hire_date)/365.25 (FORMAT 'Z9.99') AS On_The_Job
,CASE
WHEN salary_amount < 30000 AND On_The_Job > 8
THEN '15% Increase'
WHEN salary_amount < 35000 AND On_The_Job > 10
THEN '10% Increase'
WHEN salary_amount < 40000 AND On_The_Job > 10
THEN '05% Increase'
ELSE 'Not Qualified'
END AS Plan
WHERE salary_amount < 40000
FROM employee
ORDER BY 4;
この問合わせの結果は、次の表のとおりです。
last_name
salary_amount
On_The_Job
計画
Trader
$37,850.00
20.61
05% Increase
Charles
$39,500.00
18.44
05% Increase
Johnson
$36,300.00
20.41
05% Increase
Hopkins
$37,900.00
19.99
05% Increase
Morrissey
$38,750.00
18.44
05% Increase
Ryan
$31,200.00
20.41
10% Increase
Machado
$32,300.00
18.03
10% Increase
Short
$34,700.00
17.86
10% Increase
Lombardo
$31,000.00
20.11
10% Increase
SQL 関数、演算子、式および述部
499
第 12 章 CASE 式
エラー条件
last_name
salary_amount
On_The_Job
計画
Phillips
$24,500.00
19.95
15% Increase
Rabbit
$26,500.00
18.03
15% Increase
Kanieski
$29,250.00
20.11
15% Increase
Hoover
$25,525.00
20.73
15% Increase
Crane
$24,500.00
19.15
15% Increase
Stein
$29,450.00
20.41
15% Increase
関連トピック
詳細は、以下を参照してください。
• エラー条件については、「エラー条件」を参照してください。
• CASE 式の結果データ型の詳細については、「CASE 式結果タイプの規則」を参照
してください。
• CASE 式の結果の形式については、「CASE 式の書式」を参照してください。
• null と CASE 式については、「CASE と NULL」を参照してください。
エラー条件
以下の条件または式は、CASE 式では無効とみなされます。
条件または式
例
キーワード CASE の後に条件を指定した場
合。
SELECT CASE a=1
WHEN 1
THEN 1
ELSE 0
END
FROM t;
無効な WHEN 式を値形式の CASE 式に指定 SELECT CASE a
した場合。
WHEN a=1
THEN 1
ELSE 0
END
FROM t;
無効な WHEN 条件を検索形式の CASE 式に SELECT CASE
指定した場合。
WHEN a
500
SQL 関数、演算子、式および述部
第 12 章 CASE 式
CASE 式結果タイプの規則
条件または式
例
THEN 1
ELSE 0
END
FROM t;
SELECT CASE
WHEN NULL
THEN 'NULL'
END
FROM table_1;
スカラー以外の subquery が検索形式の
SELECT CASE
CASE 式の WHEN 条件で指定された場合。
WHEN t.a IN
(SELECT u.a
FROM u)
THEN 1
ELSE 0
END
FROM t;
互いに同じではない複数の UDT を CASE 式 SELECT CASE t.shape.gettype()
が参照する場合。
WHEN 1
THEN NEW circle('18,18,324')
WHEN 2
THEN NEW square('20,20,400')
END;
CASE 式結果タイプの規則
CASE THEN/ELSE 句の式はさまざまなデータ型になることがあるため、結果タイプ
を決定するのは容易であるとは限りません。CASE 式では、TYPE 属性関数を引数と
して使用して、結果のデータ タイプを検索することができます。TYPE を参照して
ください。
次のルールは、CASE 式の結果のデータ タイプに適用されます。
同じ文字以外のデータ タイプを含む THEN/ELSE 式
すべての THEN 式および ELSE 式が同じ文字以外のデータ タイプを含む場合、CASE
式の結果はこのタイプになります。たとえば、すべての THEN 式および ELSE 式が
INTEGER タイプを含む場合、CASE 式の結果タイプは INTEGER になります。
SQL 関数、演算子、式および述部
501
第 12 章 CASE 式
CASE 式結果タイプの規則
DECIMAL 結果の精度と小数部桁数がどのように計算されるかについては、2 項算術
演算子の結果のデータ タイプを参照してください。
THEN/ELSE 文字タイプの式
以下の規則は、すべての THEN/ELSE 式のデータ タイプが文字の場合の CASE 式に
適用されます。
• CASE 式の結果も文字データ タイプになり、その長さは、THEN/ELSE 式のさまざ
まな文字データ タイプの最大長に等しくなります。
• すべての THEN/ELSE 式のデータ タイプが CHARACTER (または CHAR)の場合、
結果のデータ タイプは CHARACTER になります。複数の式が VARCHAR (または
LONG VARCHAR)の場合、結果のデータ タイプは VARCHAR になります。
• 結果のサーバー文字セットは、次のように決定されます。
• CASE 式に 1 つの非リテラル文字式と 1 つ以上のリテラルが含まれている場
合、Teradata Database はすべてのリテラルを非リテラルの文字セットにコー
ド変換します。このコード変換が成功すると、非リテラルの文字セットが結果
のデータ タイプに使用されます。変換に失敗した場合、結果のサーバー文字
セットは Unicode になります。
• CASE 式に複数の非リテラル文字式と 1 つ以上のリテラルが含まれている場合
は、次のようになります。
すべての非リテラル式に同一の文字セットが含まれている場合、Teradata
Database は共通データ型としてこの文字セットを使用します。そうではなく、
非リテラル式に異なる文字セットが含まれている場合、Teradata Database は
共通データ型として Unicode 文字セットを使用します。
Teradata Database は、 すべてのリテラルを共通データ型の文字セットにコー
ド変換できるかどうかを試します。この変換に成功すると、結果のデータ タ
イプは共通データ タイプの文字セットになります。変換に失敗した場合、結
果のサーバー文字セットは Unicode になります。
例
CASE 式における文字データの例
次の CHARACTER データの動作の例では、デフォルト サーバー文字セットが KANJI1
であり、CASE の例のテーブル定義は次のようになっているとします。
CREATE TABLE table_1
(
i
INTEGER,
column_l CHARACTER(10)
column_u CHARACTER(10)
column_j CHARACTER(10)
column_g CHARACTER(10)
502
CHARACTER
CHARACTER
CHARACTER
CHARACTER
SET
SET
SET
SET
LATIN,
UNICODE,
KANJISJIS,
GRAPHIC,
SQL 関数、演算子、式および述部
第 12 章 CASE 式
CASE 式結果タイプの規則
column_k CHARACTER(10) CHARACTER SET KANJI1
);
注: Teradata の国際化計画に従って、KANJI1 のサポートはサポート外になりまし
た。このサポートは、近い将来に廃止される予定です。KANJI1 はデフォルトの文
字セットとして許可されません。システムはデフォルトの KANJI1 文字セットを
UNICODE 文字セットに変更します。KANJI1 の新規オブジェクトの作成は、高度に
制限されています。KANJI1 を使用する問合わせやアプリケーションの多くは、従
来通り動作しますが、KANJI1 を使用するサイトはできるだけ早く別の文字セット
に変換する必要があります。 詳細の参照先 “KANJI1 文字セット” 国際文字セット サ
ポート内。
CASE 式における文字データの例: 例 1
次に示す問合わせ結果のサーバー文字セットは、UNICODE になります。これは、
CASE 式に複数の非リテラル文字式が含まれ、それらの文字セットが異なるためです。
SELECT i, CASE
WHEN
WHEN
WHEN
WHEN
ELSE
END
FROM table_1
ORDER BY 1;
i=2 THEN
i=3 THEN
i=4 THEN
i=5 THEN
column_l
column_u
column_j
column_g
column_k
次の問合わせでは、THEN/ELSE 句に FLOAT 値と VARCHAR 値が含まれている CASE
式から VARCHAR の結果が戻されます。FLOAT のデフォルト書式が 30 文字未満の
文字列であり、USER が VARCHAR(30) CHARACTER SET UNICODE として設定され
ているため、結果の長さは 30 になります。USER が UNICODE であるため、結果は
CHARACTER SET UNICODE となります。
SELECT a, CASE
WHEN a=1
THEN TIME
ELSE USER
END
FROM table_1
ORDER BY 1;
CASE 式における文字データの例: 例 2
次の問合わせの結果は、5354 エラー(引数は KANJI1 タイプでなければならない)に
なります。これは、ある THEN/ELSE 式が KANJI1 リテラルであり、その他のすべ
ての THEN/ELSE 式のサーバー文字セットが KANJI1 ではないためです。
SQL 関数、演算子、式および述部
503
第 12 章 CASE 式
CASE 式結果タイプの規則
SELECT i, CASE
WHEN
WHEN
WHEN
WHEN
WHEN
ELSE
END
FROM table_1
ORDER BY 1;
i=1 THEN
i=2 THEN
i=3 THEN
i=4 THEN
i=5 THEN
column_k
column_l
column_u
column_j
column_g
_Kanji1'4142'XC
この例では、以下のテーブル定義があるものとします。
CREATE table_1
(i
INTEGER,
column_l CHARACTER(10)
column_u CHARACTER(10)
column_j CHARACTER(10)
column_g CHARACTER(10)
column_k CHARACTER(10)
CHARACTER
CHARACTER
CHARACTER
CHARACTER
CHARACTER
SET
SET
SET
SET
SET
LATIN,
UNICODE,
KANJISJIS,
GRAPHIC,
KANJI1);
次の問合わせは、サーバー文字セットが GRAPHIC であるため(文字タイプを持つ最
初の THEN のサーバー文字セットが GRAPHIC であるため)に失敗します。
SELECT i, CASE
WHEN
WHEN
WHEN
WHEN
WHEN
ELSE
END
FROM table_1
ORDER BY 1;
i=1
i=2
i=3
i=4
i=5
10
THEN
THEN
THEN
THEN
THEN
4
column_g
5
column_l
column_k
CASE 式における文字データの例: 例 3
次の問合わせの THEN/ELSE 式には、Unicode 列が含まれます。この問合せは成功
し、結果のデータ タイプは UNICODE になります。これは、この CASE 式に 1 つの
Unicode 列が含まれていて、その他のリテラルがすべて正常に Unicode にコード変
換できるためです。
SELECT i, CASE
WHEN
WHEN
WHEN
WHEN
ELSE
504
i=1
i=2
i=3
i=4
10
THEN
THEN
THEN
THEN
column_u
'abc'
8
_KanjiSJIS'4142'XC
SQL 関数、演算子、式および述部
第 12 章 CASE 式
CASE 式結果タイプの規則
END
FROM table_1
ORDER BY 1;
CASE 式における文字データの例: 例 4
次の問合わせの THEN/ELSE 式には、Latin 列が含まれます。この問合せは成功し、
結果のデータ タイプは Latin になります。これは、その他のリテラルがすべて正常
に Latin にコード変換できるためです。
SELECT i, CASE
WHEN i=1 THEN 'abc'
WHEN i=2 THEN column_l
ELSE 'def'
END
FROM table_1
ORDER BY 1;
混合データ タイプを含む THEN/ELSE 式
混合データについての規則を次の表に定義します。
THEN/ELSE 句の式
結果
BYTE および/または VARBYTE デー
タ タイプで構成される場合
すべての THEN/ELSE 式のデータ タイプが BYTE の
場合、結果のデータ タイプは BYTE になります。複
数の式が VARBYTE の場合、結果のデータ タイプは
VARBYTE になります。
結果の長さは異なるバイト数のデータ タイプの最大
長と等しくなります。
DateTime、または Interval データ タ すべての THEN/ELSE 句の式は同じデータ タイプを
イプを含んでいる場合
含まなければなりません。
FLOAT (近似値)を含んでいて、文字列 CASE 式から FLOAT の結果が戻されます。
を含んでいない場合
注: FLOAT データ タイプが関係する場合は、不正確
さを継承することはある程度避けられません。
DECIMAL データだけで構成されてい CASE 式から DECIMAL の結果が戻されます。
る場合
注: DECIMAL の計算結果は、38 桁以下に限定されま
す。38 桁を超える場合は、数値オーバーフロー エ
混合 DECIMAL、BYTEINT、
ラーになります。
SMALLINT、INTEGER、および
BIGINT データだけで構成されている DECIMAL 結果の精度と小数部桁数がどのように計算
場合
されるかについては、2 項算術演算子の結果のデー
タ タイプを参照してください。
すべて暗黙的に FLOAT に変換され、CASE 式により
FLOAT の結果が返されます。
SQL 関数、演算子、式および述部
505
第 12 章 CASE 式
CASE 式結果タイプの規則
THEN/ELSE 句の式
結果
注:
FLOAT データ タイプが関係する場合は、不正確さを
継承することはある程度避けられません。10 進値お
よび整数値を浮動小数点数値に暗黙的に変換すると、
精度が喪失するか、または正確に表現できない数字
を生成することになります。
BYTEINT、SMALLINT、INTEGER、 結果タイプは THEN/ELSE 句の式の最大タイプです。
および BIGINT データが混在している 次のリストはタイプを最大から最小へと順序付けて
場合
います。
• BIGINT
• INTEGER
• SMALLINT
• BYTEINT
NUMERIC および CHARACTER デー
タだけで構成されている場合
数値データは、CHARACTER 型に変換されます。こ
の型の長さは、この数値式に関連付けられたフォー
マットによって決まります。その後、結果のデータ
タイプには文字、長さおよび文字セットについての
ルールが適用されます。詳細は、THEN/ELSE 文字タ
イプの式を参照してください。
注: サーバー文字セットが GRAPHIC である場合はエ
ラーが生成されます。
CASE 式における数値データの例
以下に示す数値データの動作の例では、CASE の例のテーブル定義を次のとおりとし
ます。
CREATE TABLE
(column_l
,column_2
,column_3
dec22
INTEGER
INTEGER
DECIMAL(22,2) );
例: CASE 式の失敗
次の文では、column_2 で値 1 が検出されて column_3 で値
11223344556677889900.12 が検出されたときに、CASE 式は失敗します。結果の
DECIMAL 値では、39 桁以上の精度が必要だからです。
SELECT SUM (CASE
WHEN column_2=1
THEN column_3 * 6.112233445566778800000
ELSE column_3
506
SQL 関数、演算子、式および述部
第 12 章 CASE 式
CASE 式結果タイプの規則
END )
FROM dec22;
例: 乗数の小数部桁数の短縮
次の問合わせは、THEN 式の乗数の小数部桁数を小さくして、「例: CASE 式の失敗」
の問題点を修正したものです。
SELECT SUM (CASE
WHEN column_2=1
THEN column_3 * 6.1122334455667788
ELSE column_3
END )
FROM dec22;
例: DECIMAL(38,2)の結果を返す
次の問合わせでは、THEN/ELSE 句に DECIMAL 値が含まれているため、CASE 式か
ら DECIMAL(38,2)の結果が返されます。
SELECT SUM (CASE
WHEN column_2=1
THEN column_3 * 6
ELSE column_3
END )
FROM dec22;
CASE 式における文字および数値データの例
以下は、数値および文字データから成る THEN/ELSE 句を使用する CASE 式を含む
問合わせの動作を示す例です。
CASE 式における文字および数値データの例: 例 1
次の問合わせでは、THEN/ELSE 句に FLOAT 値と VARCHAR 値が含まれている CASE
式から VARCHAR の結果が戻されます。FLOAT のデフォルト書式が 30 文字未満の
文字列であり、USER が VARCHAR(30) CHARACTER SET UNICODE として設定され
ているため、結果の長さは 30 になります。USER が UNICODE であるため、結果は
CHARACTER SET UNICODE となります。
SELECT a, CASE
WHEN a=1
THEN TIME
ELSE USER
END
FROM table_1
ORDER BY 1;
SQL 関数、演算子、式および述部
507
第 12 章 CASE 式
CASE 式の書式
CASE 式における文字および数値データの例: 例 2
この例では、以下のテーブル定義があるものとします。
CREATE table_1
(i
INTEGER,
column_l CHARACTER(10)
column_u CHARACTER(10)
column_j CHARACTER(10)
column_g CHARACTER(10)
column_k CHARACTER(10)
CHARACTER
CHARACTER
CHARACTER
CHARACTER
CHARACTER
SET
SET
SET
SET
SET
LATIN,
UNICODE,
KANJISJIS,
GRAPHIC,
KANJI1);
次の問合わせは、サーバー文字セットが GRAPHIC であるため(文字タイプを持つ最
初の THEN のサーバー文字セットが GRAPHIC であるため)に失敗します。
SELECT i, CASE
WHEN
WHEN
WHEN
WHEN
WHEN
ELSE
END
FROM table_1
ORDER BY 1;
i=1
i=2
i=3
i=4
i=5
10
THEN
THEN
THEN
THEN
THEN
4
column_g
5
column_l
column_k
関連トピック
詳細は、以下を参照してください。
• 2 項算術演算子の結果のデータ タイプ
CASE 式の書式
デフォルトの書式
CASE 式の結果は、結果のデータ タイプのデフォルトの書式で表示されます。CASE
式の結果は、THEN/ELSE 式で示される列について定義される明示的な書式には適用
されません。
次のテーブル定義を考えます。
CREATE TABLE duration
(i INTEGER
508
SQL 関数、演算子、式および述部
第 12 章 CASE 式
CASE と NULL
,start_date DATE FORMAT 'EEEEBMMMBDD,BYYYY'
,end_date DATE FORMAT 'DDBM3BY4' );
DATE データ タイプのデフォルト書式が YY/MM/DD であると仮定します。
以下の問合わせは、start_date や end_date 列に定義される書式ではなく、YY/MM/
DD のデフォルトの DATE フォーマットで CASE 式の結果を表示します。
SELECT i, CASE
WHEN
THEN
WHEN
THEN
END
FROM duration
ORDER BY 1;
i=1
start_date
i=2
end_date
明示的なタイプ変換を使った書式の変更
CASE 式の結果の書式を修正するには、CAST を使用して FORMAT 句を指定します。
以下に、上記の問合わせで CAST を使って CASE 式の結果の書式を変更する例を示
します。
SELECT i, ( CAST ((CASE
WHEN i=1
THEN start_date
WHEN i=2
THEN end_date
END) AS DATE FORMAT 'M4BDD,BYYYY'))
FROM duration
ORDER BY 1;
デフォルトのデータ タイプの書式と FORMAT 句について、詳細は< SQL データ型
とリテラル、B035-1143>を参照してください。
詳細情報
参照先
デフォルトのデータ型フォーマットと
FORMAT 出力句
SQL データ型とリテラル、B035-1143。
Teradata 変換構文を使用した、データ型
フォーマットの変換
明示的なデータ型の変換における Teradata 変
換構文
CASE と NULL
ANSI SQL:2011 規格では、CASE 式および関連する式の COALESCE と NULLIF は、
NULL を戻す能力を持つと指定されています。
SQL 関数、演算子、式および述部
509
第 12 章 CASE 式
CASE と NULL
NULL と CASE 式
CASE、NULLIF、および COALESCE 式における null 使用の規則は、次のとおりです。
• ELSE 句が CASE 式で指定されていない場合、評価がすべての WHEN 句を通過す
ると、結果は null になります。
• null と null を含む式は、値形式の CASE 式内の value_expression_1 として有効で
す。
次の例は有効です。
SELECT CASE NULL
WHEN 10
THEN 'TEN'
END;
SELECT CASE NULL + 1
WHEN 10
THEN 'TEN'
END;
上記の例では ELSE 句が指定されていないので、どちらの例も NULL を戻します。
また、NULL はどの値ともまたは NULL とも等しくないので、評価は WHEN にな
ります。
• 任意の値または NULL に対して NULL を比較すると、常に FALSE になります。
NULL に関するテストでは、WHEN 条件内で IS NULL または IS NOT NULL を使
用する検索形式の CASE 式を使うのが最善です。
次の例は有効です。
SELECT CASE
WHEN column_1 IS NULL
THEN 'NULL'
END
FROM table_1;
多くの場合 Teradata Database は、常に NULL と評価される式が他の式または
NULL と比較された場合にそれを検出できるので、エラーを示して、IS NULL ま
たは IS NOT NULL の使用を推奨します。ANSI SQL では、これをエラーとは判断
しませんが、ユーザーがこの方法での NULL の比較を意図することはほとんどな
いため、Teradata Database ではエラーがレポートされることに注意してください。
次の例は無効です。
SELECT CASE column_1
WHEN NULL
THEN 'NULL'
END
510
SQL 関数、演算子、式および述部
第 12 章 CASE 式
COALESCE 式
FROM table_1;
SELECT CASE column_1
WHEN NULL + 1
THEN 'NULL'
END
FROM table_1;
SELECT CASE
WHEN column_1 = NULL
THEN 'NULL'
END
FROM table_1;
SELECT CASE
WHEN column_1 = NULL + 1
THEN 'NULL'
END
FROM table_1;
• null および null を含む式は、THEN 句の式として有効です。
次の例は有効です。
SELECT CASE
WHEN column_1 = 10
THEN NULL
END
FROM table_1
上記の例とは異なり、この THEN 句内の NULL は SQL キーワードであり文字リ
テラルの値ではないことに注意してください。
CASE 簡略形
また ANSI では、特に null を処理するために CASE の特別な簡略式が 2 つ定義され
ています。
• COALESCE 式(「COALESCE 式」を参照)
• NULLIF 式(「NULLIF 式」を参照)
COALESCE 式
目的
すべての引数が null であれば NULL を戻し、そうでなければ、scalar_expression リ
スト内の非 null の最初の引数の値を戻します。
COALESCE は、以下の完全 CASE 式の簡略式になります。
SQL 関数、演算子、式および述部
511
第 12 章 CASE 式
COALESCE 式
CASE
WHEN
THEN
...
WHEN
THEN
ELSE
END
scalar_expression_1 IS NOT NULL
scalar_expression_1
scalar_expression_n IS NOT NULL
scalar_expression_n
NULL
構文
,
COALESCE
(
2
scalar_expression_n
)
構文要素
scalar_expression_n
引数リスト。
それぞれの COALESCE 関数には少なくとも 2 つのオペランドが必要です。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
使用上の注意
引数リスト内の scalar_expression_n は、1 回めは検索条件として、2 回めはその検
索条件の戻り値として、2 回評価されることがあります。
RANDOM のような非確定的な関数を scalar_expression_n 内で使用すると、予期し
ない結果になる可能性があります。それは、scalar_expression_n の最初の計算が
NULL でない場合に、その scalar_expression_n(これは COALESCE 式の値として戻さ
れます)の 2 番目の計算が NULL になることがあるからです。
スカラー subquery は、COALESCE 式で使用できます。ただし、非スカラーの
subquery(複数の行を返す subquery)を使用すると、実行時エラーが返されます。
デフォルト タイトル
COALESCE 式のデフォルト タイトルは、次のようになります。
<CASE expression>
512
SQL 関数、演算子、式および述部
第 12 章 CASE 式
COALESCE 式
COALESCE 式におけるデータ タイプに対する制限事項
以下の制限事項が、COALESCE 式中の CLOB、BLOB、および UDT タイプに対して
適用されます。
データ タ 制約事項
イプ
BLOB
引数リストの中で BLOB を使えるのは、これが BYTE または VARBYTE にキャス
トされる場合だけです。
CLOB
引数リストの中で CLOB を使えるのは、これが CHAR または VARCHAR にキャ
ストされる場合だけです。
UDT
複数の UDT を引数リストの中で使用できるのは、それらが同一タイプの場合だ
けです。これは、Teradata Database が COALESCE 式内の UDT に対して暗黙タ
イプ変換を行なわないためです。
例
例: 電話番号の問合わせ
次の例は、指定された各人の自宅の電話番号(存在する場合)、または事務所の電話
番号(HomePhone が null の場合)、または MessageService (MessageService が存在
して、自宅および事務所の電話番号が null の場合)を戻します。3 つのすべての値が
null の場合には、NULL を戻します。
SELECT Name, COALESCE (HomePhone, OfficePhone, MessageService)
FROM PhoneDir;
例: COALESCE と算術演算子の使用
以下の例は、算術演算子とともに COALESCE を使用しています。
SELECT COALESCE(Boxes,0) * 100
FROM Shipments;
例: COALESCE と比較演算子の使用
以下の例は、比較演算子とともに COALESCE を使用しています。
SELECT Name
FROM Directory
WHERE Organization <> COALESCE (Level1, Level2, Level3);
関連トピック
詳細は、以下を参照してください。
SQL 関数、演算子、式および述部
513
第 12 章 CASE 式
NULLIF 式
• 評価のルールや結果のデータ型など、その他の詳細については、「CASE」を参照
してください。
NULLIF 式
目的
引数どうしが等しい場合に NULL を戻し、そうでなければ、最初の引数
scalar_expression_1 を戻します。
NULLIF は、以下の完全 CASE 式の簡略式になります。
CASE
WHEN scalar_expression_1=scalar_expression_2
THEN NULL
ELSE scalar_expression_1
END
構文
NULLIF
(
scalar_expression1, scalar_expression2
)
構文要素
scalar_expression_1
上記の「目的」に示されている拡張 CASE 式の左側のスカラー式。
scalar_expression_2
上記の「目的」に示されている拡張 CASE 式の右側のスカラー式。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
使用上の注意
scalar_expression_1 引数は、1 回めは検索条件の一部として(前述の拡張 CASE 式を
参照)、2 回めは ELSE 句の戻り値として、2 回評価されることがあります。
RANDOM のような非確定的な関数を使用した場合に、scalar_expression_1 の最初
の計算が scalar_expression_2 に等しくならないと、予期しない結果になることがあ
ります。この計算では、CASE 式の結果は、scalar_expression_1 の 2 番目の計算の
値(これは scalar_expression_2 になる可能性があります)になります。
514
SQL 関数、演算子、式および述部
第 12 章 CASE 式
NULLIF 式
スカラー subquery は、NULLIF 式で使用できます。ただし、非スカラーの
subquery(複数の行を返す subquery)を使用すると、実行時エラーが返されます。
デフォルト タイトル
NULLIF 式のデフォルト タイトルは、次のようになります。
<CASE expression>
NULLIF 式におけるデータ タイプに対する制限事項
以下の制限事項が、NULLIF 式中の CLOB、BLOB、および UDT タイプに対して適用
されます。
データ タ 制約事項
イプ
BLOB
引数リストの中で BLOB を使えるのは、これが BYTE または VARBYTE にキャス
トされる場合だけです。
CLOB
引数リストの中で CLOB を使えるのは、これが CHAR または VARCHAR にキャ
ストされる場合だけです。
UDT
複数の UDT を引数リストで使用できるのは、それらが同一タイプであって、並
べ替え定義を持っている場合だけです。
例
以下の例は、次の表に対する問合わせを示しています。
CREATE TABLE Membership
(FullName CHARACTER(39)
,Age SMALLINT
,Code CHARACTER(4) );
例: ANSI 準拠の形式での問合わせ
これは、Teradata SQL の NULLIFZERO(Age)関数の ANSI 準拠の形式であり、さらに
用途の広い形式です。
SELECT FullName, NULLIF (Age,0) FROM Membership;
例: 空白
次の問合わせでのブランクは、値がないことを示します。
SELECT FullName, NULLIF (Code, '
') FROM Membership;
例: 式内で算術演算子とともに使用される NULLIF の問合わせ
以下の例は、式内で算術演算子とともに NULLIF を使用しています。
SQL 関数、演算子、式および述部
515
第 12 章 CASE 式
NULLIF 式
SELECT NULLIF(Age,0) * 100;
関連トピック
詳細は、以下を参照してください。
• 評価のルールや結果のデータ型など、その他の詳細については、「CASE」を参照
してください。
516
SQL 関数、演算子、式および述部
第 13 章
データ型の変換
概要
この章では、SQL CAST 関数について説明し、データ タイプの明示的および暗黙的
な変換に関わるさまざまな規則を取り上げます。
データ タイプの変換は、式のデータ定義(データ タイプ、データ属性、または両方)
を変更します。データ タイプの変換は、明示的または暗黙的に実行することができ
ます。明示的な変換は、CAST 関数または Teradata 変換構文を使用して行なうこと
ができます。
関連トピック
詳細は、以下を参照してください。
• データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
データ タイプ変換の書式
Teradata Database は、以下の形式のデータ変換をサポートしています。
• 暗黙的
• CAST 関数を使用した明示的な変換
• Teradata 変換構文を使用した明示的な変換
暗黙的な型の変換
Teradata Database では、明示的に変換する型を必要とせずに、いくつかの型の割り
当ておよび比較を行なうことができます。Teradata Database は、次の項目に対して
も暗黙の型変換を実行します。
• マクロ、ストアド プロシージャ、および SQRT などの SQL 関数に渡される一部
の引数のタイプ。
• タイムゾーン変位を定義する AT 句内の式。詳細については、「AT LOCAL およ
び AT TIME ZONE タイムゾーン指定子」を参照してください。
SQL 関数、演算子、式および述部
517
第 13 章 データ型の変換
暗黙的な型の変換
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
例
例: 割り当て時に行なわれる暗黙的な型変換
次の表を考えます。
CREATE TABLE T1
(Fname VARCHAR(25)
,Fid
INTEGER
,Yrs
CHARACTER(2));
CREATE TABLE T2
(Wname VARCHAR(25)
,Wid
INTEGER
,Age
SMALLINT);
次の文では、Teradata Database によって T1.Yrs 内の文字列が暗黙的に数値に変換
されます。
UPDATE T2 SET Age = T1.Yrs + 5;
このことは、ソース文の構文では明確ではありませんが、テーブル T1 および T2 の
ディクショナリ情報がアクセスされたときに明確になります 。
例: 比較時に行なわれる暗黙的な型変換
「割り当て時に行なわれる暗黙的な型変換」のテーブル T1 を考慮してください。
次の文では、Teradata Database により、比較操作の両方のオペランドが暗黙的に
FLOAT 値に変換されてから、比較が実行されます。
SELECT Fname, Fid
FROM T1
WHERE T1.Yrs < 55;
例: パラメータ引き渡し操作での暗黙の型変換
引数の平方根を計算する SQRT システム関数について考えます 。
次の文では、Teradata Database によって文字列の引数が暗黙的に FLOAT 型に変換
されます。
SELECT SQRT('13147688');
サポートされるデータ タイプ
Teradata Database は、以下の型の暗黙的な変換を実行します。
518
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
暗黙的な型の変換
バイトから次へ:
• バイト
バイト タイプには、BYTE、VARBYTE、および BLOB が含まれます。
• UDT
事前定義タイプを UDT にキャストする暗黙 CAST が UDT になければなりませ
ん。UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。CREATE CAST の詳細については、<SQL データ
定義言語>を参照してください。
数値から次へ:
•
•
•
•
数値
DATE
文字
UDT
事前定義タイプを UDT にキャストする暗黙 CAST が UDT になければなりませ
ん。UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。CREATE CAST の詳細については、<SQL データ
定義言語>を参照してください。
DATE から次へ:
•
•
•
•
数値
DATE
文字
UDT
事前定義タイプを UDT にキャストする暗黙 CAST が UDT になければなりませ
ん。UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。CREATE CAST の詳細については、<SQL データ
定義言語>を参照してください。
文字から次へ:
• 数値
• DATE
• 文字
文字タイプには、CHAR、VARCHAR、および CLOB が含まれます。
• 期間
• TIME
• TIMESTAMP
• UDT
事前定義タイプを UDT にキャストする暗黙 CAST が UDT になければなりませ
ん。UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。CREATE CAST の詳細については、<SQL データ
定義言語>を参照してください。
TIME から次へ:
SQL 関数、演算子、式および述部
519
第 13 章 データ型の変換
暗黙的な型の変換
• UDT
事前定義タイプを UDT にキャストする暗黙 CAST が UDT になければなりません。
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。CREATE CAST の詳細については、<SQL データ定
義言語>を参照してください。
TIMESTAMP から次へ:
• UDT
事前定義タイプを UDT にキャストする暗黙 CAST が UDT になければなりません。
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。CREATE CAST の詳細については、<SQL データ定
義言語>を参照してください。
INTERVAL から次へ:
• UDT
事前定義タイプを UDT にキャストする暗黙 CAST が UDT になければなりません。
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。CREATE CAST の詳細については、<SQL データ定
義言語>を参照してください。
UDT から:
• UDT に対して定義されている暗黙 CAST の変換先である事前定義データ型
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。CREATE CAST の詳細については、<SQL データ定
義言語>を参照してください。
• UDT に対して定義されている暗黙 CAST のターゲットである別の UDT
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。CREATE CAST の詳細については、<SQL データ定
義言語>を参照してください。
データ タイプの詳細は、< SQL データ型とリテラル、B035-1143>を参照してくだ
さい。
日時タイプの暗黙的変換
Teradata Database は、以下の場合に DateTime データ型の暗黙的変換を実行します。
• 動的パラメータ マーカー、または疑問符(?)プレースホルダーを使用してデータを
渡すとき。
• INSERT、INSERT...SELECT、および UPDATE 文を使用する場合。
• MERGE INTO 文を使用する場合。
• CREATE/ALTER TABLE 文のデフォルト値を処理するとき。詳細については、<
SQL データ型とリテラル、B035-1143>の「DEFAULT 句」を参照してください。
• DECLARE、SELECT...INTO、および SET 文の実行など、ストアド プロシージャの
実行中。<SQL ストアード プロシージャと埋め込み SQL、B035-1148>参照して
ください。
520
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
暗黙的な型の変換
暗黙の変換はクライアント側のサポートによって異なります。DateTime 型の暗黙の
変換をサポートするクライアント製品について、詳細は Teradata Tools and Utilities
ユーザー マニュアルを参照してください。
以下の変換をサポートします。
詳細についての参照先
FROM...
TO...
DATE
TIMESTAMP
「DATE から TIMESTAMP への暗黙的変換」。
TIME
TIMESTAMP
「TIME から TIMESTAMP への暗黙的変換」。
TIMESTAMP
DATE
「TIMESTAMP から DATE への暗黙的変換」。
TIMESTAMP
TIME
「TIMESTAMP から TIME への暗黙的変換」。
INTERVAL
INTERVAL
「INTERVAL から INTERVAL への暗黙的変換」。
Teradata Database は次の場合、代入時に DateTime データ型に対して暗黙的変換を
実行します。
詳細についての参照先
FROM...
TO...
DATE
TIMESTAMP
「DATE から TIMESTAMP への暗黙的変換」。
TIME
TIMESTAMP
「TIME から TIMESTAMP への暗黙的変換」。
TIMESTAMP
DATE
「TIMESTAMP から DATE への暗黙的変換」。
TIMESTAMP
TIME
「TIMESTAMP から TIME への暗黙的変換」。
間隔
絶対数値
INTERVAL タイプはフィールドが 1 つだけ必要です
(たとえば、INTERVAL YEAR)。
「INTERVAL から数値への暗黙的変換」。
絶対数値
間隔
INTERVAL タイプはフィールドが 1 つだけ必要です
(たとえば、INTERVAL YEAR)。
「数値から INTERVAL への暗黙的変換」。
注: 数値から INTERVAL 型への変換には全般的な制限があります。INTERVAL 型に
は日時フィールドが 1 つだけ必要になります。ただし、この制限は、AT 句の式を
暗黙的に変換する際には問題になりません。その理由は、この変換が 2 つの CAST
文を使用して実行されるためです。詳細については、「AT LOCAL および AT TIME
ZONE タイムゾーン指定子」を参照してください。
詳細は、「ANSI の日時および間隔データ型の割り当て規則」を参照してください。
Teradata Database は次の場合、単一テーブル述部と結合述部で DateTime データ型
に対して暗黙的変換を実行します。
FROM...
TO...
TIMESTAMP
DATE
SQL 関数、演算子、式および述部
詳細についての参照先
「TIMESTAMP から DATE への暗黙的変換」。
521
第 13 章 データ型の変換
暗黙的な型の変換
FROM...
TO...
詳細についての参照先
間隔
絶対数値
INTERVAL タイプはフィールドが 1 つだけ必要です
(たとえば、INTERVAL YEAR)。
「INTERVAL から数値への暗黙的変換」。
絶対数値
Interval
「数値から INTERVAL への暗黙的変換」。
詳細は、「比較オペランドの暗黙の型変換」を参照してください。
以下の変換はサポートしません。
• 比較では、TIME から TIMESTAMP へ、また TIMESTAMP から TIME への暗黙的
な変換はサポートしません。
• 集合操作での日時タイプの暗黙的な変換。
データ タイプの詳細は、< SQL データ型とリテラル、B035-1143>を参照してくだ
さい。
暗黙的な変換の規則
Teradata SQL は、何らかの操作が実行される前に、式に対して暗黙的な型の変換を
行ないます。
変換時の切り捨て
暗黙的な変換の結果として、エラーなしで値が切り捨てられることがあります。
推奨事項: ベスト プラクティスとして、暗黙的な変換に頼らず、可能なときには明示
的な CAST を使用してください。
例: Teradata 変換構文を使用した、CHAR への変換
次のテーブル定義を考えます。
CREATE TABLE Test1 (c1 INT, c2 VARCHAR(1));
以下の 2 つの INSERT 文はエラーなしで完了します。
INSERT INTO Test1 VALUES (1, '1');
INSERT INTO Test1 VALUES (2, 2);
この問合わせは 2 行を返します。
SELECT * FROM Test1;
c1
c2
------------1
1
2
<<<< Note that the value inserted in c2 is a blank
522
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
暗黙的な型の変換
2 番目の INSERT 文では、数値の 2 が Teradata 変換構文を使用して(つまり CAST を
使用しないで)、暗黙的に CHAR に変換されています。処理は、以下のようになりま
す。
1 数値のデフォルトまたは指定された FORMAT を使用して数値を文字列に変換し
ます。前後の埋め込み文字は、切り捨てられません。
2 必要であれば、埋め込み文字で右側に拡張するか右側から切り捨てて、変換先
の長さ指定に適合させます。
非埋め込み文字が切り捨てられた場合には、文字列切り捨てエラーは報告されません。
この変換では数字を右寄せにしますが、結果の先頭バイトに 1 つの空白文字が入り
ます。数値から文字への変換については、「数値から文字への変換」を参照してく
ださい。
制約事項
Teradata Database は、UDF、UDM、または外部ストアド プロシージャ(外部ルーチ
ン)への入力引数の暗黙変換は実行しません。引数は、パラメータ タイプと完全に
一致する必要はありませんが、互換性がなければなりません。たとえば、INTEGER
引数が期待される外部ルーチンに SMALLINT 引数を渡すことができます。これは、
SMALLINT と INTEGER に互換性があるからです。DATE タイプの引数を、INTEGER
引数が期待される外部ルーチンに渡すには、DATE タイプを明示的に INTEGER タイ
プにキャストする必要があります。詳細は、<SQL 外部ルーチン プログラミング、
B035-1147>を参照してください。
一部の SQL 関数および演算子では、パラメータ タイプと完全に一致する引数が必
要とされます。詳細は、該当する関数または演算子の資料を参照してください。
関連トピック
詳細については、以下を参照してください。
•
•
•
•
•
•
•
•
•
•
•
•
バイト変換
数値から数値への変換
数値から DATE への変換
数値から文字への変換
数値から UDT への変換
DATE から数値への変換
DATE から DATE への変換
DATE から文字への変換
DATE から UDT への変換
文字から数値への変換
文字から DATE への変換
文字から文字への変換
SQL 関数、演算子、式および述部
523
第 13 章 データ型の変換
明示的なデータ型の変換における CAST
•
•
•
•
•
•
•
•
•
•
•
•
•
•
•
文字から Period への変換
文字から TIME への変換
文字から TIMESTAMP への変換
文字から UDT への変換
TIME から UDT への変換
TIMESTAMP から UDT への変換
INTERVAL から UDT への変換
UDT から文字への変換
UDT から DATE への変換
UDT から INTERVAL への変換
UDT から数値への変換
UDT から TIME への変換
UDT から TIMESTAMP への変換
UDT から UDT への変換
比較操作でのオペランドの暗黙タイプ変換の詳細については、比較オペランドの
暗黙的なタイプ変換を参照してください。
明示的なデータ型の変換における CAST
目的
所定のデータ タイプの式を、異なるデータ タイプまたは異なる属性の同じデータ タ
イプに変換します。
Teradata SQL は、CAST 関数用に 2 種類の構文をサポートしていますが、そのうち
の 1 つだけが ANSI SQL:2011 に準拠しています。
構文
CAST
( expression
AS
ansi_sql_data_type
)
data_definition_list
構文要素
expression
異なるデータ型としてキャストされる、データ型が既知の式。
ansi_sql_data_type
式の新しいデータ型。
data_definition_list
式の新しいデータ型またはデータ属性、あるいはその両方。
524
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
明示的なデータ型の変換における CAST
ANSI への準拠
この文は、ANSI SQL:2011 に準拠していますが、非 ANSI の Teradata Database 拡
張機能が含まれています。
使用上の注意
ANSI SQL:2011 準拠の形式は、データ型を ANSI 準拠 SQL 文または Teradata SQL
文のいずれかに変換するために使用できます。
Teradata の拡張構文はより一般的なものであり、タイプの宣言またはデータ属性、
あるいはその両方が可能です。データ型および属性の詳細は、< SQL データ型とリ
テラル、B035-1143>を参照してください。
CAST の拡張形式は、ANSI 準拠の移植可能なアプリケーションでは使用を避けてく
ださい。
CAST 関数は、ANSI モードでも Teradata モードでも同じように機能します。
日時データ型を変換するときには、CAST に使用するタイムゾーンを指定するため
に、AT 句を使用してください。ソース タイムゾーン、特定のタイムゾーン変位、
または現在のセッションのタイムゾーンを指定できるようになります。詳細は、具
体的なデータ型の変換についての節(例えば、「TIMESTAMP から DATE への変換」)
を参照してください。
CAST は、次のデータ タイプ ペアを変換しません。
• サーバー文字セットが GRAPHIC に設定されている場合の、数値から文字。
• サーバー文字セットが異なる文字式。
このような変換を実行するには、TRANSLATE 関数を使用してください
(「TRANSLATE」を参照)。
• バイト(BYTE、VARBYTE、および BLOB) から UDT またはバイト以外の任意の
データ タイプへ、およびバイトまたは UDT 以外のデータ タイプからバイトへ。
• CLOB から UDT または文字以外の任意のデータ タイプへ、および文字または UDT
以外のデータ タイプから CLOB へ。
地理空間タイプへのキャスト、および地理空間タイプからのキャストについては、
<SQL 地理空間タイプ、B035-1181>を参照してください。
UDT の関与するデータ型の変換には、その UDT に適した CAST 定義が必要です。
UDT の CAST を定義するには、CREATE CAST 文を使用します。
文字切り捨て規則
次の規則が文字列に適用されます。
SQL 関数、演算子、式および述部
525
第 13 章 データ型の変換
明示的なデータ型の変換における CAST
CAST する文字列のモード
切り捨てられる部分
ANSI
末尾の埋め込み文字スペース(必要な長さになるまで)。そ
の他の文字やマルチバイト文字の一部が切り捨てられる
と、エラーが戻されます。
TERADATA
末尾の文字(必要な長さになるまで)。
マルチバイト文字が含まれる Kanji1 文字データ タイプが
切り捨てられると、マルチバイト文字の 1 バイトが切り捨
てられることがあります。
サーバー文字セットの規則
data_definition_list で、データ型 CHARACTER (CHAR)または CHARACTER VARYING
(VARCHAR)を指定し、使用するサーバー文字セットを示すために CHARACTER SET
句を指定していない場合、その結果のサーバー文字セットは以下のようになります。
expression のデータ型
結果のサーバー文字セット
non-character
ユーザー デフォルトのサーバー文字セット。
文字
expression のサーバー文字セット。
数値の桁あふれ、フィールド モード、および CAST
数値の桁あふれは、実行しているモードが ANSI か Teradata かによって、および
フィールド モードかどうかによって、異なった方法で処理されます。
フィールド モードは ANSI SQL:2011 との互換性はありません。フィールド モード
で数値または小数データ タイプが数値の桁あふれを起こすと、エラー メッセージで
はなくアスタリスク('***')が戻されます。
レコードおよび標識モードでは、この動作は行なわれずに、エラー メッセージが戻
されます。
関連トピック
個々のデータ タイプどうしの間の変換(数値から数値、文字から数値など)に適用さ
れる規則の詳細は、この章の後半にある該当するトピックを参照してください。
CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>を
参照してください。
例
次の例は、CAST を使用してデータ型の変換を実行する方法を示します。
526
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
フィールド モードでのデータ変換
例 1: データ型の変換の実行
ANSI CAST の構文を使用した例は、次のとおりです。
SELECT ID_Col, Name_Col
FROM T1
WHERE Int_Col = CAST(SUBSTRING(Char_Col FROM 3 FOR 3) AS INTEGER);
例 2: ANSI CAST 構文を使った、データ型の変換の実行
ANSI CAST の構文を使用した例は、次のとおりです。
SELECT CAST(SUBSTRING(Char_Col FROM 1 FOR 2) AS INTEGER),
CAST(SUBSTRING (Char_Col FROM 3 FOR 3) AS INTEGER)
FROM T1;
例 3: ANSI CAST 構文に対する Teradata 拡張機能を使った、データ型の変換の実行
ANSI CAST 構文に対する Teradata 拡張機能を使用した例は、次のとおりです。
CREATE TABLE t2 (f1 TIME(0) FORMAT 'HHhMIm');
INSERT t2 (CAST('15h33m' AS TIME(0) FORMAT 'HHhMIm'));
SELECT f1 FROM t2;
この SELECT 文の結果は、次のとおりです。
f1
-----15h33m
フィールド モードでのデータ変換
フィールド モード:ユーザー応答データ
BTEQ で使用されるレポート書式であるフィールド モードでは、すべてのデータは、
文字形式で戻されます。列の位置合わせおよびスペーシングは、データ書式および
タイトル情報によって制御されます。戻された各行は、本質的には表示可能な文字
列です。
フィールド モードでは、明示的に数値データを文字書式に変換する必要はありませ
ん。
数値タイプへの変換
フィールド モードの場合、文字から数値へのデータ タイプ変換に対して戻される
数値桁あふれは、エラーとして扱われません。数値データ タイプ用に予約されてい
SQL 関数、演算子、式および述部
527
第 13 章 データ型の変換
バイト変換
る通常の桁数を結果が超えた場合、その結果はレポートでは一連のアスタリスクで
示されます。
たとえば、以下の文での文字から SMALLINT への変換は、SMALLINT 用に予約され
ている桁数は通常は 5 桁なので、結果として数値桁あふれになります。
SELECT '100000' (SMALLINT);
結果は以下のようになります。
'100000'
-------******
さらに、フィールド モードの場合、指定した出力書式に適合しない結果が含まれる
数値タイプへの変換の場合も、レポート内にアスタリスクで示されます。
たとえば、以下の文での DATE から INTEGER への変換は、結果として FORMAT 句
で指定した書式に適合しない値となります。
SELECT CAST (CURRENT_DATE as integer format '9999');
結果は以下のようになります。
Date
---****
レコードまたは標識変数モードで実行された同じ問合わせは、エラーを報告します。
バイト変換
目的
バイト表現を別のデータ定義に変換します。
CAST 構文
CAST
( byte_expression
AS
byte_data_type
(
UDT_data_type
data_attribute
data_attribute
構文要素
byte_expression
別のデータ定義にキャストされるバイト形式の式。
528
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
バイト変換
byte_data_type
byte_expression の変換先の新しいバイト型。
UDT_data_type
バイト タイプを UDT にキャストする CAST 定義を持つ UDT。
UDT の CAST を定義するには、CREATE CAST 文を使用します。CREATE CAST の詳
細は、<SQL データ定義言語 - 構文規則および例、B035-1144>を参照してください。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
構文がデータ属性を指定しない場合、CAST は ANSI SQL:2011 に準拠します。
Teradata 変換構文
byte_expression
(
byte_data_type
)
, data_attribute
,
data_attribute
, byte_data_type
, data_attribute
構文要素
byte_expression
別のデータ定義にキャストされるバイト形式の式。
byte_data_type
byte_expression の変換先の新しいバイト型。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
SQL 関数、演算子、式および述部
529
第 13 章 データ型の変換
バイト変換
変換元と変換先のタイプの長さが異なる場合の変換
byte_data_type で指定した長さが byte_expression の長さよりも短い場合、指定し
た長さを超えるバイトは切り捨てられます。エラーは報告されません。
byte_data_type が固定長であり、その長さが byte_expression よりも長い場合、2 進
数でゼロの値のバイトが、必要に応じて付加されます。
サポートされる変換元と変換先のデータ タイプ
Teradata Database は、以下の表に従ってバイト データ型の変換をサポートします。
変換元データ タ
イプ
変換先データ タ
イプ
使用できる変換
BYTE
• BYTE
• 暗黙的
• VARBYTE
• BLOB
• CAST および Teradata 変換構文を使用した明示的
な変換
UDT
• 暗黙的
VARBYTE
BLOB
BYTE
• CAST を使用した明示的変換
VARBYTE
BLOB
UDT
• BYTE
• 暗黙的
• VARBYTE
• CAST および Teradata 変換構文を使用した明示的
な変換
• BLOB
UDT の関与するデータ タイプの変換には、その UDT
に適した CAST 定義が必要です。UDT の CAST を定
義するには、CREATE CAST 文を使用します。
CREATE CAST の詳細は、<SQL データ定義言語 - 構
文規則および例、B035-1144>を参照してください。
バイトから UDT への暗黙変換に関する規則
Teradata Database は、以下の操作に対してバイトから UDT への暗黙的変換を実行
します。
• UPDATE
• INSERT
• ストアド プロシージャ、外部ストアド プロシージャ、UDF、および UDM への引
数の引渡し。
• このマニュアル中の他の箇所に明記されている特定のシステム演算子と関数 (DBS
制御レコードの DisableUDTImplCastForSysFuncOp フィールドが TRUE に設定さ
れていない場合に限る)。
530
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
バイト変換
バイトから UDT への暗黙のデータ型変換を実行するには、以下を指定する CAST 定
義(「使用上の注意」を参照)が必要です。
• AS ASSIGNMENT 句
• BYTE、VARBYTE、または BLOB ソース データ タイプ
CAST 定義の変換元データ タイプは、暗黙タイプ変換の変換元と正確に一致して
いる必要はありません。
別々のバイト タイプから UDT への変換の場合に複数の暗黙 CAST 定義が存在する
場合、Teradata Database は優先順位の最も高いバイト タイプの暗黙 CAST 定義を
使用します。以下のリストでは、バイト タイプの優先順位が最低から最高の順に並
べられています。
• BYTE
• VARBYTE
• BLOB
HASHBUCKET を使用した BYTE タイプから INTEGER タイプへの変換
HASHBUCKET 関数を使用して、BYTE(1)または BYTE(2)タイプを INTEGER タイプ
に変換することができます。
例
例: BLOB から VARBYTE への明示的な変換
次のテーブル定義を考えます。
CREATE TABLE large_images
(id INTEGER
,image BLOB);
次の文では、BLOB の列を VARBYTE タイプにキャストし、結果を POSITION 関数
への引数として使用します。
SELECT POSITION('FFF1'xb IN (CAST(image AS VARBYTE(64000))))
FROM large_images
WHERE id = 5;
例: VARBYTE から BLOB への暗黙的な変換
次のテーブル定義を考えます。
CREATE TABLE small_images
(id INTEGER
,image1 VARBYTE(30000)
,image2 VARBYTE(30000));
CREATE TABLE large_images
SQL 関数、演算子、式および述部
531
第 13 章 データ型の変換
文字から文字への変換
(id INTEGER
,image BLOB);
次の INSERT 文の場合、Teradata Database によって VARBYTE から BLOB への暗黙
的な変換が実行されます。
INSERT large_images
SELECT id, image1 || image2
FROM small_images;
関連トピック
データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
文字から文字への変換
目的
変換後の文字列を短くするか、または長くします。
CAST 構文
CAST
( character_expression
AS
character_data_type
(
data_attribute
data_attribute
構文要素
character_expression
変換する文字式。
character_data_type
式が変換されるデータ型。
data_attribute
以下のデータ属性のいずれか 1 つ。
• 文字セット
• FORMAT
• NAMED
• TITLE
532
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
文字から文字への変換
ANSI への準拠
構文がデータ属性を指定しない場合、CAST は ANSI SQL:2011 に準拠しています。
CAST 構文の使用上の注意
character_expression のサーバー文字セットは、変換先データ型として同じサーバー
文字セットでなければなりません。
CAST を使用してデータを文字列に変換したときに、非埋め込み文字が切り捨てら
れた場合には、エラーが報告されます。
Teradata 変換構文
character_expression
(
character_data_type
)
, data_attribute
,
data_attribute
, character_data_type
, data_attribute
構文要素
character_expression
変換する文字式。
character_data_type
式が変換されるデータ型。
data_attribute
以下のデータ属性のいずれか 1 つ。
• 文字セット
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
SQL 関数、演算子、式および述部
533
第 13 章 データ型の変換
文字から文字への変換
Teradata 変換構文の使用上の注意
character_expression のサーバー文字セットは、data_attribute として指定された別
のサーバー文字セットに変更することができます。この場合の data_attribute は、
CHARACTER SET 句になります。
文字から文字への暗黙的な変換
CLOB タイプとの間で変換が可能なのは、CHAR または VARCHAR タイプだけです。
たとえば、CHAR または VARCHAR の列に CLOB データを挿入すると、暗黙のうち
に変換が実行されます。
文字列(固定長でも可変長でも)の比較では、等しい長さのオペランドが必要です。次
の表に、短い方の文字列が右側を空白で埋められて変換されることを示します。
式
変換後
結果
'x'='x '
'xΔ '='x '
TRUE
'x'='xx'
'xΔ '='xx'
FALSE
Δ は、埋め込み文字です。
文字が変換先の文字セットのレパートリーに含まれていない場合には、エラーが報
告されます。
全体の使用上の注意
変換元の文字列(CHAR、VARCHAR、または CLOB)が変換先のデータ タイプ(CHAR、
VARCHAR、または CLOB)よりも長い場合、超過した文字は切り捨てられます。
INSERT または UPDATE を実行するセッ テーブルに文字値を格納するために非埋め込み文
ションのモード
字が切り捨てられる場合の結果
ANSI
エラーが報告されます。
TERADATA
エラーは報告されません。
埋め込み文字の除去または追加は、次の規則に従って行なわれます。
変換元の文字列の
データ タイプ
状態
変換先データ タ
イプ
結果
CHAR
変換先よりも長い
CLOB または
VARCHAR
末尾の埋め込み文字は除去
されます。
CHAR
末尾に埋め込み文字が付加
されます。
CHAR、VARCHAR、 変換先よりも短い
または CLOB
534
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
文字から文字への暗黙変換
変換元の文字列の
データ タイプ
状態
変換先データ タ
イプ
CHAR
すべて埋め込み文字 CLOB または
VARCHAR
結果
フィールドは長さゼロに切
り捨てられます。
例: 文字から文字への変換
次に、文字から文字への変換の例を示します。
文字列
文字列の
長さ
文字の説明
変換の結果
変換される
長さ
'HELLO '
5
CHAR(3)
'HEL'、セッションが Teradata
モードの場合
3
エラー、セッションが ANSI モー
ドの場合
'HELLO '
5
CHAR(7)
'HELLO '
7
'HELLO '
5
VARCHAR(7)
'HELLO '
5
'HELLO '
7
VARCHAR(6)
'HELLO'
6
'HELLO '
7
VARCHAR(3)
'HEL'、セッションが Teradata
モードの場合
3
エラー、セッションが ANSI モー
ドの場合
関連トピック
詳細は、以下を参照してください。
• データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
• 文字変換におけるサーバー文字セットの効果の規則については、暗黙的な型の変
換を参照してください。
• TRANSLATE 関数を使用した変換の実行については、TRANSLATE を参照してく
ださい。
文字から文字への暗黙変換
所定の操作で 2 つの文字列に互換性がないときに、文字列が暗黙に変換されます。
たとえば、
SELECT *
FROM string_table
WHERE clatin < csjis;
SQL 関数、演算子、式および述部
535
第 13 章 データ型の変換
文字から文字への暗黙変換
clatin は CHARACTER SET LATIN として定義された文字の列を表わし、csjis は
CHARACTER SET KANJISJIS として定義された文字の列を表わします。
文字列'string’から UNICODE 文字列への暗黙の変換が必要な場合には、
TRANSLATE(string USING source_repertoire_name _TO_Unicode)関数を実行すれば
同じ結果が得られます。ここで source-repertoire-name は、「文字列」のサーバー
文字セットです。
さらに具体的に言えば、上記の例で「文字列」が KANJISJIS 型である場合に、
TRANSLATE(string USING KanjiSJIS_TO_Unicode)関数を実行すれば同じ結果が得ら
れます。
ANSI への準拠
これは、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
文字リテラル
文字リテラルが関係する文字から文字への暗黙的な変換には、以下の規則が適用さ
れます。
一方のオペラ
ンド
もう一方のオペラ
ンド
結果
リテラル
リテラル
両方のオペランドが UNICODE に変換されます。
非リテラル
リテラルは、非リテラルのタイプに変換されます。
その変換が失敗した場合には、両方とも UNICODE
に変換されます。
リテラル式
リテラルは、リテラル式のタイプに変換されます。
その変換が失敗した場合には、両方とも UNICODE
に変換されます。
リテラル式
両方のオペランドが UNICODE に変換されます。
非リテラル
リテラル式は、非リテラルのタイプに変換されま
す。その変換が失敗した場合には、両方とも
UNICODE に変換されます。
非リテラル
両方のオペランドが UNICODE に変換されます。
リテラル式
非リテラル
KANJISJIS サーバー文字セット
文字から文字への暗黙的な変換では、KANJISJIS サーバー文字セットをもつ文字列引
数は必ず UNICODE に変換されます。
536
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
文字から DATE への変換
式と関数引数の暗黙変換についての SQL の規則
次に、式と関数引数のタイプの暗黙変換についての規則を示します。
結果が文字タイプになる列関数の結果を次の表にまとめました。
関数
結果
TRIM
主要な文字列引数(最後の引数)のタイプに変換されます。
|| (連結)
変換されず、暗黙の変換後、引数の文字データ型になります。
他の列関数には変換が含まれておらず、結果のタイプは、引数のサーバー文字セッ
トではなく関数に基づいて決定されることに注意する必要があります。
例えば、次の TRIM 関数の場合、<unicode-literal>がまず LATIN に変換されてから、
除去操作が実行されます。
...
TRIM(<unicode-literal> FROM <latin-value>)
結果は、LATIN です。
文字から DATE への変換
目的
文字列を日付値に変換します。
CAST 構文
CAST
( character_expression
AS
DATE
)
data_attribute
構文要素
character_expression
変換する文字式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
SQL 関数、演算子、式および述部
537
第 13 章 データ型の変換
文字から DATE への変換
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI の拡張として、CAST では、日付データの代替書式化を可能にする FORMAT 句
などのデータ属性を使用することができます。
Teradata 変換構文
character_expression
(
DATE
data_attribute ,
)
, data_attribute
構文要素
character_expression
DATE 値にキャストされる文字表現。
data_attribute
以下の任意選択のデータ属性のうちの 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
文字から DATE への暗黙的な変換
文字列が有効な日付を表わしていない場合は、エラーが報告されます。
レコードまたは標識モードでは、セッションの DateForm モードが ANSIDate に設定
された場合、文字列は ANSI DATE 形式を使用する必要があります。
使用上の注意
文字式は、先行および後続の埋め込み文字が調整され、DATE 定数の宣言内の文字列
定数であるかのように処理されます。
文字から DATE への変換は、CHAR および VARCHAR タイプしかサポートされませ
ん。CLOB をソース文字タイプとすることはできません 。
有効な DATE に変換できる場合には、文字列は変換されます。そうでない場合には、
エラーが返されます。
538
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
文字から DATE への変換
文字列の書式
現在のセッションの日付形式が INTEGERDATE の場合、文字列での日付表記は、次
の表に示すルールに従って、DATE 出力書式と一致しなければなりません。
文
結果
DATE に
FORMAT 句を指
定する場合
文字列はその DATE 書式と一致しなければなりません。
FORMAT 句を指
定しない場合
DATE 列定義
FORMAT 句を指定する場合、文字列はその DATE 書式と一致しなければ
なりません。
FORMAT 句を指定しない場合、文字列は「YY/MM/DD」、またはデー
タ書式設定(SDF)ファイル内で指定の、デフォルトの日付書式の現行の設
定に一致しなければなりません。
例については、「例: IntegerDate 日付形式モード」を参照してください。
現行セッションの日付形式が ANSIDATE の場合、文字列での日付表記は、次の表に
示すルールに従って、DATE 出力書式と一致しなければなりません。
文
結果
DATE に FORMAT 句 文字列はその DATE 書式と一致しなければなりません。
を指定する場合
FORMAT 句を指定し フィールド モードでの DATE 列定義:
ない場合
• FORMAT 句を指定する場合、文字列はその DATE 書式と一致しな
ければなりません。
• FORMAT 句を指定しない場合、文字列は ANSI フォーマット
('YYYY-MM-DD')と一致する必要があります。
レコード モードまたは標識モードの場合、ANSI フォーマット('YYYYMM-DD')に合致する文字列。
文字から DATE への変換に対する CAST での FORMAT の強制
FORMAT 句を使用することで、ターゲットの DATE データ タイプの書式とマッチン
グしない文字列を変換することができます。FORMAT 句を指定しない変換の場合、
文字列には DATE データ タイプの出力書式が使用されます。
たとえば、セッションの日付形式が INTEGERDATE で、tdlocaledef ユーティリティ
によってシステムのデフォルトの DATE 書式が 'yyyymmdd' に設定されているとし
ます。次の文では文字列の中に分離文字があり、これはデフォルトの DATE 書式と
一致しないため、失敗します。
SELECT CAST ('2005-01-01' AS DATE);
SQL 関数、演算子、式および述部
539
第 13 章 データ型の変換
文字から DATE への変換
デフォルトの DATE 書式をオーバーライドし、分離文字の入った文字列を変換する
には、DATE ターゲット タイプに FORMAT 句を指定します。
SELECT CAST ('2005-01-01' AS DATE FORMAT 'YYYY-MM-DD');
文字から DATE への変換では、FORMAT 句は以下の書式設定文字だけで構成すべき
ではありません。
• EEEE
• EEE
• E4
• E3
日、月、または年が省略された文字列
文字から DATE に変換される文字列と書式で日、月、または年が省略されている場
合、システムは変換先の DATE 値のデフォルト値を使用します。
文字列から省略されているもの
システムが使用する値
日
値 1 (月の最初の日)。
月
値 1 (1 月)。
年
現在の年(現在のセッションのタイムゾーン
で)
次の表について考察します。
CREATE TABLE date_log
(id INTEGER
,start_date DATE
,end_date DATE
,log_date DATE);
次の INSERT 文は、3 つの文字列を DATE 値に変換します。最初の文字列では日が省
略され、2 番目と 3 番目の文字列ではそれぞれ、月と年が省略されています。現在
は 1992 年であると仮定しましょう。
INSERT date_log
(1001
,CAST ('January 1992' AS DATE FORMAT 'MMMMBYYYY')
,CAST ('1992-01' AS DATE FORMAT 'YYYY-DD')
,CAST ('01/01' AS DATE FORMAT 'MM/DD'));
INSERT 文の結果は、以下のようになります。
SELECT * FROM date_log;
id start_date
----------- ---------1001
92/01/01
540
end_date
-------92/01/01
log_date
-------92/01/01
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
文字から DATE への変換
例
例: IntegerDate 日付形式モード
たとえば、セッションの日付形式が INTEGERDATE で、tdlocaledef ユーティリティ
によってシステムのデフォルトの DATE 書式が'yyyymmdd'に設定されているとしま
す。
次の表を考えてみましょう。この表の start_date 列ではデフォルトの DATE 書式を
使用し、end_date 列では書式'YYYY/MM/DD'を使用しています。
CREATE TABLE date_log
(id INTEGER
,start_date DATE
,end_date DATE FORMAT 'YYYY/MM/DD');
次の INSERT 文は、文字列が対応する DATE 列の書式と一致するので目的どおりに
機能し、Teradata Database は、文字から DATE への暗黙の変換を正常に実行するこ
とができます。
INSERT INTO date_log (1099, '20030122', '2003/01/23');
対応する DATE 列の書式と一致しない文字列を文字から DATE に変換するには、
FORMAT 句を使用する必要があります。
INSERT INTO date_log
(1047
,CAST ('Jan 12, 2003' AS DATE FORMAT 'MMMBDD,BYYYY')
,CAST ('Jan 13, 2003' AS DATE FORMAT 'MMMBDD,BYYYY'));
例: ANSIDate 日付形式モード
セッション日付形式が ANSIDATE であるとします。システムのデフォルトの DATE
フォーマットは'YYYY-MM-DD'です。
次の表を考えてみましょう。この表の start_date 列ではデフォルトの DATE 書式を
使用し、end_date 列では書式'YYYY/MM/DD'を使用しています。
CREATE TABLE date_log
(id INTEGER
,start_date DATE
,end_date DATE FORMAT 'YYYY/MM/DD');
次の INSERT 文は、文字列が対応する DATE 列の書式と一致するので目的どおりに
機能し、Teradata Database は、文字から DATE への暗黙の変換を正常に実行するこ
とができます。
INSERT INTO date_log (1099, '2003-01-22', '2003/01/23');
対応する DATE 列の書式と一致しない文字列を文字から DATE に変換するには、
FORMAT 句を使用する必要があります。
SQL 関数、演算子、式および述部
541
第 13 章 データ型の変換
文字から INTERVAL への変換
INSERT INTO date_log
(1047
,CAST ('Jan 12, 2003' AS DATE FORMAT 'MMMBDD,BYYYY')
,CAST ('Jan 13, 2003' AS DATE FORMAT 'MMMBDD,BYYYY'));
例: 文字から DATE への暗黙的な変換
セッションの DateForm モードが ANSIDate に設定されていると想定します。
以下の CREATE TABLE 文は、DATE データ タイプ列に FORMAT 句を指定します。
CREATE SET TABLE datetab (f1 DATE FORMAT 'MMM-DD-YYYY');
フィールド モードでは、以下の INSERT 文は、文字列の書式が datetab テーブルの
DATE 列の書式に従っているので、文字から DATE への暗黙的な変換を正常に実行し
ます。
INSERT INTO datetab ('JAN-10-1999');
レコード モードでは、セッションの DateForm モードが ANSIDate に設定されてい
る場合、以下の INSERT 文は、文字列の書式が ANSI TIME 書式なので、文字から
DATE への暗黙的な変換を正常に実行します。
INSERT INTO datetab ('2002-05-10');
関連トピック
詳細は、以下を参照してください。
• データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
• 例については、「例: ANSIDate 日付形式モード」を参照してください。
• デフォルトの書式および FORMAT 句については、< SQL データ型とリテラル、
B035-1143>の「データ タイプの書式および書式句」を参照してください。
文字から INTERVAL への変換
目的
文字列を間隔値に変換します。
CAST 構文
CAST
( character_expression
AS
interval_data_type
)
data_attribute
542
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
文字から INTERVAL への変換
構文要素
character_expression
変換する文字式。
interval_data_type
式が変換される INTERVAL データ型。
data_attribute
以下のデータ属性のいずれか 1 つ。
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI SQL の拡張機能として、Teradata はデータ属性の仕様をサポートします。
Teradata 変換構文
character_expression
(
interval_data_type
data_attribute ,
)
, data_attribute
説明:
構文要素
character_expression
INTERVAL 値にキャストされる文字表現。
data_attribute
以下の任意選択のデータ属性のうちの 1 つ。
• NAMED
• TITLE
interval_data_type
character_expression の変換先の INTERVAL データ型。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
SQL 関数、演算子、式および述部
543
第 13 章 データ型の変換
文字から数値への変換
使用上の注意
文字の値は、先行および後続の埋め込み文字が除去され、INTERVAL 文字列定数の
宣言内の文字列定数であるかのように処理されます。
文字から INTERVAL への変換は、CHAR および VARCHAR タイプしかサポートされ
ません。CLOB をソース文字タイプとすることはできません 。
文字列の内容は、有効な INTERVAL 値に変換できる場合には変換が行なわれ、それ
以外の場合にはエラーが戻されます。
GRAPHIC の文字データ タイプを INTERVAL 文字列定数に変換することはできません。
例
例: CAST での問合わせ
以下の問合わせは' -265-11'を戻します。
SELECT CAST('-265-11' AS INTERVAL YEAR(4) TO MONTH);
例: INTERVAL 値への変換
ソース文字列が INTERVAL 形式に正規化されていない値を含んでいるにもかかわら
ず、正しい INTERVAL に変換できる場合には、変換が行なわれます。
たとえば、以下の問合わせは'-267-06'を戻します。
SELECT CAST('265-30' AS INTERVAL YEAR(4) TO MONTH);
関連トピック
データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
文字から数値への変換
目的
文字データ列を数値へ変換します。
CAST 構文
CAST
(character_expression
AS
numeric_data_type
)
data_attribute
544
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
文字から数値への変換
構文要素
character_expression
変換する文字式。
numeric_data_definition
character_expression の変換先の数値型。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI の拡張として、CAST では、数値型データの代替書式化を可能にする FORMAT
句などのデータ属性を使用することができます。
Teradata 変換構文
character_expression
(
numeric_data_type
data_attribute ,
)
, data_attribute
構文要素
character_expression
変換する文字式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
numeric_data_type
式が変換されるデータ型。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
SQL 関数、演算子、式および述部
545
第 13 章 データ型の変換
文字から数値への変換
文字から数値への暗黙的な変換
文字から数値への暗黙の変換が有効な結果になるのは、文字列が数値を表わしてい
る場合のみです。
数のオペランドが必要な式に CHAR または VARCHAR 文字列がある場合、その文字
列は書式化された数として読み取られ、FLOAT のデフォルトの書式で FLOAT 値に変
換されます。
暗黙の書式をオーバーライドするには、FORMAT 句を使用します。
または、FLOAT のデフォルト フォーマットを変更するには、REAL 構成要素の設定
を、SDF(データ フォーマット仕様)ファイルで変更することができます。デフォルト
のデータ型フォーマット、SDF ファイル、FORMAT 句については、< SQL データ型
とリテラル、B035-1143>の「データ型のフォーマットおよびフォーマット句」を参
照してください。
数値オペランドが必要な式で CLOB タイプを使用する場合、まず CLOB を CHAR ま
たは VARCHAR に明示的に変換する必要があります。
空の文字列(長さがゼロ)または埋め込み文字だけで構成されている文字列は、数値が
ゼロであるとみなされます。
FLOAT のデフォルトの書式が-9.99E-99 の場合、以下のようになります。
式
変換後
結果
1.1*’$20.00’
1.10E 00*2.00E1
2.20E 01
’2’+’2’
2.00E 00+2.00E 00
4.00E 00
’A’ + 2
----------
エラー
数値データ型の列またはパラメータが文字列値で指定されている場合、その文字列
も、書式化された数値であるとみなされます。たとえば、次の INSERT 文は、Salary
を数値の文字列として指定しています。
INSERT INTO Employee (EmpNo, Name, Salary)
VALUES (10022, 'Clements D', '$38,000.00');
数値型への変換は、編集用の記号を取り除きます。選択された時に、給与データは、
CREATE TABLE 文中で Salary 用に FORMAT 句で許可された特殊文字だけを含みま
す。FORMAT 句が'G-(9)D9(2)'の場合、出力は以下のようになります。
Salary
--------38,000.00
FORMAT 句が'G-L(9)D9(2)'の場合、出力は以下のようになります。
Salary
---------$38,000.00
546
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
文字から数値への変換
サポートされる文字タイプ
変換する文字式は CHAR または VARCHAR でなければなりません。CLOB を明示的
に数値タイプに変換することはできません。
使用上の注意
処理を開始する前に、数値の記述節が FORMAT 句についてスキャンされます。これ
は基数分離文字、グループ分離文字、通貨記号または文字列、サインゾーン(S)、ま
たは暗黙小数点(V)書式設定を決定するために使用されます。
変換は、文字ごとに左から右へと数値の終わりまで順番に行なわれます。
すべて数値の文字列だけを文字書式から数値書式に変換できます。例えば、文字列
‘US Dollars 123456’または‘123456’を整数値 123456 に変換することはできます
が、文字列‘EX1AM2PL3E’を数値に変換することはできません。
次のリストに、文字タイプ データを数値タイプに変換するためのステップを示しま
す。GRAPHIC 文字タイプの character_expression を数値に変換できないことに注意
する必要があります。
変換は前のステップに戻ることなく順番に行なわれますが、ステップは飛ばされる
ことがあります。
1 先行の埋め込み文字は無視されます。符号付きゾーン小数の入力を除いて、先
行の埋め込み文字は無視されます。
埋め込みスペースを使用できるのは、以下の規則に従える場合のみです。
• 現在の SDF ファイルでグループ分離文字としてスペースが定義されていれ
ば、文字列の基数分離文字の左の桁グループを分離するのにスペースを使用
できます。このとき、GroupingRule または CurrencyGroupingRule で定義さ
れるグループ化規則に従います。
• 現在の SDF ファイルで基数分離文字としてスペースが定義されていれば 、文
字列に基数文字としてスペースを 1 つ含めることができます。
• FORMAT 句に N などの通貨書式設定文字が含まれていて、SDF ファイルの中
のそれに適合した CurrencyName などの通貨文字列にスペースが含まれる場
合は、文字列にその通貨文字列の一部としてスペースを含めることができます。
2 符号(+または-)は、数値の一部として保存されます。仮数記号は、文字列の最初
の数字の前、または文字列の最後の数字の後に置くことができます。指数記号
は、仮数符号の後に置くことができます。
3 FORMAT と一致する場合、通貨記号は無視されます。FORMAT と一致する場合、
通貨文字列は無視されます。文字列ではただ 1 つの通貨だけが許可されます。
4 数字は、基数または英字 E の構文解析に応じて、整数、小数、または指数部分
として保存されます。
5 FORMAT で指定された基数に一致しない限り、分離文字は無視されます。
SQL 関数、演算子、式および述部
547
第 13 章 データ型の変換
文字から数値への変換
分離文字が FORMAT で指定された基数に一致する場合、位置はその数の小数部
の始めとして保存されます。V は、暗黙小数の小数部分をマークします。
通貨および分離文字が許容されているのは、文字から数値への変換に関する非
ANSI 標準の Teradata 拡張機能です。
6 (数字間の)埋め込みダッシュは、その数が符号付きであったり、基数、通貨、ま
たは指数が付帯していたりしない限り、許可されます。
7 英字の E は、その数の指数部の始めとして保存されます。E の後ろには、1 個の
空白が許可されています。
8 指数部の符号(+ または -)は保存されます。
9 指数部の数字は保存されます。符号が、指数部の数字の後ろにあってはなりませ
ん。
数値の桁あふれ
フィールド モードの場合、文字から数値への変換の際の数値桁あふれは、エラーと
して扱われません。結果がデータ タイプ用に予約されている通常の桁数を超えると、
アスタリスクが表示されます。
レコードおよび標識変数モードでは、数値の桁あふれはエラーとして報告されます。
この動作は、CAST および Teradata 変換構文のどちらにも適用されます。
FORMAT 句によるデータの構文解析の制御
FORMAT 句それ自体は、文字タイプの値を数値タイプの値に変換することはできま
せん。この句は、結果の値の構文解析方法を部分的に制御します。
文字から数値への変換の例を、以下の表にいくつか挙げます。G、D、C、および N
書式制御文字を含む FORMAT 句の場合、データ書式設定ファイル(SDF)の指定にあ
る関連項目は以下のようであると想定します。
RadixSeparator
GroupSeparator
GroupingRule
Currency
ISOCurrency
CurrencyName
548
{"."}
{","}
{"3"}
{"$"}
{"USD"}
{"US Dollars"}
文字列
変換後
結果の数値
フィールド モードで表示
される結果
'$20,000.00'
DECIMAL(10,2)
20000.00
20000.00
'$$$.50'
DECIMAL(10,2)
エラー
エラー
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
文字から数値への変換
文字列
変換後
結果の数値
フィールド モードで表示
される結果
文字列ではただ
1 つの通貨だけ
が許可されま
す。
'$.50'
DECIMAL(8,2)
.50
.50
'.345'
DECIMAL(8,3)
.345
.345
'-1.234E-02'
FLOAT
-.01234
-.01234
'-1E.-2'
FLOAT
エラー
エラー
数字の指数部分
の前に基数がな
ければなりませ
ん。
'00000000-.93'
DECIMAL(12,4)
エラー
エラー
基数の入った文
字列内では、埋
め込みダッシュ
は使用できませ
ん。
'- 55'
INTEGER
-55
-55
'E67'
FLOAT
0.0
0E 000
'9876'
DECIMAL(4,2)
FORMAT '99V99'
98.76
9876
'-123'
INTEGER
-123
-123
'9876'
DECIMAL(4,2)
FORMAT '9(2)V9(2)'
98.76
9876
'1-2-3'
INTEGER
123
123
'123-'
INTEGER
-123
-123
'123- '
INTEGER
-123
-123
'-1.234E 02'
FLOAT
-123.4
-1.23400000000000E
002
'111,222,333'
INTEGER
FORMAT 'G9(I)'
111222333
0,111,222,333
SQL 関数、演算子、式および述部
549
第 13 章 データ型の変換
文字から Period への変換
文字列
変換後
結果の数値
フィールド モードで表示
される結果
'2.49US Dollars'
DECIMAL(10,2)
FORMAT 'GZ(I)D9(F)BN'
2.49
2.49 US Dollars
'25000USD'
INTEGER
FORMAT '9(I)C'
25000
0000025000USD
FORMAT 句を指定しない変換は、SDF で定義されている、対応のデータ タイプのデ
フォルト書式を使用します。
例: 文字から数値への暗黙的な変換
以下の例の INSERT 文は、文字データ タイプを変換先の数値データ タイプに暗黙的
に変換します。
CREATE TABLE t1
(f1 DECIMAL(10,2) FORMAT 'G-U(9)D9(2)');
INSERT t1 ('USD12,345,678.90');
CREATE TABLE 文の列定義がデータ タイプに FORMAT 句を指定していない場合、
列は、データ書式設定(SDF)ファイルの指定で定義されている、対応するデータ タイ
プのデフォルト書式を使用します。
関連トピック
詳細は、以下を参照してください。
• データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
• デフォルトのデータ タイプ書式、SDF ファイル、および FORMAT 句における書
式設定文字の意味の詳細については、< SQL データ型とリテラル、B035-1143>
の「データ タイプの書式および書式句」を参照してください。
文字から Period への変換
目的
文字列を Period 値に変換します。
CAST 構文
CAST
( character_expression
AS
period_data_type
)
data_attribute
550
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
文字から Period への変換
構文要素
character_expression
変換する文字式。
period_data_type
式が変換されるデータ型。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
使用上の注意
文字値式は、CAST 関数または暗黙のキャストを使用して、PERIOD(DATE)、
PERIOD(TIMESTAMP)、または PERIOD(TIMESTAMP WITH TIME ZONE)タイプとし
てキャストできます。文字入力値も、Period タイプとして暗黙的にキャストできま
す。
変換元の文字値に含まれる先行および後続の埋め込み文字を除去した後、結果とし
ての文字列は変換先タイプの書式に従っている必要があります。日時値に対応する
文字値式の開始部分と終了部分の変換は、CHARACTER/VARCHAR から日時データ
型の変換の既存のルールに従います。
既存のルールには、変換元に指定されたタイムゾーン、または指定されていない場
合には、現在のセッションのタイムゾーンに基づいて、TIME または TIMESTAMP
形式の変換元の値から UTC への変換が含まれます。Period データ タイプから UTC
への変換には例外があります。変換元の文字の終了部分がタイムゾーンを持たない
TIMESTAMP 値のときに、値が UNTIL_CHANGED を表わすために使用される最大値
と等しい場合、その値は UTC に変換されません。
変換先タイプが TIME または TIMESTAMP 要素タイプを持ち、文字値式の開始境界
または終了境界の部分にうるう秒が含まれている場合、秒部分は変換先の精度にま
で精度を切り詰めた 59.999999 に調整されます。
変換先タイプが TIME または TIMESTAMP 要素タイプを持ち、その変換先の精度が
変換元の文字列に指定されているいずれの精度よりも低い場合には、エラーが報告
されます。変換先の精度が変換元の文字列の境界に指定された精度より高い場合、
キャストの結果得られる Period 値の対応する境界の秒の小数桁の末尾にゼロが追加
されます。
SQL 関数、演算子、式および述部
551
第 13 章 データ型の変換
文字から Period への変換
変換先の要素は、それに対応する結果値に設定します。
結果の開始境界が、UTC 形式で結果の終了境界以上になると、エラーが報告されます。
変換時に ANSI 日時形式を使用して文字データを解釈する場合、開始値と終了値を単
一引用符で囲むかどうかは任意選択です。詳細については、「ANSI DateTime フォー
マットを使用する文字列」を参照してください。
文字から Period への暗黙的変換
CHARACTER 値または VARCHAR 値は、変換先が Period データ タイプを持つ場合の
代入、更新、挿入、マージ、またはパラメータを渡す操作と、他のオペランドに
Period データ タイプがある場合の比較操作のときに、Period データ タイプとして
暗黙的にキャストされます。その他の非 Period 値が期間である変換先に直接代入さ
れると、エラーが報告されます。同様に、その他の非 Period 値を Period 値と直接
比較しても、エラーが報告されます。
注: 場合によっては、このエラーを回避するため、値を明示的に Period データ タイ
プとしてキャストすることがあります。
応答モードがフィールド モード以外の場合や、文字列データがパラメータ化されて
いる場合には、CHARACTER または VARCHAR から Period データ タイプへの暗黙的
な変換時に、文字列内の開始要素値と終了要素値を解釈するために ANSI 日時書式の
文字列が使用されます。応答モードがフィールド モードであり、文字列データがパ
ラメータ化されていない場合には、文字列内の開始要素値と終了要素値を解釈する
ために変換先の期間の書式が使用されます。以下の表では、この点を詳しく説明し
ます。
モード
パラメータ化されたデータの有無
暗黙的なキャストの解釈に使用され
る書式
フィールド
無し
変換先の書式
フィールド
有り
ANSI 書式
非フィールド
有り
ANSI 書式
非フィールド
無し
ANSI 書式
ANSI 日時書式の文字列を使用して、文字列内の開始要素値と終了要素値を解釈する
場合、開始値と終了値を単一引用符で囲むかどうかは任意選択です。このような自
由度は明示的キャストの場合にも適用されます。
ANSI 日時書式を使用する文字列
以下に、文字列から期間への暗黙的または明示的な変換で ANSI 日時書式を使用して
開始境界および終了境界の要素を解釈する場合に有効な文字列表記の一覧を示します。
• '(''beginning_element_value '' ,Δ''ending_element_value '')'
• '(beginning_element_value , Δending_element_value )'
552
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
文字から TIME への変換
• '(''beginning_element_value '', Δending_element_value )'
• '(beginning_element_value , Δ''ending_element_value '')'
beginning_element_value と ending_element_value の形式は、変換先データ型に
よって異なります。
変換先データ タイプ
書式
PERIOD (DATE)
YYYY-MM-DD
PERIOD(TIME [(n)])
HH:MI:SS.S(F)
PERIOD(TIMESTAMP [(n)])
YYYY-MM-DDBHH:MI:SS.S(F)
例: 連結された文字リテラルのキャスト
以下の例では、2 つの連結された文字リテラルが PERIOD(TIMESTAMP(2))として
キャストされます。出力は、表示時に現在のセッションのタイムゾーンに応じて調
整されます。現在のセッションのタイムゾーン変位は INTERVAL -'08:00' HOUR TO
MINUTE で、SDF に基づいて得られた書式が「YYYY-MM-DDBHH:MI:SS.S(2)Z」だ
とします。
SELECT CAST('(''2005-02-02 12:12:12.34+08:00'', ' ||
'''2006-02-03 12:12:12.34+08:00'')'
AS PERIOD(TIMESTAMP(2)));
次の PERIOD(TIMESTAMP(2))値が返されます。
('2005-02-01 20:12:12.34', '2006-02-02 20:12:12.34')
関連トピック
詳細は、以下を参照してください。
• データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
• 書式設定文字の意味は、< SQL データ型とリテラル、B035-1143>にある FORMAT
句の説明を参照してください。
• 詳細については、「ANSI DateTime フォーマットを使用する文字列」を参照して
ください。
文字から TIME への変換
目的
文字データ列を TIME または TIME WITH TIME ZONE 値に変換します。
SQL 関数、演算子、式および述部
553
第 13 章 データ型の変換
文字から TIME への変換
CAST 構文
CAST
A
( character_expression
A
AS
)
TIME
(fractional_seconds_precision)
WITH TIME ZONE
data_attribute
構文要素
character_expression
変換する文字式。
fractional_seconds_precision
SECOND フィールドの小数部の有効桁数を表わす 1 桁の数字。有効な範囲は、0 か
ら 6 です。デフォルトは 6 です。
time_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI の拡張として、CAST では、TIME タイプ データの代替出力書式化を可能にす
る FORMAT 句などのデータ属性を使用することができます。
注: TIME(タイムゾーンなし)は、ANSI SQL:2011 準拠ではありません。Teradata
Database は、現行セッションのタイムゾーン、または指定されたタイムゾーンに基
づいて、TIME 値を内部的に UTC に変換します。
Teradata 変換構文
character_expression
(
A
TIME
(fractional_seconds_precision)
data_attribute ,
)
A
,
data_attribute
WITH TIME ZONE
554
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
文字から TIME への変換
構文要素
character_expression
変換する文字式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
fractional_seconds_precision
SECOND フィールドの小数部の有効桁数を表わす 1 桁の数字。有効な範囲は、0 か
ら 6 です。デフォルトは 6 です。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
文字から TIME への暗黙的な変換
フィールド モードでは、文字列は変換先の TIME タイプの形式に従う必要がありま
す。
レコードまたは標識モードでは、文字列は ANSI TIME 書式を使用する必要がありま
す。
使用上の注意
文字値は、先行および後続の埋め込み文字が調整され、TIME 文字定数の宣言内の
文字列定数であるかのように処理されます。
文字列の内容は、有効な TIME に変換できる場合には変換が行なわれ、それ以外の
場合にはアプリケーションにエラーが戻されます。
文字から TIME への変換は、CHAR および VARCHAR タイプのみサポートされます。
CLOB または GRAPHIC の文字データ タイプを TIME に変換することはできません。
FORMAT 句を使用して、変換先の TIME データ タイプの明示的書式を指定できま
す。FORMAT 句を指定しない変換は、TIME データ タイプのデフォルト書式を使用
します。
文字列の変換先
デフォルト書式
TIME
タイムゾーン書式設定文字を使用せず、タイムゾーンを表示
しない。
SQL 関数、演算子、式および述部
555
第 13 章 データ型の変換
文字から TIME への変換
文字列の変換先
デフォルト書式
TIME WITH TIME ZONE
タイムゾーン書式設定文字を使用して、タイムゾーンを表示
する。
タイムゾーンを組み込んだ変換
タイムゾーンを組み込んだ文字から TIME への変換には、以下の規則が適用されます。
• 変換先のデータ型がタイムゾーンを指定しない場合、例えば TIME(0)の変換元文
字列には、形式+hh:mi または-hh:mi のタイムゾーンを含めることができますが、
それを指定できるのは時刻の直前または直後のみです。
たとえば、以下の変換は正常に実行されます。
SELECT CAST ( '-02:0011:23:44'
AS TIME(0) );
以下の変換は、タイムゾーンと時刻との間のブランク分離文字が原因で失敗しま
す。
SELECT CAST ( '+02:00 11:23:44.56'
AS TIME(2) );
• ソース文字列にタイムゾーンが含まれており、ターゲットのデータ型がタイム
ゾーン(例えば TIME(0))を指定していない場合、変換では文字列内のタイムゾー
ンを使用して、文字列を万国標準時(UTC)に変換します。これは、FORMAT 句に
タイムゾーンのフォーマット文字が含まれているかどうかに関係なく実行されま
す。
SELECT CAST ('10:15:12+12:30'
AS TIME(0));
• 変換元の文字列にタイムゾーンが含まれておらず、変換先のデータ型がタイム
ゾーンと変換先の FORMAT 句を指定し、FORMAT 句にはタイムゾーン書式設定
文字が含まれる場合、出力にはセッションのタイムゾーンが含まれます。
SELECT CAST ('10:15:12'
AS TIME(0) WITH TIME ZONE FORMAT 'HH:MI:SSBZ');
• 変換元の文字列と変換先のデータ タイプの両方がタイムゾーンを指定していない
場合、変換元の文字列は現在のセッションのタイムゾーンに基づいて、内部的に
UTC に変換されます。
小数秒を組み込んだ変換
小数秒が含まれる変換には、以下の規則が適用されます。
• 変換元の文字列の小数秒の精度は、変換先の型で指定された小数秒の精度以下で
なければなりません。
556
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
文字から TIME への変換
SELECT CAST('12:30:25.44' AS TIME(3));
小数秒が変換元の文字列に表示されない場合、小数秒の精度は必ず変換先のデー
タ タイプの小数秒の精度以下となります。これは精度の有効範囲が 0~6 である
からです(デフォルトは 6)。
SELECT CAST('12:30:25' AS TIME(3));
• 変換先のデータ型が FORMAT 句で定義されている場合、小数秒精度の書式設定
文字は、データ型によって指定された精度以上でなければなりません。
SELECT CAST('12h:15.12s:30m'
AS TIME(4) FORMAT 'HHh:SSDS(4)s:MIm');
FORMAT 句は、変換先のデータ タイプで小数秒の精度を指定していない場合、
デフォルトの精度は 6 なので、小数秒の精度を 6 に指定する必要があります。
SELECT CAST ('12:30:25' AS TIME FORMAT 'HH:MI:SSDS(6)');
時間、分、または秒が省略された文字列
文字から TIME に変換される文字列で時間、分、または秒が省略されている場合、
システムは変換先の TIME 値のデフォルト値を使用します。
文字列から省略されているもの
システムが使用する値
時間
値 0。
分
秒
次の表について考察します。
CREATE TABLE time_log
(id INTEGER
,start_time TIME
,end_time TIME
,log_time TIME);
次の INSERT 文は、3 つの文字列を TIME 値に変換します。最初の文字列では時間
が省略され、2 番目と 3 番目の文字列ではそれぞれ、分と秒が省略されています。
INSERT time_log
(1001
,CAST ('01:02.030405' AS TIME FORMAT 'MI:SS.S(6)')
,CAST ('01:02.030405' AS TIME FORMAT 'HH:SS.S(6)')
,CAST ('01:02' AS TIME FORMAT 'HH:MI'));
INSERT 文の結果は、以下のようになります。
SQL 関数、演算子、式および述部
557
第 13 章 データ型の変換
文字から TIME への変換
SELECT * FROM time_log;
id
start_time
----------- --------------1001 00:01:02.030405
end_time
--------------01:00:02.030405
log_time
--------------01:02:00.000000
FORMAT 句の制限事項
文字から TIME への変換では、FORMAT 句は以下の書式設定文字だけで構成すべき
ではありません。
• Z
• T
例
例: 小数桁
この問合わせは、値'12:23:39.999900'を戻します(TIME(6)タイプに CAST するよう
に要求されたため、小数の秒は 6 桁に拡張される)。
SELECT CAST(' 12:23:39.9999 '
AS TIME(6));
例: 非埋め込み文字データの切り捨て
要求された変換には非埋め込み文字のデータの切り捨てが必要であるため、この問
合わせはエラーを戻します。
SELECT CAST(' 12:23:39.9999 '
AS TIME(3));
例: 無効な MINUTE 値
63 という MINUTE 値は有効ではないため、この問合わせはエラーを戻します。
SELECT CAST(' 12:63:39.9999 '
AS TIME(6));
例: FORMAT 句
この問合わせは値'15h33m'を戻します。
SELECT CAST('15h33m'
AS TIME(0) FORMAT 'HHhMIm');
例: 文字から TIME への暗黙的な変換
以下の CREATE TABLE 文は、TIME データ タイプ列に FORMAT 句を指定します。
CREATE SET TABLE timetab (f1 TIME(0) FORMAT 'TBHHhMImSSs');
558
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
文字から TIMESTAMP への変換
フィールド モードでは、以下の INSERT 文は、文字列の書式が timetab テーブルの
TIME 列の書式に従っているので、文字から TIME への暗黙的な変換を正常に実行
します。
INSERT INTO timetab ('AM 10h20m30s');
レコード モードでは、以下の INSERT 文は、文字列の書式が ANSI TIME 書式なの
で、文字から TIME への暗黙的な変換を正常に実行します。
INSERT timetab ('11:23:34');
関連トピック
詳細は、以下を参照してください。
• データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
• デフォルトの書式および FORMAT 句については、< SQL データ型とリテラル、
B035-1143>の「データ タイプの書式および書式句」を参照してください。
文字から TIMESTAMP への変換
目的
文字データ列を TIMESTAMP または TIMESTAMP WITH TIME ZONE 値に変換しま
す。
CAST 構文
CAST
( character_expression
AS
A
TIMESTAMP
(fractional_seconds_precision)
)
A
WITH TIME ZONE
data_attribute
構文要素
character_expression
変換する文字式。
fractional_seconds_precision
SECOND フィールドの小数部の有効桁数を表わす 1 桁の数字。有効な範囲は、0 か
ら 6 です。デフォルトは 6 です。
SQL 関数、演算子、式および述部
559
第 13 章 データ型の変換
文字から TIMESTAMP への変換
timestamp_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI の拡張として、CAST では、TIME データの代替書式化を可能にする FORMAT
句などのデータ属性を使用することができます。
注: TIMESTAMP(タイムゾーンなし)は、ANSI SQL:2011 準拠ではありません。
Teradata Database は、現行セッションのタイムゾーン、または指定されたタイム
ゾーンに基づいて、TIMESTAMP 値を内部的に UTC に変換します。
Teradata 変換構文
CAST
( character_expression
AS
A
TIMESTAMP
(fractional_seconds_precision)
)
A
WITH TIME ZONE
data_attribute
構文要素
character_expression
変換する文字式。
fractional_seconds_precision
SECOND フィールドの小数部の有効桁数を表わす 1 桁の数字。有効な範囲は、0 か
ら 6 です。デフォルトは 6 です。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
560
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
文字から TIMESTAMP への変換
文字から TIMESTAMP への暗黙的な変換
フィールド モードでは、文字列は変換先の TIMESTAMP タイプの形式に従う必要が
あります。
レコードまたは標識モードでは、文字列は ANSI TIMESTAMP 書式を使用する必要
があります。
使用上の注意
変換元の式は、先行および後続の埋め込み文字が調整され、TIMESTAMP 文字列定
数の宣言内の文字列定数であるかのように処理されます。
文字から TIMESTAMP への変換は、CHAR および VARCHAR タイプしかサポートさ
れません。CLOB または GRAPHIC 文字データ タイプを TIMESTAMP に変換するこ
とはできません。
文字列の内容は、有効な TIMESTAMP 値に変換できる場合には変換が行なわれ、そ
れ以外の場合にはエラーが戻されます。
FORMAT 句を使用して、変換先の TIMESTAMP データ タイプの明示的書式を指定
できます。FORMAT 句を指定しない変換は、TIMESTAMP データ タイプのデフォル
ト書式を使用します。
文字列の変換先
デフォルト書式
TIMESTAMP
タイムゾーン書式設定文字を使用せず、タイ
ムゾーンを表示しない。
TIMESTAMP WITH TIME ZONE
タイムゾーン書式設定文字を使用して、タイ
ムゾーンを表示する。
例: CAST での問合わせ
次の問合わせは‘2007-12-31 23:59:59.999999-08:00’を戻します。
SELECT CAST('2007-12-31 23:59:59.999999'
AS TIMESTAMP(6) WITH TIME ZONE);
ソース文字列は、この変換が正しく行なわれるために明示的なタイムゾーンフィー
ルドを持つ必要はない点に注意する必要があります。
タイムゾーンを組み込んだ変換
タイムゾーンを組み込んだ文字から TIMESTAMP への変換には、以下の規則が適用
されます。
• 変換先のデータ型がタイムゾーンを指定しない場合、例えば TIMESTAMP(0)の変
換元文字列には、形式+hh:mi または-hh:mi のタイムゾーンを含めることができ
ますが、それを指定できるのは時刻の直前または直後のみです。
SQL 関数、演算子、式および述部
561
第 13 章 データ型の変換
文字から TIMESTAMP への変換
たとえば、以下の変換は正常に実行されます。
SELECT CAST ( '2008-09-19 11:23:44-02:00'
AS TIMESTAMP(0) FORMAT 'Y4-MM-DDBHH:MI:SSBZ' );
以下の変換は、タイムゾーンと時刻との間のブランク分離文字が原因で失敗しま
す。
SELECT CAST ( '2008-01-19 +02:00 11:23:44'
AS TIMESTAMP(0) FORMAT 'Y4-MM-DDBZBHH:MI:SS' );
• ソースの文字列にタイムゾーンが含まれており、ターゲットのデータ型がタイム
ゾーンを指定していない場合、変換では文字列内のタイムゾーンを使用して、文
字列を万国標準時(UTC)に変換します。これは、FORMAT 句にタイムゾーンの
フォーマット文字が含まれているかどうかに関係なく実行されます。
SELECT CAST ('2002-02-20 10:15:12+12:30' AS TIMESTAMP(0));
• 変換先の FORMAT 句にタイムゾーンの書式設定文字が含まれており、変換先の文
字列にタイムゾーンが含まれていない場合、出力にはセッションのタイムゾーン
が入ります。これは、ターゲットのデータ型がタイムゾーンを指定しているかど
うかに関係なく実行されます。
SELECT CAST ('2002-02-20 10:15:12'
AS TIMESTAMP(0) WITH TIME ZONE FORMAT 'Y4-MM-DDBHH:MI:SSBZ');
• 変換元の文字列と変換先のデータ タイプの両方がタイムゾーンを指定していない
場合、変換元の文字列は現在のセッションのタイムゾーンに基づいて、内部的に
UTC に変換されます。
小数秒を組み込んだ変換
小数秒が含まれる変換には、以下の規則が適用されます。
• 変換元の文字列の小数秒の精度は、変換先の型で指定された小数秒の精度以下で
なければなりません。
SELECT CAST('2002-01-01 12:30:25.44' AS TIMESTAMP(3));
小数秒が変換元の文字列に表示されない場合、小数秒の精度は必ず変換先のデー
タ タイプの小数秒の精度以下となります。これは精度の有効範囲が 0~6 である
からです(デフォルトは 6)。
SELECT CAST('2002-01-01 12:30:25' AS TIMESTAMP(3));
• 変換先のデータ型が FORMAT 句で定義されている場合、小数秒精度の書式設定文
字は、データ型によって指定された精度以上でなければなりません。
SELECT CAST('12-02-07 12:30:25' AS TIMESTAMP(3)
FORMAT 'DD-MM-YYBHH:MI:SSDS(3)');
FORMAT 句は、変換先のデータ タイプで小数秒の精度を指定していない場合、
デフォルトの精度は 6 なので、小数秒の精度を 6 に指定する必要があります。
562
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
文字から TIMESTAMP への変換
SELECT CAST('12-02-07 12h:15.12s:30m'
AS TIMESTAMP FORMAT 'DD-MM-YYBHHh:SSDS(6)s:MIm');
日、月、年、時間、分、または秒が省略された文字列
文字から TIMESTAMP に変換される文字列で日、月、年、時間、分、または秒が省
略されている場合、システムは変換先の TIMESTAMP 値のデフォルト値を使用しま
す。
文字列から省略されているもの
システムが使用する値
日
値 1 (月の最初の日)。
月
値 1 (1 月)。
年
現在の年。
時間
値 0。
分
秒
次の表について考察します。
CREATE TABLE timestamp_log
(id INTEGER, start_ts TIMESTAMP, end_ts TIMESTAMP);
次の INSERT 文は、2 つの文字列を TIMESTAMP 値に変換します。どちらの文字列
も時間、分、および秒が省略されています。さらに、最初の文字列では日が省略さ
れており、2 番目の文字列では月が省略されています。
INSERT timestamp_log
(1001
,CAST ('January 2006' AS TIMESTAMP FORMAT 'MMMMBYYYY')
,CAST ('2006-01' AS TIMESTAMP FORMAT 'YYYY-DD'));
INSERT 文の結果は、以下のようになります。
SELECT * FROM timestamp_log;
id
start_ts
----------- -------------------------1001 2006-01-01 00:00:00.000000
end_ts
-------------------------2006-01-01 00:00:00.000000
次に示す INSERT 文では、どちらの文字列も年が省略されています。さらに、最初
の文字列では時間が省略されており、2 番目の文字列では分が省略されています。
現在は 2003 年であると仮定しましょう。
INSERT timestamp_log
(1002
,CAST ('January 23 04:05' AS TIMESTAMP FORMAT 'MMMMBDDBMI:SS')
,CAST ('01-23 04:05' AS TIMESTAMP FORMAT 'MM-DDBHH:SS'));
SQL 関数、演算子、式および述部
563
第 13 章 データ型の変換
文字から UDT への変換
INSERT 文の結果は、以下のようになります。
SELECT * FROM timestamp_log WHERE id = 1002;
id
start_ts
end_ts
----------- -------------------------- -------------------------1001 2003-01-23 00:04:05.000000 2003-01-23 04:00:05.000000
FORMAT 句の制限事項
文字から TIMESTAMP への変換では、FORMAT 句は以下の書式設定文字だけで構成
すべきではありません。
•
•
•
•
•
•
EEEE
E4
EEE
E3
T
Z
関連トピック
詳細は、以下を参照してください。
• データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
• デフォルトの書式および FORMAT 句については、< SQL データ型とリテラル、
B035-1143>の「データ タイプの書式および書式句」を参照してください。
文字から UDT への変換
目的
文字データ列を UDT へ変換します。
CAST 構文
CAST
( character_expression
AS
UDT_data_type (
構文要素
character_expression
変換する文字式。
564
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
文字から UDT への変換
UDT_data_definition
式が変換されるデータ型。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、FORMAT などのデータ属性句を CAST で使用できます。
使用上の注意
Teradata 変換構文を使った文字から UDT への明示的な変換はサポートされていま
せん。
UDT の関与するデータ型の変換には、その UDT に適した CAST 定義が必要です。
UDT の CAST を定義するには、CREATE CAST 文を使用します。
文字から UDT への暗黙的変換
Teradata Database は、以下の操作に対して文字から UDT への暗黙変換を実行しま
す。
• UPDATE
• INSERT
• ストアド プロシージャ、外部ストアド プロシージャ、UDF、および UDM への
引数の引渡し。
• このマニュアル中の他の箇所に明記されている特定のシステム演算子と関数 (DBS
制御レコードの DisableUDTImplCastForSysFuncOp フィールドが TRUE に設定さ
れていない場合に限る)。
暗黙のデータ型変換を実行するには、AS ASSIGNMENT 句を指定する適切な CAST
定義(「使用上の注意」を参照)が存在する必要があります。
CAST 定義のソース文字タイプは、暗黙変換のソース文字タイプと正確に一致して
いる必要はありません。Teradata Database では、CHAR、VARCHAR、または CLOB
ソース タイプを指定する暗黙の CAST 定義を使用することができます。
別々の文字タイプから UDT への変換の場合に複数の暗黙 CAST 定義が存在する場
合、Teradata Database は優先順位の最も高い文字タイプの暗黙 CAST 定義を使用し
ます。以下のリストでは、文字タイプの優先順位が最低から最高の順に並べられて
います。
• CHAR
• VARCHAR
• CLOB
SQL 関数、演算子、式および述部
565
第 13 章 データ型の変換
文字から UDT への変換
CLOB 以外の文字タイプの場合、文字から UDT への暗黙 CAST 定義が存在しないと、
Teradata Database はその代用になる他の CAST 定義を探します。
存在する暗黙 CAST 定義の組み合わせ
Teradata Database の動作
Numeric- DATE- TIME- TIMESTAMP
to-UDT
to-UDT to-UDT -to-UDT
X
数値から UDT への暗黙 CAST 定義を使用する。
数値から UDT への暗黙 CAST 定義が複数存在す
る場合、Teradata Database は SQL エラーを戻
します。
X
DATE から UDT への暗黙 CAST 定義を使用する。
X
TIME から UDT への暗黙 CAST 定義を使用する。
X
X
X
X
エラーを報告する。
X
X
X
X
X
X
X
X
X
X
X
X
X
X
TIMESTAMP から UDT への暗黙 CAST 定義を使
用する。
X
X
X
X
X
X
X
X
X
X
X
Teradata Database は CLOB 以外の文字タイプを代用データ タイプに暗黙でキャス
トしてから、暗黙 CAST 定義を使用して、その代用データ タイプから UDT へのキャ
ストを行なえるため、代用は有効です。
関連トピック
詳細は、以下を参照してください。
• データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
• CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>
を参照してください。
566
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
文字データ タイプの割り当て規則
文字データ タイプの割り当て規則
サーバー文字セット
LATIN、UNICODE、KANJISJIS、KANJI1、および GRAPHIC のサーバー文字セット
は、基本的に相互に割り当てが可能です。
式を文字列の列に割り当てるとします。その割り当ては、SQL の UPDATE または
INSERT 文の結果になるか、またはロード ユーティリティの割り当ての結果になり
ます。
式は、文字の列のサーバー文字セットに変換されます。
GRAPHIC データの例外
GRAPHIC データには、以下の例外が適用されます。
• GRAPHIC データをインポートして、そのデータを文字の列に割り当てる場合、
その列を GRAPHIC として定義する必要があります。
• GRAPHIC ではない文字データの場合、そのデータを GRAPHIC として定義されて
いる列に割り当てることはできません。
詳細は、< SQL データ操作言語、B035-1146>の USING 行記述子の説明を参照し
てください。
• GRAPHIC 以外のデータを BTEQ またはロード ユーティリティから GRAPHIC 列
に割り当てることはできません。
詳細は、< SQL データ操作言語、B035-1146>の USING 行記述子の説明を参照し
てください。
• ASCII や EBCDIC などの 1 バイト文字セットから GRAPHIC データを割り当てた
り、エクスポートすることはできません。
DATE から文字への変換
目的
DATE 値を文字列へ変換します。
CAST 構文
CAST
( date_expression
AS
character_data_type
A
)
A
CHARACTER SET
SQL 関数、演算子、式および述部
server_character_set
data_attribute
567
第 13 章 データ型の変換
DATE から文字への変換
構文要素
date_expression
変換する日付式。
character_data_type
式が変換されるデータ型。
character_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、CAST で文字データ属性句を使用できます。
Teradata 変換構文
CAST
( date_expression
AS
character_data_type
A
)
A
CHARACTER SET
server_character_set
data_attribute
構文要素
date_expression
変換する日付式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
character_data_type
式が変換されるデータ型。
568
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
DATE から文字への変換
server_character_set
変換に使用するサーバー文字セット。CHARACTER SET 句を省略した場合は、ユー
ザー デフォルトのサーバー文字セットが使用されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
DATE から CHAR(n)または VARCHAR(n)への変換時に、n は、文字列定数によって
表わされた DATE 値の長さと等しいかそれよりも長くなければなりません。
変換先データ タ
イプ
n
CHAR(n)
文字列定数で表わされた DATE 値 末尾の埋め込み文字が表記を埋め
の長さより長い
るために追加される。
小さすぎる
VARCHAR(n)
結果
文字切り捨てエラーが戻される。
文字列定数で表わされた DATE 値 ブランク埋め込みは文字表記に追
の長さより長い
加されない。
小さすぎる
文字切り捨てエラーが戻される。
制約事項
サーバー文字セットが GRAPHIC の場合、暗黙的にも明示的にも DATE タイプを文
字タイプに変換することはできません。
DATE から CLOB への変換はサポートされていません。
DATE から文字への変換に対する CAST での FORMAT の強制
DATE から文字への変換のデフォルトの書式は、DATE 値に有効な書式を使用します。
デフォルトの書式をオーバーライドするには、FORMAT 句を使って、DATE 値を文
字列に変換できます。ただし、結果の書式は、DATE 値と同じになります。文字列
値で別の書式を使用する場合は、以下で説明するように CAST を併用する必要があ
ります。
DATE 値に関連する書式にかかわらず、DATE から CHAR に値を変換し、その結果に
おいて明示的な FORMAT を強制するには、入れ子 CAST 操作を行なう必要がありま
す。これは、FORMAT 句をデータ タイプに突き合わせるための規則によるものです。
SQL 関数、演算子、式および述部
569
第 13 章 データ型の変換
DATE から文字への変換
例
例: DATE 値から文字列への変換
セッションの日付形式モードが INTEGERDATE、テーブル INTDAT 内の列 F1 が明示
的なフォーマット'YYYY,MMM,DD'を持つ DATE 値であるとします。
SELECT F1 FROM INTDAT ;
結果(タイプの変更はなし)は、以下のレポートになります。
F1
---------1900,Dec,31
この値を CHAR(12)の値に変換し、'MMMBDD,BYYYY'の明示的な出力フォーマット
にすると仮定します。入れ子 CAST 句と FORMAT を使って、目的の結果を入手しま
す。 つまり、文字書式のレポートです。
SELECT
CAST( (CAST (F1 AS FORMAT 'MMMBDD,BYYYY')) AS CHAR(12))
FROM INTDAT;
入れ子 CAST の結果は、以下のレポートになります。
F1
-----------Dec 31, 1900
内部 CAST は DATE 値の表示書式を確立し、外部 CAST は必要な結果のデータ タイ
プを示します。
例: データ値を変換するスクリプトの作成
DATE 値のソースまたはセッションの DATEFORM モードにかかわらず、データ値を
ANSI DATE 書式に変換するためのスクリプトを作成する必要があると仮定します。
入れ子 CAST および FORMAT を使用して、以下の例に示すようにこれを行なうこと
ができます。
SELECT
CAST( (CAST (F1 AS FORMAT 'YYYY-MM-DD')) AS CHAR(10))
FROM INTDAT;
入れ子 CAST の結果は、以下のレポートになります。
F1
---------1900-12-31
570
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
DATE から DATE への変換
関連トピック
データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
DATE から DATE への変換
目的
DATE から DATE への変換を使用して、DATE タイプの書式またはタイトルを変換し
ます。
CAST 構文
CAST
( date_expression
AS
)
DATE
data_attribute
data_attribute
構文要素
date_expression
変換する日付式。
date_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
CAST では、日付データの代替出力の書式化を可能にする FORMAT 句などのデータ
属性を使用することができます。これは、CAST の Teradata 拡張機能です。
日付形式が INTEGERDATE の DATE タイプを使用する DATE から DATE への変換は、
ANSI SQL:2011 の Teradata 拡張機能です。これは、CAST の Teradata 拡張機能で
す。
SQL 関数、演算子、式および述部
571
第 13 章 データ型の変換
DATE から DATE への変換
Teradata 変換構文
date_expression
(
DATE
)
, data_attribute
,
data_attribute
, DATE
, data_attribute
構文要素
date_expression
変換する日付式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
例: 従業員の生年月日の検索
セッション日付形式モードが INTEGERDATE で作成された employee という名前の
テーブルがあるとします。dob は書式が M3BDDBY4 の DATE 列です。1938 年 1 月
30 日から 1943 年 3 月 30 日の間に生まれた従業員をリストするには、日付情報を
次のように指定します。
SELECT name, dob
FROM employee
WHERE dob BETWEEN 'Jan 30 1938' AND 'Mar 30 1943'
ORDER BY dob;
結果は、Employee テーブルに指定されたとおりの誕生日が戻されます。
Name
---------Inglis C
Peterson J
DOB
----------Mar 07 1938
Mar 27 1942
日付の書式を別の書式に変更するには、次の SELECT 文にします。
572
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
DATE から数値への変換
SELECT name, dob (FORMAT 'yy-mm-dd')
FROM employee
WHERE dob BETWEEN 'Jan 30 1938' AND 'Mar 30 1943'
ORDER BY dob ;
書式の指定によって、表示が以下のように変わります。
Name
---------Inglis C
Peterson J
DOB
-------38-03-07
42-03-27
関連トピック
データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
DATE から数値への変換
序
DATE データを以下の数値タイプに変換することができます。
•
•
•
•
•
•
•
BYTEINT
SMALLINT
INTEGER
BIGINT
DECIMAL(n, m)
NUMBER
FLOAT
CAST 構文
CAST
( date_expression
AS
)
numeric_data_type
data_attribute
構文要素
date_expression
変換する日付式。
numeric_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
SQL 関数、演算子、式および述部
573
第 13 章 データ型の変換
DATE から数値への変換
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、CAST で数値データ属性句を使用できます。
Teradata 変換構文
date_expression
numeric_data_type
(
)
data_attribute ,
, data_attribute
構文要素
date_expression
変換する日付式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
numeric_data_type
式が変換されるデータ型。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
日付を数値に変換すると、エンコードされて内部に格納された日付の整数値が戻さ
れます。この場合、以下の公式が使用されます。
(year - 1900) * 10000 + (month * 100) + day
指定可能な日付値は、西暦 0001 年 1 月 1 日~西暦 9999 年 12 月 31 日です。
たとえば、1985 年 12 月 31 日は整数 851231、1776 年 7 月 4 日は-1239296、
2041 年 3 月 30 日は 1410330 としてそれぞれ格納されます。
574
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
DATE から数値への変換
DATE から DECIMAL(n,m)への変換で、数字(n)の数が小さすぎる場合は、数値オー
バーフローのエラーが発生します。DATE から BYTEINT または SMALLINT への変
換では、戻される値がそのデータ タイプで表現できる値の範囲外である場合は、数
値桁あふれエラーが発生します。
DATE から INTEGER または FLOAT への変換では、エラーは生成されません。
FORMAT 句
DATE から数値への変換における FORMAT 句には、9 または Z の書式制御文字が含
まれるだけです。たとえば、
SELECT CAST (DATE '2007-12-31' AS INTEGER FORMAT '9999999');
DATE から数値への暗黙的変換
Teradata Database は、DATE 型を数値型に割り当て、DATE 型と数値型を比較する、
または数値型をとるシステム関数に DATE 型を渡す場合に、DATE から数値型への
暗黙の変換を実行します。
例
以下は、employee テーブルの dob 列の DATE データを、数値書式に変換する例です。
日付データを DATE タイプとして定義するのが最善の実施方法です。日付データを
数値タイプとして定義しないように注意してください。
表示を日付書式から整数書式に変えるためには、文を以下のように変更します。
SELECT name, dob (INTEGER)
FROM employee
WHERE dob BETWEEN 380307 AND 420825
ORDER BY dob ;
または
SELECT name, CAST (dob AS INTEGER)
FROM employee
WHERE dob BETWEEN 380307 AND 420825
ORDER BY dob ;
表示は以下のようになります。
Name
---------Inglis C
Peterson J
SQL 関数、演算子、式および述部
DOB
-----380307
420327
575
第 13 章 データ型の変換
DATE から Period への変換
関連トピック
データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
DATE から Period への変換
目的
PERIOD(DATE)または PERIOD(TIMESTAMP[(n)] [WITH TIME ZONE])としてキャスト
します。
CAST 構文
CAST
( date_expression
AS
)
period_data_type
data_attribute
構文要素
date_expression
変換する日付式。
period_data_type
式が変換されるデータ型。
period_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、CAST でデータ属性句を使用できます。
使用上の注意
DATE 値は、CAST 関数を使用すると PERIOD(DATE)または PERIOD(TIMESTAMP[(n)]
[WITH TIME ZONE])としてキャストできます。DATE 値を PERIOD(TIME[(n)] [WITH
TIME ZONE])としてキャストしようとすると、エラーが報告されます。
576
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
DATE から Period への変換
変換先タイプが PERIOD(DATE)の場合、結果の開始要素は変換元の値に設定されま
す。結果の終了要素は、結果の開始境界に変換先タイプの 1 最小単位(つまり、
INTERVAL '1' DAY)を加算したものに設定されます。結果の終了境界が最大 DATE 値
を超える(つまり、変換元の値が最大 DATE 値に等しい)場合や、結果の終了境界が
最大 DATE 値に等しい(つまり、結果の終了境界値が UNTIL_CHANGED の値に等し
い)場合、エラーが報告されます。
変換先タイプが PERIOD(TIMESTAMP[(n)])の場合、結果の開始要素は現在のセッショ
ンのタイムゾーン、変換元 DATE 値によって作成されたタイムスタンプ値、および
ゼロの時間部分を使用して得られる UTC 値に設定されます。結果の終了要素は、結
果の開始境界に変換先タイプの 1 最小単位を加算したものに設定されます(これはエ
ラーにはなりません)。
変換先タイプが PERIOD(TIMESTAMP[(n)] WITH TIME ZONE)の場合、結果の開始要
素の時間部分は現在のセッションのタイムゾーン、変換元 DATE 値から作成された
タイムスタンプ値、およびゼロの時間部分を使用して得られる UTC 値に設定されま
す。結果の開始要素のタイムゾーンは、現在のセッションのタイムゾーン変位に設
定されます。結果の終了要素は、結果の開始境界に変換先タイプの 1 最小単位を加
算したものに設定されます(これはエラーにはなりません)。
注: 結果は開始境界と最後の値が同じ値になります。
例
例: DATE リテラルを PERIOD(DATE)としてキャストする
以下の例では、DATE リテラルが PERIOD(DATE)としてキャストされます。結果の
開始境界は、変換元から取得します。結果の終了要素は、結果の開始境界に
INTERVAL '1' DAY を加算したものに設定されます。
SELECT CAST(DATE '2005-02-03' AS PERIOD(DATE));
次に示す PERIOD(DATE)値が返されます。
('2005-02-03', '2005-02-04')
例: DATE リテラルを PERIOD(TIMESTAMP(4))としてキャストする
以下の例では、DATE リテラルが PERIOD(TIMESTAMP(4))としてキャストされま
す。結果の開始境界は、DATE リテラルとゼロの時間部分で作成されます。結果の
終了要素は、結果の開始境界に INTERVAL '0.0001' SECOND を加算したものに設定
されます。
SELECT CAST(DATE '2005-02-03' AS PERIOD(TIMESTAMP(4)));
次の PERIOD(TIMESTAMP(4))値が返されます。
('2005-02-03 00:00:00.0000', '2005-02-03 00:00:00.0001')
SQL 関数、演算子、式および述部
577
第 13 章 データ型の変換
DATE から TIMESTAMP への変換
関連トピック
データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
DATE から TIMESTAMP への変換
目的
DATE 値を TIMESTAMP または TIMESTAMP WITH TIME ZONE 値に変換します。
CAST 構文
CAST
( date_expression
AS
A
TIMESTAMP
(fractional_seconds_precision)
B
A
WITH TIME ZONE
AT
LOCAL
expression
TIME ZONE
B
time_zone_string
)
data_attribute
構文要素
date_expression
変換する日付式。
fractional_seconds_precision
SECOND フィールドの小数部の有効桁数を表わす 1 桁の数字。有効な範囲は、0 か
ら 6 です。デフォルトは 6 です。
AT LOCAL
現在のセッションのタイムゾーンに基づくタイムゾーン変位を使用します。
AT [TIME ZONE] expression
式で定義されたタイムゾーンの変位を使用します。
expression のデータ タイプは INTERVAL HOUR(2) TO MINUTE か、暗黙的に
INTERVAL HOUR(2) TO MINUTE に変換できるデータ タイプでなければなりません。
578
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
DATE から TIMESTAMP への変換
AT [TIME ZONE] time_zone_string
time_zone_string は、タイムゾーン変位を決定します。
timestamp_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI の拡張として、CAST では、タイムスタンプ データの代替出力の書式化を可能
にするために、FORMAT 句を使用することができます。
AT 句は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、CAST を使用した DATE から TIMESTAMP への変換に、AT
句がサポートされるようになりました。また、INTERVAL 式の他にも追加の式を使
用して、タイムゾーン変位を指定することができます。
注: TIMESTAMP (without time zone)は、ANSI SQL:2011 互換ではありません。
Teradata Database は、現行セッションのタイムゾーン、または指定されたタイム
ゾーンに基づいて、TIMESTAMP 値を内部的に UTC に変換します。
Teradata 変換構文
date_expression
(
A
TIMESTAMP
(fractional_seconds_precision)
data_attribute ,
B
A
, WITH TIME ZONE
AT
LOCAL
expression
TIME ZONE
B
time_zone_string
)
, data_attribute
構文要素
date_expression
変換する日付式。
SQL 関数、演算子、式および述部
579
第 13 章 データ型の変換
DATE から TIMESTAMP への変換
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
fractional_seconds_precision
SECOND フィールドの小数部の有効桁数を表わす 1 桁の数字。有効な範囲は、0 か
ら 6 です。デフォルトは 6 です。
AT LOCAL
現在のセッションのタイムゾーンに基づくタイムゾーン変位を使用します。
AT [TIME ZONE] expression
式で定義されたタイムゾーンの変位を使用します。
expression のデータ タイプは INTERVAL HOUR(2) TO MINUTE か、暗黙的に
INTERVAL HOUR(2) TO MINUTE に変換できるデータ タイプでなければなりません。
AT [TIME ZONE] time_zone_string
time_zone_string は、タイムゾーン変位を決定します。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
AT 句は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、Teradata 変換構文を使用した DATE から TIMESTAMP への
変換に、AT 句がサポートされるようになりました。また、INTERVAL 式の他にも追
加の式を使用して、タイムゾーン変位を指定することができます。
注: TIMESTAMP (without time zone)は、ANSI SQL:2011 互換ではありません。
Teradata Database は、現行セッションのタイムゾーン、または指定されたタイム
ゾーンに基づいて、TIMESTAMP 値を内部的に UTC に変換します。
使用上の注意
CAST 関数、または各種の指定オプションに基づいた Teradata 変換の結果を以下の
表に示します。変換先の精度がゼロより高い場合、精度を調整するために結果の末
尾にゼロが追加されます。
580
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
DATE から TIMESTAMP への変換
指定内容
THEN...
AT LOCAL
変換元の date_expression から、ローカルのタイムスタンプが生成されま
す。時間の部分は'00:00:00'に設定されます。次に、このローカルのタイム
スタンプ値から、現在のセッションのタイムゾーンに基づいたタイムゾー
ン変位を減算することで、UTC に調整された結果が生成されます。
これは、AT 句を指定しない場合と同じ結果になります。
AT 式または
AT TIME ZONE expression
変換元の date_expression から、ローカルのタイムスタンプが生成されま
す。時間の部分は'00:00:00'に設定されます。次に、このローカル タイム
スタンプ値から、expression で定義されるタイムゾーン変位を減算するこ
とで、UTC に調整された結果が生成されます。
AT time_zone_string または AT
TIME ZONE time_zone_string
変換元の date_expression から、ローカルのタイムスタンプが生成されま
す。時間の部分は'00:00:00'に設定されます。タイムゾーン変位は、
time_zone_string と、ローカルのタイムスタンプ値を基に決定されます。
次に、ローカルのタイムスタンプ値からタイムゾーン変位を減算すること
で、UTC に調整された結果が生成されます。
DATE から TIMESTAMP への暗黙的変換
Teradata Database は、DATE から TIMESTAMP タイプへの暗黙的変換を実行する場
合があります。「DateTime 型の暗黙的変換」を参照してください。
以下の変換をサポートします。
変換元タイプ
変換先タイプ
DATE
TIMESTAMP
ANSIDate 日付形式モードまたは IntegerDate TIMESTAMP WITH TIME ZONE
日付形式モード
TIMESTAMP 値は、比較の場合には常に DATE に変換されます。「TIMESTAMP か
ら DATE への変換」を参照してください。
例
例: DATE 値から TIMESTAMP 値への変換
この例では、CAST の結果は、ソースの式の値'2008-05-14'と、現行セッションの
タイムゾーン変位 INTERVAL '01:00' HOUR TO MINUTE によって UTC に調整され
たデフォルトの時間'00:00:00'から生成されるタイムスタンプになります。したがっ
て、CAST の値は、'2008-05-13 23:00:00' (UTC)になります。
UTC での CAST の結果値は現在のセッションのタイムゾーン変位 INTERVAL '01:00'
HOUR TO MINUTE に調整されるため、SELECT 文の結果は次のようになります。
TIMESTAMP '2008-05-14 00:00:00'
SQL 関数、演算子、式および述部
581
第 13 章 データ型の変換
DATE から TIMESTAMP への変換
SET TIME ZONE INTERVAL '01:00' HOUR TO MINUTE;
SELECT CAST(DATE '2008-05-14' AS TIMESTAMP(0));
SELECT CAST(DATE '2008-05-14' AS TIMESTAMP(0) AT LOCAL);
例: DATE 値から TIMESTAMP WITH TIME ZONE 値への変換
この例では、CAST の結果は、ソースの式の値'2008-05-14'と、現行セッションのタ
イムゾーン変位 INTERVAL '06:00' HOUR TO MINUTE によって UTC に調整されたデ
フォルトの時間'00:00:00'から生成されるタイムスタンプになります。したがって、
CAST の値は現在のセッションのタイムゾーン変位 INTERVAL '06:00' HOUR TO
MINUTE によって、'2008-05-13 18:00:00' (UTC)になります。
UTC での CAST の結果値はそのタイムゾーン変位 INTERVAL '06:00' HOUR TO
MINUTE に調整されるため、SELECT 文の結果は次のようになります。TIMESTAMP
'2008-05-14 00:00:00+06:00'
SET TIME ZONE INTERVAL '06:00' HOUR TO MINUTE;
SELECT CAST(DATE '2008-05-14' AS TIMESTAMP(0) WITH TIME ZONE);
SELECT CAST(DATE '2008-05-14' AS TIMESTAMP(0) WITH TIME ZONE
AT LOCAL);
例
次の SELECT 文では、CAST の結果は、日付'2008-05-14'と、指定したセッションの
タイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE によって UTC に調整され
デフォルトの時間'00:00:00'から生成されるタイムスタンプになります。したがっ
て、CAST の値は、'2008-05-14 08:00:00' (UTC)になります。
UTC での CAST の結果値は現在のセッションのタイムゾーン変位 INTERVAL
'05:00:00' HOUR TO MINUTE に調整されるため、SELECT 文の結果は次のようにな
ります。TIMESTAMP '2008-05-14 13:00:00'
SET TIME ZONE INTERVAL '05:00' HOUR TO MINUTE;
SELECT CAST(DATE '2008-05-14' AS TIMESTAMP(0) AT -8);
次の SELECT 文を考慮します。
SELECT CAST(DATE '2008-05-14' AS TIMESTAMP(0) WITH TIME ZONE AT -8);
この場合、CAST の結果はタイムスタンプになります。このタイムスタンプはソース
の式値'2008-05-14'から生成され、デフォルトの時間'00:00:00'は指定されたセッ
ションのタイムゾーン変位(INTERVAL -'08:00' HOUR TO MINUTE)によって UTC に
調整されます。したがって、CAST の値は指定されたセッションのタイムゾーン変位
INTERVAL -'08:00' HOUR TO MINUTE により、UTC で'2008-05-14 08:00:00'にな
ります。
UTC での CAST の結果値はそのタイムゾーン変位 INTERVAL -'08:00' HOUR TO
MINUTE に調整されるため、SELECT 文の結果は、TIMESTAMP '2008-05-14
00:00:00-08:00'になります。現在のセッションのタイムゾーンは影響しません。
582
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
DATE から UDT への変換
例: タイムゾーン文字列に基づく DATE 値から TIMESTAMP 値の変換
この例では、現在のタイムスタンプは次のとおりです。
Current TimeStamp(6)
-------------------------------2010-03-09 19:23:27.620000+00:00
次の文では、DATE 値'2010-03-09'を、TIMESTAMP 値に変換します。ここでのタ
イムゾーン変位は、タイムゾーン文字列'America Pacific'に基づいています。
SELECT CAST(DATE '2010-03-09' AS TIMESTAMP(0) AT 'America Pacific');
問合わせの結果は、次のとおりです。
2010-03-09
------------------2010-03-09 08:00:00
関連トピック
データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
DATE から UDT への変換
目的
DATE データを UDT データに変換します。
CAST 構文
CAST
( date_expression
AS
UDT_data_type (
構文要素
date_expression
変換する日付式。
UDT_data_definition
式が変換されるデータ型。
SQL 関数、演算子、式および述部
583
第 13 章 データ型の変換
DATE から UDT への変換
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、FORMAT などのデータ属性句を CAST で使用できます。
使用上の注意
Teradata 変換構文を使った DATE から UDT への明示的な変換はサポートされていま
せん。
UDT の関与するデータ型の変換には、その UDT に適した CAST 定義が必要です。
UDT の CAST を定義するには、CREATE CAST 文を使用します。
DATE から UDT への暗黙的変換
暗黙のデータ型変換を実行するには、AS ASSIGNMENT 句を指定する適切な CAST 定
義(「使用上の注意」を参照)が存在する必要があります。
Teradata Database は、以下の操作に対して DATE から UDT への暗黙的変換を実行
します。
• UPDATE
• INSERT
• ストアド プロシージャ、外部ストアド プロシージャ、UDF、および UDM への引
数の引渡し。
• このマニュアル中の他の箇所に明記されている特定のシステム演算子と関数 (DBS
制御レコードの DisableUDTImplCastForSysFuncOp フィールドが TRUE に設定さ
れていない場合に限る)。
DATE から UDT への暗黙 CAST 定義が存在しないと、Teradata Database はその代用
になる他の CAST 定義を探します。
存在する暗黙 CAST 定義の組み合
わせ
Teradata Database の動作
Numeric-to-UDT 文字から UDT
CLOB 以外の文字
タイプ
X
数値から UDT への暗黙 CAST 定義を使用する。
数値から UDT への暗黙 CAST 定義が複数存在する場
合、Teradata Database は SQL エラーを戻します。
X
文字から UDT への暗黙 CAST 定義を使用する。
文字から UDT への暗黙の CAST 定義が複数存在する場
合、Teradata Database は SQL エラーを戻します。
584
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
INTERVAL から文字への変換
存在する暗黙 CAST 定義の組み合
わせ
Teradata Database の動作
Numeric-to-UDT 文字から UDT
CLOB 以外の文字
タイプ
X
X
エラーを報告する。
Teradata Database は DATE タイプを代用データ タイプに暗黙でキャストしてから、
暗黙 CAST 定義を使用して、その代用データ タイプから UDT へのキャストを行な
えるため、代用は有効です。
関連トピック
詳細は、以下を参照してください。
• データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
• CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>
を参照してください。
INTERVAL から文字への変換
目的
CAST 構文または Teradata 暗黙的変換構文を使用して、INTERVAL タイプをその正
規化された文字列表現に変換します。
INTERVAL から文字への変換は、CHAR および VARCHAR タイプしかサポートされ
ません。CLOB を変換先のタイプとすることはできません。
CAST 構文
CAST
( interval_expression
AS
A
character_data_type
)
A
CHARACTER SET
server_character_set
data_attribute
構文要素
interval_expression
変換する INTERVAL 式。
SQL 関数、演算子、式および述部
585
第 13 章 データ型の変換
INTERVAL から文字への変換
character_data_type
式が変換されるデータ型。
character_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
これは、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、CAST で文字データ属性句を使用できます。
Teradata 変換構文
interval_expression
(
character_data_type
A
data_attribute ,
)
A
,
data_attribute
CHARACTER SET
server_character_set
構文要素
interval_expression
変換する INTERVAL 式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
character_data_type
式が変換されるデータ型。
server_character_set
変換に使用するサーバー文字セット。CHARACTER SET 句を省略した場合は、ユー
ザー デフォルトのサーバー文字セットが使用されます。
586
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
INTERVAL から文字への変換
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
INTERVAL から固定長 CHARACTER への変換
ターゲットのデータ型が CHAR(n)である場合、n は、文字列定数によって示された
正規形式の値の長さと等しいかまたはそれよりも長くなければなりません。
n がその長さよりも長い場合には、正規表現を埋め込むために、後続の埋め込み文
字が追加されます。
n が小さすぎる場合には、文字列切り捨てエラーが戻されます。
INTERVAL から VARCHAR への変換
ターゲットのデータ 型が VARCHAR(n)である場合、n は、可変文字列定数によって
示された正規形式の値の長さと等しいかまたはそれよりも長くなければなりません。
n が小さすぎる場合には、文字列切り捨てエラーが戻されます。
関連トピック
データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
INTERVAL から固定長 CHARACTER への変換
ターゲットのデータ型が CHAR(n)である場合、n は、文字列定数によって示された
正規形式の値の長さと等しいかまたはそれよりも長くなければなりません。
n がその長さよりも長い場合には、正規表現を埋め込むために、後続の埋め込み文
字が追加されます。
n が小さすぎる場合には、文字列切り捨てエラーが戻されます。
INTERVAL から VARCHAR への変換
ターゲットのデータ 型が VARCHAR(n)である場合、n は、可変文字列定数によって
示された正規形式の値の長さと等しいかまたはそれよりも長くなければなりません。
n が小さすぎる場合には、文字列切り捨てエラーが戻されます。
関連トピック
データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
SQL 関数、演算子、式および述部
587
第 13 章 データ型の変換
INTERVAL から INTERVAL への変換
INTERVAL から INTERVAL への変換
CAST 構文
CAST
( interval_expression
AS
)
interval_data_type
interval_data_attribute
data_attribute
構文要素
interval_expression
変換する INTERVAL 式。
interval_data_type
式が変換される INTERVAL データ型。
interval_data_attribute
以下のデータ属性のいずれか 1 つ。
• NAMED
• TITLE
ANSI への準拠
ANSI を拡張したことで、CAST でデータ属性句を使用できます。
Teradata 変換構文
interval_expression
(
interval_data_type
,
)
, data_attribute
data_attribute
, interval_data_type
, data_attribute
構文要素
interval_expression
変換する INTERVAL 式。
interval_data_type
式が変換されるデータ型。
588
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
INTERVAL から INTERVAL への変換
data_attribute
以下のデータ属性のいずれか 1 つ。
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
これは、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
互換タイプ
両方のデータ タイプが同じ INTERVAL ファミリーのものでなければなりません。
Year-Month または Day-Time。タイプを混ぜることはできません。
INTERVAL データ タイプ
属している INTERVAL ファミリー
• INTERVAL YEAR
Year-Month
• INTERVAL YEAR TO MONTH
• INTERVAL MONTH
• INTERVAL DAY
Day-Time
• INTERVAL DAY TO HOUR
• INTERVAL DAY TO MINUTE
• INTERVAL DAY TO SECOND
• INTERVAL HOUR
• INTERVAL HOUR TO MINUTE
• INTERVAL HOUR TO SECOND
• INTERVAL MINUTE
• INTERVAL MINUTE TO SECOND
• INTERVAL SECOND
INTERVAL タイプの変換は、フィールドと精度とが異なる場合にのみ実行されます。
変換元と変換先のタイプの精度
変換先のデータ タイプの精度が変換元のデータ タイプの対応する精度よりも小さ
い場合には、この変換の結果は桁あふれエラーになる可能性があります。
変換元の最小有効値が変換先の値よりも低い場合、変換先の最小フィールドよりも
精度の低い変換元の値は無視されます。結果は切り捨てられます。この処理の回復
は、システムによって異なります 。
SQL 関数、演算子、式および述部
589
第 13 章 データ型の変換
INTERVAL から INTERVAL への変換
変換元の値の最大有効フィールドが変換先の値の最大有効フィールドよりも高い場
合、12 ヵ月、24 時間などの係数を使用して、変換元の高位フィールドが変換先の
最大有効フィールドのスカラー値の精度に変換されます。
比較されたスカラー値が、変換先のフィールドに定義された精度から桁あふれする
場合は、エラーが戻されます。
INTERVAL から INTERVAL への暗黙的変換
Teradata Database は、場合によっては、INTERVAL から INTERVAL データ型への暗
黙の変換を実行します。「DateTime 型の暗黙的変換」を参照してください。
INTERVAL タイプの変換が実行されるのは、両方のデータ タイプが同じ INTERVAL
ファミリーのものである場合だけです。Year-Month または Day-Time です。「互換
データ型」を参照してください。
例
例: 変換元の最小有効フィールドが変換先よりも低い場合
次の問合わせは‘3-11’を‘3’に変換します。変換元は INTERVAL YEAR(2)です。この変
換では切り捨てが行なわれます。
SELECT CAST(INTERVAL '3-11' YEAR TO MONTH AS INTERVAL YEAR(2));
例: 変換元の最小有効フィールドが変換先よりも低い場合
次の問合わせは‘135 12:37:25.26’を‘3252’に変換します。変換元は DAY(3) TO
SECOND(2)です。
SELECT CAST(INTERVAL '135 12:37:25.26' DAY(3) TO SECOND(2) AS INTERVAL
HOUR(4));
例: 変換元の最小有効フィールドが変換先よりも高い場合
次の問合わせは‘3’を‘3-00’に変換します。変換元は INTERVAL YEAR です。変換で
は、ゼロが挿入されます。
SELECT CAST(INTERVAL '3' YEAR AS INTERVAL YEAR TO MONTH);
例: 変換元の最小有効フィールドが変換先よりも高い場合
次の問合わせは、最後の HOUR 値、3240 を取得するための乗算 135 * 24 の追加変
換を行なった後に‘135 00:00:00.0’を‘3240:00:00.00’に変換します。変換元は DAY
のデータ タイプでした。
SELECT CAST(INTERVAL ' 135 00:00:00.0' DAY AS INTERVAL HOUR TO SECOND);
590
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
INTERVAL から数値への変換
例: 変換元の最大有効フィールドが変換先よりも高い場合
次の問合わせは、まず変換元の INTERVAL 値を‘135 12’として扱ってから、HOURS
を(135*24)+12=3252 として計算します。変換先値の精度が 4 未満である場合(エ
ラーが返される場合)を除き、問合せの結果は INTERVAL ‘3252’ HOUR となります。
変換元は DAY TO SECOND のデータ タイプでした。
SELECT CAST(INTERVAL '135 12:37:25.26' DAY TO SECOND AS INTERVAL HOUR);
例: 割り当て時に行なわれる暗黙的な型変換
INTERVAL YEAR TO MONTH 列を含む次の表について考えます。
CREATE TABLE TimeInfo
(YrToMon INTERVAL YEAR TO MONTH);
次のパラメータ化された要求を使用して列にデータを挿入し、INTERVAL YEAR 値
または INTERVAL MONTH 値を要求に渡す場合、Teradata Database はその値を挿
入する前に INTERVAL YEAR TO MONTH 値に暗黙的に変換します。
INSERT INTO TimeInfo
VALUES (?);
関連トピック
データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
INTERVAL から数値への変換
目的
フィールドを 1 つだけ持つ INTERVAL を絶対数値データ タイプに変換します。
この数値は、INTERVAL レコード内の単一数値フィールドの値です。
CAST 構文
CAST
( interval_expression
AS
)
numeric_data_type
data_attribute
構文要素
interval_expression
変換する INTERVAL 式。
SQL 関数、演算子、式および述部
591
第 13 章 データ型の変換
INTERVAL から数値への変換
numeric_data_type
式が変換されるデータ型。
numeric_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
ANSI を拡張したことで、CAST でデータ属性句を使用できます。
INTERVAL から数値への暗黙的変換
Teradata Database は、場合によっては、INTERVAL データ型から真数データ型への
暗黙の変換を実行します。「DateTime 型の暗黙的変換」を参照してください。
Teradata 変換構文
interval_expression
(
numeric_data_type
data_attribute ,
)
, data_attribute
構文要素
interval_expression
変換する INTERVAL 式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
numeric_data_type
式が変換されるデータ型。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、CAST でデータ属性句を使用できます。
592
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
INTERVAL から UDT への変換
INTERVAL から数値への暗黙的変換
Teradata Database は、場合によっては、INTERVAL データ型から真数データ型への
暗黙の変換を実行します。「DateTime 型の暗黙的変換」を参照してください。
例: CAST を使用した、INTERVAL MONTH 値の変換
次のテーブル定義を考えます。
CREATE TABLE sales_intervals
( sdate DATE
, sinterval INTERVAL MONTH
, stotals DECIMAL(5,0));
次の問合わせは、CAST を使用して sinterval 列の INTERVAL MONTH 値を INTEGER
に変換します。
SELECT stotals,
(EXTRACT (MONTH FROM sdate)) + (CAST(sinterval AS INTEGER))
FROM sales_intervals;
関連トピック
データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
INTERVAL から UDT への変換
目的
間隔データを UDT データに変換します。
CAST 構文
CAST
( interval_expression
AS
UDT_data_type (
構文要素
interval_expression
変換する INTERVAL 式。
UDT_data_definition
式が変換されるデータ型。
SQL 関数、演算子、式および述部
593
第 13 章 データ型の変換
INTERVAL から UDT への変換
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、FORMAT などのデータ属性句を CAST で使用できます。
使用上の注意
Teradata 変換構文を使った INTERVAL から UDT への明示的な変換はサポートされ
ていません。
UDT の関与するデータ型の変換には、その UDT に適した CAST 定義が必要です。
UDT の CAST を定義するには、CREATE CAST 文を使用します。
INTERVAL から UDT への暗黙的変換
暗黙のデータ型変換を実行するには、以下を指定する CAST 定義(「使用上の注意」
を参照)が必要です。
• AS ASSIGNMENT 句
• 暗黙 CAST の変換元と同じ INTERVAL ファミリー内にある次のようなソース デー
タ タイプ。
INTERVAL データ タイプ
属している INTERVAL ファミリー
• INTERVAL YEAR
Year-Month
• INTERVAL YEAR TO MONTH
• INTERVAL MONTH
• INTERVAL DAY
Day-Time
• INTERVAL DAY TO HOUR
• INTERVAL DAY TO MINUTE
• INTERVAL DAY TO SECOND
• INTERVAL HOUR
• INTERVAL HOUR TO MINUTE
• INTERVAL HOUR TO SECOND
• INTERVAL MINUTE
• INTERVAL MINUTE TO SECOND
• INTERVAL SECOND
CAST 定義の変換元データ タイプは、暗黙タイプ変換の変換元と正確に一致してい
る必要はありません。
Teradata Database は、以下の操作に対して INTERVAL から UDT への暗黙的変換を
実行します。
• UPDATE
• INSERT
594
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
数値から文字への変換
• ストアド プロシージャ、外部ストアド プロシージャ、UDF、および UDM への
引数の引渡し。
• このマニュアル中の他の箇所に明記されている特定のシステム演算子と関数 (DBS
制御レコードの DisableUDTImplCastForSysFuncOp フィールドが TRUE に設定さ
れていない場合に限る)。
関連トピック
データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>
を参照してください。
数値から文字への変換
目的
数値データ タイプを文字データ タイプに変換します。
CAST 構文
CAST
(numeric_expression
AS
character_data_type
)
data_attribute
構文要素
numeric_expression
数値式。
character_data_type
式が変換されるデータ型。
data_attribute
以下のデータ属性のいずれか 1 つ。
• 文字セット
• FORMAT
• NAMED
• TITLE
使用するサーバー文字セットを示すために CHARACTER SET 句が指定されていない
場合、ユーザーのデフォルトのサーバー文字セットが使用されます。
SQL 関数、演算子、式および述部
595
第 13 章 データ型の変換
数値から文字への変換
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、FORMAT などのデータ属性句を CAST で使用できます。
Teradata 変換構文
numeric_expression
(
character_data_type
A
data_attribute ,
)
A
,
data_attribute
CHARACTER SET
server_character_set
構文要素
numeric_expression
数値式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
character_data_type
式が変換されるデータ型。
使用するサーバー文字セットを示すために character_data_definition が CHARACTER
SET 句を指定していない場合、ユーザー デフォルトのサーバー文字セットが使用さ
れます。
server_character_set
変換に使用するサーバー文字セット。CHARACTER SET 句を省略した場合は、ユー
ザー デフォルトのサーバー文字セットが使用されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
596
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
数値から文字への変換
数値から文字への暗黙的な変換
SQL 文字列関数の数値引数が CHAR または VARCHAR 文字タイプに暗黙に変換さ
れ、数値引数の形式に以下の書式設定文字が含まれる場合、文字タイプのサーバー
文字セットは UNICODE になります。
• G
• L
• F
• U
• O
• I
• A
• C
• D
• N
その他の書式の場合はいずれも、サーバー文字セットは LATIN になります。
数値の項目を CLOB タイプまたは GRAPHIC 文字に変換することはできません。
CAST と Teradata 変換構文の違い
CAST 関数での処理は、以下のとおりです。
1 数値のデフォルトまたは指定された書式を使用して数値を文字列に変換します。
2 前後の埋め込み文字を取り除きます。
3 変換先の文字列長だけ必要に応じて右側に拡張します。
4 変換先の文字列長に合わせるために非埋め込み文字の切り捨てが必要な場合に
は、文字列切り捨てエラーを報告します。
CAST の操作は、Teradata SQL の変換と以下の点で異なります。
• 結果は左揃えになります。列表示は、位置合わせされません。
• 有効データが切り捨てられた場合には、文字列切り捨てエラーが発生します。
数値データから文字データへ明示的に変換するために Teradata 構文を使用する(す
なわち、CAST を使用しない)場合には、 警告が必要です。
処理は、以下のようになります。
1. 数値のデフォルトまたは指定された FORMAT を使用して数値を文字列に変換し
ます。
前後の埋め込み文字は、切り捨てられません。
2. 必要であれば、埋め込み文字で右側に拡張するか右側から切り捨てて、変換先
の長さ指定に適合させます。
非埋め込み文字が切り捨てられた場合には、文字列切り捨てエラーは報告され
ません。
SQL 関数、演算子、式および述部
597
第 13 章 データ型の変換
数値から文字への変換
サポートされる文字タイプ
数値から文字への変換は、CHAR および VARCHAR タイプしかサポートされません。
数値タイプを CLOB タイプに変換することはできません。
使用上の注意
数値タイプ値を文字列に変換するには、その文字の記述節にデータのタイプ宣言を
含めなければなりません。FORMAT 句それ自体は、数値タイプを文字タイプの値に
変換するために使用することはできません。この句は、結果の値の表示方法を制御
するためにだけ使用することができます。
文字定義に FORMAT 句が含まれていない場合には、元の数値に関連付けられている
書式によってデータの表示方法が決定されます。
数値から文字への Teradata 変換構文の書式では、文字表現への変換のために明示的
またはデフォルトで FORMAT を使用します。FORMAT は、文字列が示している長さ
に応じて、切り捨てたり、埋め込み文字を入れたりします。このために、有効数字
が失われることがあります。
数値タイプから GRAPHIC サーバー文字セットを使用する文字タイプに変換しようと
すると、エラーが発生します。
一般的には、数値は、文字データとしてではなく数値データとして格納する必要が
あります。たとえば、次のコードでテーブルを作成するとします。
CREATE TABLE job AS
(job_code CHAR(6) PRIMARY KEY
,description CHAR(70) );
その後、次の問合わせが行なわれたとします。
SELECT job_code, description
FROM job
WHERE job_code = 1234;
この場合、問題となるのは、'1234'、'1234'、'01234'、'001234'、'+1234'などが
すべて有効な数値リテラル値の文字表記であり、システムでハッシュに使用する値
を識別できないことです。したがって、システムは 、比較できるように、すべての
job_code の値を相当する数値表現に変換するために全テーブル走査を実行しなけれ
ばなりません。
例
例: INTEGER データ型から文字への変換
T1.Field1 には、デフォルト書式が'-(10)9'の数値 INTEGER データ タイプがありま
す。ユーザーには、123456 などの値があり、999999 を超える値はありません。
INTEGER 書式として定義されている値は、CHAR(8)に変換されます。
598
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
数値から文字への変換
次の例は、この数値から文字への変換を実行するための Teradata の構文を示します。
SELECT Field1(CHAR(8)) FROM T1;
結果は、値 123456 に対し'123'を返します。結果には 5 つの先行の埋め込み文字
が含まれ、有効桁が切り捨てられます。
例: 給与の変換
データは次の給与の記述を基に、次の表に示すように変換されます(Δ = 埋め込み文
字)。
Salary (DECIMAL(8,2), FORMAT '$$$,$$9.99')
データ
変換
結果
20000.00
Salary (CHAR(10))
'$20,000.00'
9000.00
Salary (CHAR(10))
'Δ $9,000.00'
20000.00
Salary (FORMAT'9(5)') (CHAR (5))
'20000'
9000.00
CAST (Salary AS CHAR(10))
'$9,000.00Δ '
結果の文字列は、埋め込み文字で拡張されるか、または切り捨てられて、指定され
た文字の記述に従います。
例: 従業員数の変換
EmpNo がデフォルトの書式が'9(6)'の SMALLINT として定義されたとします。
EmpNo の値は 12501 であると想定します。
SELECT EmpNo(CHAR(5)) FROM Employee;
は'1250’を戻します。ここでは先行の埋め込み文字が含まれ、下位桁がありません。
同じ変換のために使用される CAST 関数は、数値を文字表現に変換し、前にある埋
め込み文字を切り捨て、最後に右側に対して切り捨てるか埋め込みます。例えば、
以下の SELECT 文は'12501'を戻します。
SELECT CAST (EmpNo AS CHAR(5)) FROM Employee;
関連トピック
詳細は、以下を参照してください。
• データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
• 重要データが切り捨てられる数値から文字への変換の例については、「例:
INTEGER データ型から文字への変換」を参照してください。
• データ タイプ書式、 書式設定文字、FORMAT 句については、< SQL データ型と
リテラル、B035-1143>の「データ タイプの書式および書式句」を参照してくだ
さい。
SQL 関数、演算子、式および述部
599
第 13 章 データ型の変換
数値から DATE への変換
数値から DATE への変換
目的
数値式を DATE データ タイプに変換します。
CAST 構文
CAST
(
numeric_expression
AS
DATE
)
data_attribute
構文要素
numeric_expression
数値式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
使用するサーバー文字セットを示すために CHARACTER SET 句が指定されていない
場合、ユーザーのデフォルトのサーバー文字セットが使用されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
Teradata 変換構文
numeric_expression
(
DATE
data_attribute ,
)
, data_attribute
構文要素
numeric_expression
数値式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• 文字セット
• FORMAT
• NAMED
600
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
数値から DATE への変換
• TITLE
FORMAT 句を指定すると、代替書式が可能になります。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
数値から日付への変換
お勧めしませんが、数値を明示的に日付に変換することは可能です。
Teradata Database は、以下の公式に基づいて、各日付値を 4 バイト整数で格納し
ます。
(year - 1900) * 10000 + (month * 100) + day
たとえば、1985 年 12 月 31 日は整数 851231、1776 年 7 月 4 日は-1239296、
2041 年 3 月 30 日は 1410330 としてそれぞれ格納されます。
以下の表は、列への挿入時に数値日付が解釈される方法を示しています。特に、3
番目の日付の変換に注目してください。これは、1990 年 12 月 01 日を想定した日
付と思われます。
数値
変換先の日付値
901201
1990-12-01
1001201
2000-12-01
19901201
3890-12-01
この公式は 1900 年代の 2 桁の日付に最適なものとしていることに注意する必要が
あります。1900 年代以外の年代にこの書式を使うことは難しいので、代わりに日
付は ANSI 日付定数で指定するのが最善です。
指定可能な値の範囲
指定可能な日付値は、西暦 0001 年 1 月 1 日(-18989899)~西暦 9999 年 12 月 31
日(80991231)です。
数値が有効な日付を表わしていない場合は、エラーが報告されます。
数値から DATE への暗黙タイプ変換
数値タイプを DATE タイプの割り当てで指定することもできます。ただし、この方
法はお勧めできません。Teradata Database は割り当て前に数値から DATE タイプへ
の暗黙的な変換を実行します。数値タイプの値には、有効な値を使用する必要があ
ります。
SQL 関数、演算子、式および述部
601
第 13 章 データ型の変換
数値から INTERVAL への変換
ただし、数値タイプのオペランドと DATE タイプのオペランドが関与する比較操作
の場合、Teradata Database は DATE タイプを数値タイプに変換します。数値タイプ
と DATE タイプを比較して、2 つの DATE タイプの間で比較が行なわれることを期待
する場合、明示的に数値タイプを DATE タイプに変換する必要があります。
例: 数値 INTEGER 式から日付形式への変換
この例では、数値 INTEGER 式を日付形式にキャストします。
SELECT CAST (1071201 AS DATE);
セッションの DateForm モードが ANSIDate に設定されている場合、結果はこのよう
になります。
1071201
---------2007-12-01
関連トピック
詳細は、以下を参照してください。
• 比較操作でのオペランドの暗黙タイプ変換については、比較オペランドの暗黙的
なタイプ変換を参照してください。
• DateTime タイプに関連した割り当てのデータ型互換性規則については、間隔デー
タ タイプの割り当て規則を参照してください。
• データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
数値から INTERVAL への変換
目的
数値データを、単一の日時フィールドを持つ INTERVAL 値に変換します。
CAST 構文
CAST
( numeric_expression
AS
)
interval_data_type
data_attribute
構文要素
numeric_expression
数値式。
602
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
数値から INTERVAL への変換
interval_data_type
式が変換されるデータ型。
interval_data_attribute
以下のデータ属性のいずれか 1 つ。
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、CAST で間隔データ属性句を使用できます。
Teradata 変換構文
numeric_expression
(
interval_data_type
data_attribute ,
)
, data_attribute
構文要素
numeric_expression
数値データ タイプを含む式または既存のフィールド。
data_attribute
以下のデータ属性のいずれか 1 つ。
• NAMED
• TITLE
interval_data_type
式が変換されるデータ型。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
数値データは、1 つの日時フィールドを使用して INTERVAL 値に変換されます。
数値は、INTERVAL に許可された値の範囲内にある場合には、INTERVAL の単一
フィールドとして使用されます。そうでない場合には、オーバーフロー エラーが戻
されます。
SQL 関数、演算子、式および述部
603
第 13 章 データ型の変換
数値から数値への変換
数値から INTERVAL への暗黙的変換
Teradata Database は、場合によっては、真数データ型から INTERVAL データ型への
暗黙の変換を実行します。「DateTime 型の暗黙的変換」を参照してください。
例: 数値データから INTERVAL 値への変換
以下の問合わせは、'-5'を返します(先行の埋め込み文字が 3 つ付く)。
SELECT CAST(-5 AS INTERVAL YEAR(4));
関連トピック
データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
数値から数値への変換
目的
あるデータ タイプが定義された数値式を異なる数値データ タイプに変換します。
CAST 構文
CAST
( numeric_expression
AS
)
numeric_data_type
data_attribute
data_attribute
構文要素
numeric_expression
数値式。
numeric_data_type
式が変換されるデータ型。
numeric_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
604
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
数値から数値への変換
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI SQL の拡張として、CAST では、numeric_expression の代替書式を可能にする
FORMAT 句などのデータ属性を使用することができます。
Teradata 変換構文
CAST
( numeric_expression
AS
)
numeric_data_type
data_attribute
data_attribute
構文要素
numeric_expression
数値式。
numeric_data_type
式が変換されるデータ型。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
数値から数値への暗黙的な変換
数値の項目は、算術または比較操作が実行される前に、同じ数値タイプに変換され
ます。戻される結果は、基底となる同じタイプです。
たとえば、INTEGER 値が FLOAT 値に加算される前に、INTEGER 値は結果のデー
タ タイプである FLOAT に変換されます。
SQL 関数、演算子、式および述部
605
第 13 章 データ型の変換
数値から数値への変換
FLOAT/REAL/DOUBLE PRECISION への変換
浮動小数点の数値は正確な値ではないため、DECIMAL 値および整数値を FLOAT 値
に変換すると、精度が失われたり、正確には表わせない数値を生成するという結果
を招くことがあります。例えば、値 0.1 を FLOAT にキャストすると、その値は厳密
には 0.1 ではなくなります。
変換時の切り捨ておよび端数処理
DECIMAL/NUMERIC の BIGINT、INTEGER、BYTEINT、または SMALLINT への変換
は、小数部分を切り捨てます。DECIMAL への変換は、四捨五入された結果になりま
す。範囲を超えた場合は、操作が失敗することがあります。
FLOAT/REAL/DOUBLE PRECISION への変換では、使用可能な最近似値に端数処理
(丸め)されます。小数や、9,007,199,254,740,992 よりも大きな数は、どちらも正
確に表現できる保証はありません。そのため、表現可能な最近似値が選択されます。
最近似値と見なされる 2 つの表現可能な値があるときには、最小有効ビットが 0 で
表わされる値が選択されます。例えば、0.1 を FLOAT 列に格納すると、その値はわ
ずかに大きな値に丸められます
(0.1000000000000000055511151231257827021181583404541015625)。
切り上げ/切り捨てについては、< SQL データ型とリテラル、B035-1143>の
「DECIMAL/NUMERIC データ タイプ」を参照してください。
数値変換の例を、いくつか示します。
値
変換後
結果
20000.99
INTEGER
20000
20000.99
DECIMAL(6,1)
20001.0
20000.99
DECIMAL(4, 1)
エラー
200000
SMALLINT
エラー
DECIMAL タイプのサイズ制限があるアプリケーションでの CAST の使用
一部のアプリケーションでは、DECIMAL タイプが 15 桁以下にならなければなりま
せん。
こうした要件を持つアプリケーションが 15 桁を上回る DECIMAL の列にアクセスし
たり、15 桁を上回る DECIMAL の結果を生じる可能性のある式を使用しなければな
らなくなることがあります。DECIMAL 型サイズの要件を満たすには、CAST を使用
して DECIMAL 型を 15 または 15 未満の桁に変換します。
たとえば、次のような式を考慮してみます。A、B、C は、DECIMAL(8,2)として定義
された列です。
SELECT (A*B)/C FROM table1;
606
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
数値から数値への変換
結果値は 15 桁を下回る可能性がありますが、A*B は最大 18 桁になります。
結果が必ず 16 桁を下回るようにするには、CAST を使用します。
SELECT CAST ((A*B)/C AS DECIMAL(15,2)) FROM table1;
数値の桁あふれを防ぐための CAST の使用
Teradata SQL のコンパイラの動作の性質上、大きな値が予期される場合は必ず式の
引数に CAST を使用するのは重要なことです。
たとえば、f1 が DECIMAL(14,2)と定義されており、これを整数倍する、あるいは
SUM(f1)を計算するとします。
この場合に、以下の演算について考慮してみます。
CAST(f1 AS DECIMAL(18,2))*100
または
SUM(CAST(f1 AS DECIMAL(18,2)))
上記の方法は、正しい結果集合を得るための適切な方法です。
一方、次のように式の結果をキャストするとします。
CAST(f1*100 AS DECIMAL(18,2))
または
CAST(SUM(f1) AS DECIMAL(18,2)
このとき、計算時(および CAST が作成される前)に、望むような結果ではない、オー
バーフローが発生することがあります。
例
例: 数値 INTEGER 式のキャスト
この例では、IntegerField という数値 INTEGER 式を DECIMAL(7,2)にキャストしま
す。
CAST (IntegerField AS DECIMAL (7,2))
例: FORMAT 句を変更して数値を表示する
FORMAT 句を使用して列に定義された基礎となるデータ タイプを変更することはで
きませんが、その句を使用して、数値の表示を変更することはできます。
たとえば、両方とも DECIMAL (7,2)と定義されている列の Wholesale と Retail の
フィールド値がそれぞれ 12467.75 と 21500.50 の場合、次の式
SQL 関数、演算子、式および述部
607
第 13 章 データ型の変換
数値から UDT への変換
CAST (Wholesale - Retail AS FORMAT '-99999')
の結果は、次のとおりです。
-09033
FORMAT 句は、レコード モード(クライアント システムの内部書式 )でクライアン
ト システムへ戻されるデータには影響を与えません 。
前の例で、クライアント システムへ戻される値は 、依然として小数の書式にパック
されています(すなわち、-9032.75)。
CAST での FORMAT の使用は、ANSI 標準の Teradata 拡張機能です。
関連トピック
詳細は、以下を参照してください。
• データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
• バイナリ算術式の暗黙タイプ変換については、2 項算術演算子の結果のデータ タ
イプを参照してください。
• 比較操作での暗黙的な型の変換の詳細については、比較オペランドの暗黙的なタ
イプ変換を参照してください。
数値から UDT への変換
目的
数値データを UDT データに変換します。
CAST 構文
CAST
( numeric_expression
AS
UDT_data_type (
構文要素
numeric_expression
数値式。
UDT_data_definition
式が変換される UDT の型(FORMAT、NAMED、または TITLE データ属性句が続く)。
608
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
数値から UDT への変換
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、FORMAT などのデータ属性句を CAST で使用できます。
使用上の注意
Teradata 変換構文を使った数値から UDT への明示的な変換はサポートされていま
せん。
UDT の関与するデータ型の変換には、その UDT に適した CAST 定義が必要です。
UDT の CAST を定義するには、CREATE CAST 文を使用します。CREATE CAST の詳
細は、<SQL データ定義言語 - 構文規則および例、B035-1144>を参照してください。
数値から UDT への暗黙的変換
Teradata Database は、以下の操作に対して数値から UDT への暗黙的変換を実行し
ます。
• UPDATE
• INSERT
• ストアド プロシージャ、外部ストアド プロシージャ、UDF、および UDM への
引数の引渡し。
• このマニュアル中の他の箇所に明記されている特定のシステム演算子と関数 (DBS
制御レコードの DisableUDTImplCastForSysFuncOp フィールドが TRUE に設定さ
れていない場合に限る)。
暗黙のデータ型変換を実行するには、AS ASSIGNMENT 句を指定する適切な CAST
定義(「使用上の注意」を参照)が存在する必要があります。
キャスト定義のソース数値型は、暗黙の変換のソース数値型と正確に一致している
必要はありません。Teradata Database は、BYTEINT、SMALLINT、INTEGER、
BIGINT、DECIMAL/NUMERIC、NUMBER、または REAL/FLOAT/DOUBLE ターゲッ
ト型を指定する暗黙的なキャスト定義を使用することができます。
別々の数値型から UDT への変換で複数の暗黙的なキャスト定義が存在する場合、
Teradata Database は優先順位の最も高い数値型の暗黙的なキャスト定義を使用しま
す。以下のリストでは、数値型の優先順位が最低から最高の順に並べられています。
•
•
•
•
•
•
•
BYTEINT
SMALLINT
INTEGER
BIGINT
DECIMAL/NUMERIC
NUMBER
REAL/FLOAT/DOUBLE
SQL 関数、演算子、式および述部
609
第 13 章 データ型の変換
Period から文字への変換
数値から UDT への暗黙 CAST 定義が存在しない場合、Teradata Database は代用可
能なその他の CAST 定義を検索します。
存在する暗黙 CAST 定義の組 Teradata Database の動作
み合わせ
DATE-toUDT
Character-toUDT
X
DATE から UDT への暗黙 CAST 定義を使用する。
X
文字から UDT への暗黙 CAST 定義を使用する。
CLOB は文字タイプにはなりません。
文字から UDT への暗黙の CAST 定義が複数存在する場合、
Teradata Database は SQL エラーを戻します。
X
X
エラーを報告する。
Teradata Database は数値型を代用データ型に暗黙的にキャストしてから、暗黙的な
キャスト定義を使用して、その代用データ型から UDT へのキャストを行なえるた
め、代用は有効です。
関連トピック
データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
Period から文字への変換
目的
Period データ タイプを正規形式の文字列表現へ変換します。
Period から文字への変換は、CHAR および VARCHAR タイプのみサポートされます。
CLOB を変換先のタイプとすることはできません。
CAST 構文
CAST
( period_expression
AS
A
character_data_type
)
A
CHARACTER SET
610
server_character_set
data_attribute
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
Period から文字への変換
構文要素
period_expression
変換される PERIOD 式。
character_data_type
式が変換されるデータ型。
server_character_set
変換に使用するサーバー文字セット。CHARACTER SET 句を省略した場合は、ユー
ザー デフォルトのサーバー文字セットが使用されます。
character_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
ANSI を拡張したことで、CAST で文字データ属性句を使用できます。
Teradata 変換構文
period_expression
(
character_data_type
A
data_attribute ,
)
A
,
data_attribute
CHARACTER SET
server_character_set
構文要素
period_expression
変換される PERIOD 式。
character_data_type
式が変換されるデータ型。
data_attribute
以下のデータ属性のいずれか 1 つ。
SQL 関数、演算子、式および述部
611
第 13 章 データ型の変換
Period から文字への変換
• FORMAT
• NAMED
• TITLE
server_character_set
変換に使用するサーバー文字セット。CHARACTER SET 句を省略した場合は、ユー
ザー デフォルトのサーバー文字セットが使用されます。
使用上の注意
期間式は、CAST 関数や Teradata キャスト構文を使用するか、フィールド モードの
出力を形成するときに、文字列表現としてキャストできます。キャストする期間式
に関連付けられた書式に書式化した文字列の最大長を L とします。結果の文字列は、
期間式の開始境界と終了境界を表わす 2 つの文字列を含みます。それぞれの最大長
は L であり、それぞれが単一引用符(' ')で囲まれ、カンマとスペース(, )で区切られ、
左右の括弧[( )]で囲まれます。したがって、結果の文字列の最大長は 2*L+8 になり
ます。 これが、例えば、フォーマットが月の正式名称を含み、境界に対する特定の
月が 7 月(July)の場合には、実際の長さが K とした場合、その長さは 2*L+8 より小
さくなり、変換先タイプは CHARACTER(n)または VARCHAR(n)となります。
• n が K に等しい場合、期間は長さが K の結果の文字列にキャストされます。
• n が K より大きく、変換先が VARCHAR(n)の場合、期間は長さが K の結果の文字
列にキャストされます。
• n が K より大きく、変換先が CHARACTER(n)の場合、期間は結果の文字列にキャ
ストされ、長さが n になるまで末尾の埋め込み文字が追加されます。
• n が K より小さく、セッションが ANSI モードの場合、切り捨てエラーが報告さ
れます。
• n が K より小さく、セッションが Teradata モードの場合、長さを n に切り捨てた
文字列が返されます。
TIME 要素タイプと TIMESTAMP 要素タイプを持つ Period データ タイプのデータの
場合、期間式の UTC 値はデータの値のタイムゾーンに調整されます。また、データ
の値にタイムゾーンがない場合は、現在のセッションのタイムゾーンに調整されま
す。UTC からの変換の例外は、PERIOD(TIMESTAMP(n))値の終了境界が
UNTIL_CHANGED を表わすために使用される最大値と等しい場合です。この場合、
値は変更されません。このような調整を行なっために、結果の終了境界が開始境界
より小さいように見える場合がありますが、UTC では終了境界は開始境界より大き
くなっています。これが発生する理由は、TIME データ タイプの時間値が 24 時間単
位でラップされる(つまり、時間値は「モジュール 24」を使用して取得される)ため
です。
例: PERIOD データ型からその正規化された文字列表現への変換
pts は、PERIOD '(2005-02-02 12:12:12.34, 2006-02-03 12:12:12.34)'の値を持つ
テーブル t の PERIOD(TIMESTAMP(2))列だとします。
612
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
Period から DATE への変換
以下の例では、CAST 関数を使用して PERIOD(TIMESTAMP(2))列を
CHARACTER(52)としてキャストします。
SELECT CAST(pts AS CHARACTER(52)) FROM t;
次の結果が返されます。
('2005-02-02 12:12:12.34', '2006-02-03 12:12:12.34')
関連トピック
データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
Period から DATE への変換
目的
Period データを DATE 値に変換します。
CAST 構文
CAST
( expression
AS
ansi_sql_data_type
)
data_definition_list
period_expression
変換される PERIOD 式。
date_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、CAST で DATE データ属性句を使用できます。
SQL 関数、演算子、式および述部
613
第 13 章 データ型の変換
Period から Period への変換
使用上の注意
PERIOD(DATE)値または PERIOD(TIMESTAMP(n) [WITH TIME ZONE])値は、CAST 関
数を使用すると DATE としてキャストできます。変換元の最後の値は、変換元の開
始境界と等しくなければなりません。そうでないと、エラーが報告されます。
変換元のタイプが PERIOD(DATE)の場合、結果は変換元の開始境界になります。
変換元のタイプが PERIOD(TIMESTAMP(n) [WITH TIME ZONE])の場合、結果は現在
のセッションのタイムゾーンに調整した後の変換元の開始境界の日付部分になります。
変換元のタイプが PERIOD(TIME(n) [WITH TIME ZONE])の場合、エラーが報告され
ます。
例: PERIOD データから DATE 値への変換
pd がテーブル t 内の PERIOD(DATE)列で、PERIOD '(2005-02-02, 2005-02-03)'の値
を持つとします。
以下の例では、PERIOD(DATE)列が DATE としてキャストされます。結果は、列の開
始境界になります。
SELECT CAST(pd AS DATE) FROM t;
次の結果が返されます。
2005-02-02
関連トピック
データ型およびデータ属性について、詳細は< SQL データ型とリテラル、B035-1143>
を参照してください。
Period から Period への変換
CAST 構文
CAST
( period_expression
AS
)
period_data_type
data_attribute
data_attribute
614
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
Period から Period への変換
構文要素
period_expression
変換される PERIOD 式。
period_data_type
式が変換されるデータ型。
period_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、CAST でデータ属性句を使用できます。
互換タイプ
以下の表では、変換元と変換先のタイプがどちらも Period データ タイプの場合に、
許容される組み合わせを示します。
変換元タイプ
変換先タイプ
PERIOD (DATE)
PERIOD (DATE)
PERIOD(TIMESTAMP[(m)] [WITH TIME ZONE])
PERIOD(TIME[(n)] [WITH
TIME ZONE])
PERIOD(TIME[(m)] [WITH TIME ZONE])
m はターゲットの精度です。この m はソースの精度 n 以上で
なければなりません。m のデフォルトは 6 です。
PERIOD(TIMESTAMP[(m)] [WITH TIME ZONE])
m はターゲットの精度です。この m はソースの精度 n 以上で
なければなりません。m のデフォルトは 6 です。
PERIOD(TIMESTAMP[(n)]
WITH TIME ZONE)
PERIOD (DATE)
PERIOD(TIME[(m)] [WITH TIME ZONE])
m はターゲットの精度です。この m はソースの精度 n 以上で
なければなりません。m のデフォルトは 6 です。
PERIOD(TIMESTAMP[(m)] [WITH TIME ZONE])
SQL 関数、演算子、式および述部
615
第 13 章 データ型の変換
Period から Period への変換
変換元タイプ
変換先タイプ
m はターゲットの精度です。この m はソースの精度 n 以上で
なければなりません。m のデフォルトは 6 です。
PERIOD(DATE)から PERIOD(TIMESTAMP)
PERIOD(DATE)値は、CAST 関数を使用すると PERIOD(TIMESTAMP[(n)] [WITH TIME
ZONE])としてキャストできます。
結果要素の UTC 値は、日付部分を対応する変換元の要素に、時間部分を 0 にそれぞ
れ設定して作成されたタイムスタンプからの現在のセッションのタイムゾーンに対
する調整後に取得されます。変換先タイプが PERIOD(TIMESTAMP[(n)] WITH TIME
ZONE)の場合、結果のタイムゾーン フィールドは両方とも現在のセッションのタイ
ムゾーン変位に設定されます。ただし、これには例外があります。変換元の終了境
界が最大 DATE 値の場合、結果の終了境界は最大の TIMESTAMP 値に設定されます。
PERIOD(TIME)から PERIOD(TIME)
PERIOD(TIME(n) [WITH TIME ZONE])値は、CAST 関数を使用すると
PERIOD(TIME[(n)] [WITH TIME ZONE])としてキャストできます。
変換元の UTC 値が、結果の UTC 値にコピーされます。変換先のタイプに WITH TIME
ZONE が指定されていて、変換元にタイムゾーンが含まれている場合には、変換元
のタイムゾーン変位が対応する結果要素にコピーされます。変換元にタイムゾーン
が含まれていない場合には、現在のセッションのタイムゾーン変位が両方の要素に
コピーされます。例えば、現在のセッションのタイムゾーン変位が INTERVAL "08:00" HOUR TO MINUTE で、変換元の PERIOD(TIME(0) WITH TIME ZONE)の値
が PERIOD '(12:12:12+08:00, 12:12:13+08:00)'だとします。この変換元の UTC 値
は、('04:12:12', '04:12:13')になります。結果の UTC 値は、この値に設定されます。
この結果を出力するときに、UTC 値が現在のセッションのタイムゾーンに調整され、
結果は('20:12:12', '20:12:13')になります。
注: UTC での CURRENT_DATE が DATE '2006-07-28'だとすると、この値は実際には
前日のものになります。これがタイムスタンプ要素だとすると、出力の開始境界は
'2006-07-27 20:12:12'になるでしょう。
変換先の精度が変換元の精度より高い場合、秒の小数桁の末尾にゼロが追加されま
す。変換先の精度が変換元の精度より低い場合、エラーが報告されます。
PERIOD(TIME)から PERIOD(TIMESTAMP)
PERIOD(TIME(n) [WITH TIME ZONE])値は、CAST 関数を使用すると
PERIOD(TIMESTAMP[(n)] [WITH TIME ZONE])としてキャストできます。
変換元の時間値は、対応する UTC 値を基にセッションのタイムゾーンに調整されま
す。各結果要素の日付部分は、CURRENT_DATE に設定されます。時、分、秒は、前
616
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
Period から Period への変換
述の調整を実行した後の変換元からコピーされ、タイムスタンプ値は対応する UTC
値に変換されます。
変換先のタイプに WITH TIME ZONE が指定されていて、変換元にタイムゾーンが
含まれている場合には、変換元のタイムゾーン変位が対応する結果要素にコピーさ
れます。変換元にタイムゾーンが含まれていない場合には、現在のセッションのタ
イムゾーン変位が両方の要素にコピーされます。
変換先の精度が変換元の精度より高い場合、秒の小数桁の末尾にゼロが追加されま
す。変換先の精度が変換元の精度より低い場合、エラーが報告されます。
PERIOD(TIMESTAMP)から PERIOD(DATE)
PERIOD(TIMESTAMP(n) [WITH TIME ZONE])値は、CAST 関数を使用すると
PERIOD(DATE)としてキャストできます。
結果要素は、変換元の境界を現在のセッションのタイムゾーンに応じて調整した後、
それぞれが対応する変換元の境界の日付部分に設定されます(変換元の終了境界が最
大値の場合、その終了境界に対する調整は実行されません)。タイムゾーンの調整に
よって日付が変わる場合には、変更後の値が使用されます。結果の日付部分が同じ
になる場合には、エラーが報告されます。
PERIOD(TIMESTAMP)から PERIOD(TIME)
PERIOD(TIMESTAMP(n) [WITH TIME ZONE])値は、CAST 関数を使用すると
PERIOD(TIME[(n)] [WITH TIME ZONE])としてキャストできます。
変換元の開始および終了 UTC 値の日付部分は、同じ DATE 値でなければなりませ
ん。そのようにしないと、エラーが報告されます。結果要素の時間部分は、対応す
る変換元の時間部分からコピーされます。変換先のタイプに WITH TIME ZONE が
指定されていて、変換元にもタイムゾーンが含まれている場合には、変換元のタイ
ムゾーン変位が対応する結果要素にコピーされます。変換元にタイムゾーンが含ま
れていない場合には、現在のセッションのタイムゾーン変位が両方の要素にコピー
されます。
変換先の精度が変換元の精度より高い場合、秒の小数桁の末尾にゼロが追加されま
す。変換先の精度が変換元の精度より低い場合、エラーが報告されます。
PERIOD(TIMESTAMP)から PERIOD(TIMESTAMP)
PERIOD(TIMESTAMP(n) [WITH TIME ZONE])値は、CAST 関数を使用すると
PERIOD(TIMESTAMP[(n)] [WITH TIME ZONE])としてキャストできます。
結果の日付と時間の部分は、対応する変換元の日付と時間の部分に設定されます。
変換先のタイプに WITH TIME ZONE が指定されていて、変換元にもタイムゾーン
が含まれている場合には、変換元のタイムゾーン変位が対応する結果要素にコピー
されます。変換元にタイムゾーンが含まれない場合には、現在のセッションのタイ
SQL 関数、演算子、式および述部
617
第 13 章 データ型の変換
Period から Period への変換
ムゾーン変位が両方の要素にコピーされます。ただし例外として、変換元の終了境
界が最大値の場合は、結果の終了境界のタイムゾーンは+00:00 になります。
変換先の精度が変換元の精度より高い場合、秒の小数桁の末尾にゼロが追加されま
す。変換先の精度が変換元の精度より低い場合、エラーが報告されます。
例
例: PERIOD(DATE)から PERIOD(TIMESTAMP)
p は、PERIOD '(2005-02-02, 2006-02-03)'の値を持つテーブル t1 の PERIOD(DATE)
列で、現在のセッションのタイムゾーン変位が INTERVAL -'08:00' HOUR TO MINUTE
だとします。
以下の例では、PERIOD(DATE)列を PERIOD(TIMESTAMP(6))としてキャストします。
日付部分は対応する結果要素のために変換元から取得され、時間部分にはゼロが設
定されます。
SELECT CAST(p AS PERIOD(TIMESTAMP(6))) FROM t1;
次の結果が返されます。
('2005-02-02 00:00:00.000000', '2006-02-03 00:00:00.000000')
例: 変換元の最小有効フィールドが変換先よりも低い場合
p は、PERIOD '(12:12:12.45, 13:12:12.67)'の値を持つテーブル t の
PERIOD(TIME(2))列で、現在のセッションのタイムゾーン変位が INTERVAL -'08:00'
HOUR TO MINUTE だとします。
以下の例では、PERIOD(TIME(2))列を PERIOD(TIME(6) WITH TIME ZONE)として
キャストします。時間部分は、対応する結果要素の精度が 6 になるように秒の小数
桁の末尾にゼロを追加した変換元から取得し、両方の結果のタイムゾーンには現在
のセッションのタイムゾーン変位が設定されます。
SELECT CAST(p AS PERIOD(TIME(6)WITH TIME ZONE)) FROM t;
次の結果が返されます。
('12:12:12.450000-08:00', '13:12:12.670000-08:00')
関連トピック
データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
618
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
Period から TIME への変換
Period から TIME への変換
目的
Period データを TIME 値に変換します。
CAST 構文
CAST
A
( period_expression
A
AS
TIME
)
(fractional_seconds_precision)
WITH TIME ZONE
data_attribute
構文要素
period_expression
変換される PERIOD 式。
fractional_seconds_precision
SECOND フィールドの小数部の有効桁数を表わす 1 桁の数字。有効な範囲は、0 か
ら 6 です。デフォルトは 6 です。
time_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、CAST で TIME データ属性句を使用できます。
使用上の注意
PERIOD(TIME(n) [WITH TIME ZONE])値または PERIOD(TIMESTAMP(n) [WITH
TIME ZONE])値は、CAST 関数を使用すると TIME[(n)] [WITH TIME ZONE]として
キャストできます。変換元の最後の値は、変換元の開始境界と等しくなければなり
ません。そうでないと、エラーが報告されます。
変換先の精度が変換元の精度より高い場合、精度を調整するために結果の末尾にゼ
ロが追加されます。変換先の精度が変換元の精度より低い場合、エラーが報告され
ます。
SQL 関数、演算子、式および述部
619
第 13 章 データ型の変換
Period から TIMESTAMP への変換
変換元のタイプが PERIOD(TIME(n) [WITH TIME ZONE])または
PERIOD(TIMESTAMP(n) [WITH TIME ZONE])の場合、結果の時間部分は変換元の開
始境界の時間部分から取得されます。変換元と変換先のタイプがどちらも WITH TIME
ZONE の場合、結果のタイムゾーンフィールドは変換元の開始境界のタイムゾーン
変位に設定されます。変換先のタイプのみが WITH TIME ZONE の場合、結果のタイ
ムゾーンフィールドは現在のセッションのタイムゾーン変位に設定されます 。
変換元のタイプが PERIOD(DATE)の場合、エラーが報告されます。
例
pt は、PERIOD '(12:12:12.34, 12:12:12.35)'の値を持つテーブル t の
PERIOD(TIME(2))列だとします。
以下の例では、PERIOD(TIME(2))列を TIME(6)としてキャストしています。TIME(6)
の結果は変換元の開始境界から取得され、精度が 6 になるよう秒の小数桁の末尾に
ゼロが追加されます。
SELECT CAST(pt AS TIME(6)) FROM t;
次の結果が返されます。
12:12:12.340000
関連トピック
データ型およびデータ属性について、詳細は< SQL データ型とリテラル、B035-1143>
を参照してください。
Period から TIMESTAMP への変換
目的
Period データを TIMESTAMP 値に変換します。
CAST 構文
CAST
( period_expression
AS
A
TIMESTAMP
(fractional_seconds_precision)
A
)
WITH TIME ZONE
620
data_attribute
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
Period から TIMESTAMP への変換
構文要素
period_expression
変換される PERIOD 式。
fractional_seconds_precision
SECOND フィールドの小数部の有効桁数を表わす 1 桁の数字。有効な範囲は、0 か
ら 6 です。デフォルトは 6 です。
timestamp_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI の拡張として、CAST では、日時データの代替出力の書式化を可能にするため
に、FORMAT 句を使用することができます。
使用上の注意
PERIOD(DATE)、PERIOD(TIME(n) [WITH TIME ZONE])、または
PERIOD(TIMESTAMP(n) [WITH TIME ZONE])の値は、CAST 関数を使用すると
TIMESTAMP[(n)] [WITH TIME ZONE]としてキャストできます。変換元の最後の値
は、変換元の開始境界と等しくなければなりません。そうでないと、エラーが報告
されます。
変換元の型が PERIOD(TIME(n) [WITH TIME ZONE])または PERIOD(TIMESTAMP(n)
[WITH TIME ZONE])の場合、次のようになります。
• 変換先の精度が変換元の精度より高い場合、精度を調整するために結果の末尾に
ゼロが追加されます。
• 変換先の精度が変換元の精度より低い場合、エラーが報告されます。
変換元のタイプが PERIOD(DATE)の場合、結果は現在のセッションのタイムゾーン
に調整された変換元の開始境界とゼロの時間部分で作成されます。変換先のタイプ
が WITH TIME ZONE ならば、現在のセッションのタイムゾーン変位も追加されます。
変換元のタイプが PERIOD(TIME(n) [WITH TIME ZONE])の場合、変換元の(UTC で
の)開始境界は現在のセッションのタイムゾーン変位に調整されます。結果のタイム
スタンプ部分は、CURRENT_DATE と前述の調整を実行した後に取得した変換元の
開始境界の時間部分から作成されます。結果のタイムスタンプ値は、UTC に変換さ
れます。変換元と変換先のタイプがどちらも WITH TIME ZONE の場合、結果のタ
イムゾーンフィールドは変換元の開始境界のタイムゾーン変位に設定されます 。変
SQL 関数、演算子、式および述部
621
第 13 章 データ型の変換
符号付きゾーン DECIMAL 変換
換先のタイプのみが WITH TIME ZONE の場合、結果のタイムゾーンフィールドは現
在のセッションのタイムゾーン変位に設定されます。
変換元のタイプが PERIOD(TIMESTAMP(n) [WITH TIME ZONE])の場合、結果のタイ
ムスタンプ部分は変換元の開始境界のタイムスタンプ部分になります。変換元と変
換先のタイプがどちらも WITH TIME ZONE の場合、結果のタイムゾーンフィールド
は変換元の開始境界のタイムゾーン変位に設定されます。変換先のタイプのみが
WITH TIME ZONE の場合、結果のタイムゾーンフィールドは現在のセッションのタ
イムゾーン変位に設定されます。
例
pts は、PERIOD '(03.02.05 12:12:12.34, 03.02.05 12:12:12.35)'の値を持つテーブ
ル t の PERIOD(TIMESTAMP(2))列だとします。
以下の例では、列 pts を TIMESTAMP(6)としてキャストしています。結果は、精度
が 6 になるよう秒の小数桁の末尾にゼロが追加された変換元の開始境界になります。
SELECT CAST(pts AS TIMESTAMP(6)) FROM t;
次の結果が返されます。
2005-02-03 12:12:12.340000
関連トピック
データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
符号付きゾーン DECIMAL 変換
Teradata SQL は、符号付きゾーン(外部)小数である入力データを数値データ タイプ
に変換できるので、数値演算を列の値に対して実行できるようになります。符号付
きゾーン小数が格納されることになる列は、どの数値データ タイプでもかまいません。
S 符号文字を組み込んだ FORMAT 句は、 Teradata Database に渡されるとき、およ
び Teradata Database から渡されるときにデータをフィルタ処理します。
入力データ列の右端の文字は、ゾーン(オーバーパンチ)ビットを含んでいると想定さ
れます。
ゾーンと数値の組み合わせを表わす文字を次の表に示します。
622
最後の文字(入 数値変換
力文字列)
最後の文字(入 数値変換
力文字列)
最後の文字(入 数値変換
力文字列)
{
}
0
n…0
-n … 0
n…0
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
符号付きゾーン DECIMAL 変換
最後の文字(入 数値変換
力文字列)
最後の文字(入 数値変換
力文字列)
最後の文字(入 数値変換
力文字列)
A
n…1
J
-n … 1
1
n…1
B
n…2
K
-n … 2
2
n…2
C
n…3
L
-n … 3
3
n…3
D
n…4
M
-n … 4
4
n…4
E
n…5
N
-n … 5
5
n…5
F
n…6
O
-n … 6
6
n…6
G
n…7
P
-n … 7
7
n…7
H
n…8
Q
-n … 8
8
n…8
I
n…9
R
-n … 9
9
n…9
列の定義では CREATE TABLE または ALTER TABLE 文に、データのロードでは
INSERT 文に、符号付きの FORMAT 句を含めることができます。格納された値をど
のように使用するかにより、FORMAT 句の指定方法が異なります。
符号付きの FORMAT 句が列作成時に指定されている場合、その句は列レベルでデー
タが変換されるため、列に「付属している」とみなされます。すなわち、そのデー
タがロードされる時と検索される時の両方で行なわれます。
CREATE TABLE での FORMAT の使用
CREATE TABLE 文で、次の FORMAT 句が使用されるとき、
CREATE TABLE Test1 (Col1 DECIMAL(4) FORMAT '9999S');
ゾーン付きの入力文字列は、データが次のように直接入力されるか、
INSERT INTO Test1 (Col1) VALUES ('123J');
または、次のように USING 修飾子を使用して、クライアント システムのデータレ
コードから読まれるかどうかにかかわらず、標準の INSERT 文でロードすることが
できます。
USING Ext1 (CHAR(4))
INSERT INTO Test1 (Col1)
VALUES (:Ext1);
データ レコードには、文字列‘123J’が含まれます。
これ以降、次のような単純な選択は、
SELECT Col1 FROM Test1;
次の結果が得られます。
SQL 関数、演算子、式および述部
623
第 13 章 データ型の変換
符号付きゾーン DECIMAL 変換
Col1
---123J
SELECT 文での別の FORMAT の使用
定義済みの書式を無効にするには、別の FORMAT 句が検索の文に必要です。前の例
のテーブルを使用すると、次の 2 つの文の内の 1 つを使用して数値を検索しなけれ
ばなりません。
SELECT Col1 (FORMAT '+9999') FROM Test1;
または
SELECT CAST (Col1 AS INTEGER) FROM Test1;
結果は、以下のようになります。
Col1
-----1231
列に付属していない FORMAT
この書式が列に付属していない場合、符号付きゾーン小数データがロードされるご
とに、および、行の値が符号付きゾーン小数の書式で検索されるごとに、符号付き
の FORMAT 句を使用しなければなりません。
たとえば、以下のように表が CREATE TABLE 文で定義されている場合、
CREATE TABLE Test2 (Col2 DECIMAL(5));
符号付き FORMAT 句を、符号付きゾーン小数文字列の挿入時に必ず組み込む必要が
あります。
これは、例 1 と 2 のように、定義が明示的に定義されているかどうかには関係なく
当てはまります。 例 3 と 4 のように、クライアント システム データ レコードから
読み込まれることによって暗黙に定義されているかどうかには関係なく当てはまり
ます。
624
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
符号付きゾーン DECIMAL 変換
例
例
INSERT INTO Test2 (Col2)
VALUES ('5678B' (DECIMAL(5), FORMAT '99999S'));
例
INSERT INTO Test2 (Col2)
VALUES ('9012L' (DECIMAL(5), FORMAT '99999S'));
例
USING Ext2 (CHAR(5))
INSERT INTO Test2 (Col2)
VALUES (:Ext2 (DECIMAL(5), FORMAT '99999S'));
例
USING Ext2 (CHAR(5))
INSERT INTO Test2 (Col2)
VALUES (:Ext2 (DECIMAL(5), FORMAT '99999S'));
Ext2 には、文字列‘5678B’と‘9012L’が含まれます。
Col2 には付属の FORMAT 句がないので、次のような単純な SELECT の例では、次
の結果が戻されます。
SELECT Col2 FROM Test2;
Col2
------56782.
-90123.
値‘5678B’と‘9012L’を取得するために、符号 FORMAT 句が SELECT 文に含まれてい
る必要があります。
符号付きゾーン小数の値を処理する場合、特に、subquery などの複雑な機能を使用
する場合には、この規則を憶えておくことが重要です。
例
この例は、前の例のデータに基づきます。
CHARACTER データ タイプで作成された列を考えてみます。
CREATE TABLE Test3 (Col3 CHAR(5));
SQL 関数、演算子、式および述部
625
第 13 章 データ型の変換
TIME から文字への変換
列は次のように、符号 FORMAT 句なしで、"付属していない"列から値を選択してロー
ドされます。
INSERT INTO Test3 (Col3)
SELECT Col2 FROM Test2 ;
挿入される値は、次のとおりです。
Col3
----5678
-9012
値'5678B'と'9012L'を挿入するために、符号 FORMAT 句が問合わせ指定に含まれて
いる必要があります。
関連トピック
データ タイプ、データ タイプの書式、書式設定文字、および FORMAT 句について、
詳細は< SQL データ型とリテラル、B035-1143>を参照してください。
TIME から文字への変換
目的
TIME データを文字列に変換します。
CAST 構文
CAST
( time_expression
AS
A
character_data_type
)
A
CHARACTER SET
server_character_set
data_attribute
構文要素
time_expression
変換する TIME 式。
character_data_type
式が変換されるデータ型。
626
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIME から文字への変換
server_character_set
変換に使用するサーバー文字セット。CHARACTER SET 句を省略した場合は、ユー
ザー デフォルトのサーバー文字セットが使用されます。
character_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI の拡張として、CAST では、日時データの文字表現の代替出力の書式化を可能
にするために、FORMAT 句を使用することができます。
Teradata 変換構文
CAST
( time_expression
AS
A
character_data_type
)
A
CHARACTER SET
server_character_set
data_attribute
構文要素
time_expression
変換する TIME 式。
character_data_type
式が変換されるデータ型。
server_character_set
変換に使用するサーバー文字セット。CHARACTER SET 句を省略した場合は、ユー
ザー デフォルトのサーバー文字セットが使用されます。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
SQL 関数、演算子、式および述部
627
第 13 章 データ型の変換
TIME から文字への変換
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
TIME から CHAR(n)または VARCHAR(n)への変換時に、n は、文字列定数によって表
わされた TIME 値の長さと等しいかそれよりも長くなければなりません。
変換先データ タイプ
n
結果
CHAR(n)
文字列定数で表わされた
TIME 値の長さより長い
末尾の埋め込み文字が表記を埋める
ために追加される。
小さすぎる
文字切り捨てエラーが戻される。
文字列定数で表わされた
TIME 値の長さより長い
ブランク埋め込みは文字表記に追加
されない。
小さすぎる
文字切り捨てエラーが戻される。
VARCHAR(n)
TIME から CLOB への変換はサポートされていません。
サーバー文字セットが GRAPHIC のときは、TIME 値を文字列に変換することはでき
ません。
TIME から文字への変換に対する CAST での FORMAT の強制
TIME から文字への変換のデフォルトの書式は、TIME 値に有効な書式を使用します。
FORMAT 句を使って、TIME 値を文字列に変換できます。ただし、結果の書式は、
TIME 値と同じになります。文字列値で別の書式を使用する場合は、以下で説明する
ように CAST を併用する必要があります。
TIME 値に関連する書式にかかわらず、TIME から CHAR に値を変換し、その結果に
おいて明示的な FORMAT を強制するには、入れ子 CAST 操作を行なう必要がありま
す。これは、FORMAT 句をデータ タイプに突き合わせるための規則によるものです。
例
テーブル INTTIME のフィールド T1 は、明示的なフォーマット'HH:MI:SSDS(6)'を使
用した TIME(6)値です。この値を CHAR(6)の値に変換し、'HHhMIm'の明示的な出力
フォーマットにすると仮定します。
SELECT T1 FROM INTTIME ;
結果(タイプの変更はなし)は、以下のレポートになります。
628
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIME から Period への変換
T1
--------------05:57:11.362271
入れ子 CAST 句と FORMAT を使って、目的の結果を入手します。つまり、文字書式
のレポートです。
SELECT
CAST( (CAST (T1 AS FORMAT 'HHhMim'))
AS CHAR(6))
FROM INTTIME;
入れ子 CAST の結果は、以下のレポートになります。
T1
-----05h57m
内部 CAST は TIME 値の表示書式を確立し、外部 CAST は必要な結果のデータ タイ
プを示します。
関連トピック
データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
TIME から Period への変換
目的
TIIME データを PERIOD(TIME(n) [WITH TIME ZONE])または
PERIOD(TIMESTAMP(n)[WITH TIME ZONE])として変換します。
CAST 構文
CAST
( timestamp_expression
AS
period_data_type
)
data_attribute
構文要素
time_expression
変換する TIME 式。
SQL 関数、演算子、式および述部
629
第 13 章 データ型の変換
TIME から Period への変換
period_data_type
式が変換されるデータ型。
period_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、CAST でデータ属性句を使用できます。
使用上の注意
TIME(n) [WITH TIME ZONE]値は、CAST 関数を使用すると PERIOD(TIME[(n)]
[WITHTIMEZONE])または PERIOD(TIMESTAMP[(n)] [WITH TIME ZONE])としてキャ
ストできます。
変換先の精度が変換元の精度より高い場合、精度を調整するために結果の境界の末
尾にゼロが追加されます。変換先の精度が変換元の精度より低い場合、エラーが報
告されます。
変換元の TIME 値にうるう秒が含まれている場合、秒部分は変換先の精度にまで精
度を切り詰めた 59.999999 に調整されます。
変換先のタイプが PERIOD(TIME[(n)] [WITH TIME ZONE])の場合、結果の開始要素は
(UTC での)変換元の値に設定されます。変換先タイプが PERIOD(TIMESTAMP[(n)]
WITH TIME ZONE)の場合、変換元の時間値は、対応する UTC 値を基に現在のセッ
ションのタイムゾーン変位に調整され、結果の開始要素の日付部分は CURRENT_DATE
に設定されます。時間部分は前述の調整を実行した後に取得した変換元の値に設定
され、結果のタイムスタンプ値は UTC に変換されます。変換元と変換先のタイプが
どちらも WITH TIME ZONE の場合、結果の開始要素のタイムゾーンフィールドは変
換元のタイムゾーンフィールドに設定されます。変換先にのみ WITH TIME ZONE が
ある場合、結果の開始要素のタイムゾーンフィールドは現在のセッションのタイム
ゾーン変位に設定されます。結果の終了要素は、結果の開始境界に変換先タイプの
1 最小単位を加算したものに設定されます。結果の終了境界の値が、
PERIOD(TIME[(n)] [WITH TIME ZONE])の変換先タイプの結果の開始境界よりも小さ
い場合、または結果の終了要素の値が、PERIOD(TIMESTAMP[(n)] [WITH TIME
ZONE])の変換先タイプの対応する TIMESTAMP 値の最大値よりも大きい場合、エ
ラーが報告されます。
注: 変換先タイプが WITH TIME ZONE の場合、結果の開始境界および終了境界は同
じタイムゾーンでなければなりません。
630
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIME から TIME への変換
また、結果は開始境界と最後の値が同じ値になることに注意してください。
例
pt は、TIME '12:12:12'の値を持つテーブル t の TIME(0)列で、現在のセッションの
タイムゾーン変位が INTERVAL -'08:00' HOUR TO MINUTE だとします。
以下の例では、TIME(0)列を PERIOD(TIME(4) WITH TIME ZONE)としてキャストし
ます。結果の開始境界は、精度が 4 になるよう末尾にゼロを追加した(UTC での)変
換元と、現在のセッションのタイムゾーン変位から作成されます。結果の終了要素
は、結果の開始境界に INTERVAL '0.0001' SECOND を加算したものに設定されます。
注: 結果の開始要素と終了要素のタイムゾーンは同じになります。
SELECT CAST(pt AS PERIOD(TIME(4) WITH TIME ZONE)) FROM t;
以下に示すような PERIOD(TIME(4) WITH TIME ZONE)値が返されます。
('12:12:12.0000-08:00', '12:12:12.0001-08:00')
関連トピック
データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
TIME から TIME への変換
目的
TIIME または TIME WITH TIME ZONE を、任意選択のデータ属性を使用して TIME
または TIME WITH TIME ZONE に変換します。
SQL 関数、演算子、式および述部
631
第 13 章 データ型の変換
TIME から TIME への変換
CAST 構文
CAST
( time_expression
AS
A
TIME
(fractional_seconds_precision)
B
A
WITH TIME ZONE
AT
LOCAL
SOURCE
TIME ZONE
expression
TIME ZONE
time_zone_string
)
B
data_attribute
構文要素
time_expression
変換する TIME 式。
fractional_seconds_precision
SECOND フィールドの小数部の有効桁数を表わす 1 桁の数字。有効な範囲は、0 か
ら 6 です。デフォルトは 6 です。
AT LOCAL
現在のセッションのタイムゾーンに基づくタイムゾーン変位を使用します。
AT SOURCE [TIME ZONE]
次の場合に、timestamp_expression に付随するタイムゾーンを使用します。
• AT SOURCE TIME ZONE が指定される。
• AT SOURCE が without TIME ZONE で指定され、範囲に source という列がない。
その他の場合、AT SOURCE が without TIME ZONE で指定され、source という列が
存在する場合、SOURCE はこの列を参照し、列の値は CAST のタイムゾーン変位と
して使用されます。必要な場合、列値が型 INTERVAL HOUR(2) TO MINUTE に暗黙
的に変換されます。
詳細については、「AT LOCAL および AT TIME ZONE タイムゾーン指定子」を参照
してください。範囲に source という列が複数ある場合は、エラーが戻されます。
AT [TIME ZONE] expression
time_zone_string は、タイムゾーン変位を決定します。
expression のデータ型は INTERVAL HOUR(2) TO MINUTE か、暗黙的に INTERVAL
HOUR(2) TO MINUTE に変換できるデータ型でなければなりません。
632
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIME から TIME への変換
AT [TIME ZONE] time_zone_string
time_zone_string は、タイムゾーン変位を決定します。
time_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI の拡張として、CAST では、日時データの代替出力の書式化を可能にするため
に、FORMAT 句を使用することができます。
AT 句は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、CAST を使用した TIME (タイムゾーンの有無は関係なし)
の TIME WITH TIME ZONE への変換に、AT 句がサポートされるようになりました。
また、INTERVAL 式の他にも追加の式を使用して、タイムゾーン変位を指定するこ
とができます。
注: TIME (without time zone)は、ANSI SQL:2011 互換ではありません。Teradata
Database は、現在のセッションのタイムゾーン、または指定されたタイムゾーンに
基づいて、TIME 値を内部的に UTC に変換します。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
Teradata 変換構文
time_expression
(
A
TIME
(fractional_seconds_precision)
data_attribute ,
B
A
, WITH TIME ZONE
AT
LOCAL
SOURCE
TIME ZONE
expression
TIME ZONE
B
time_zone_string
)
, data_attribute
SQL 関数、演算子、式および述部
633
第 13 章 データ型の変換
TIME から TIME への変換
構文要素
time_expression
変換する TIME 式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
fractional_seconds_precision
SECOND フィールドの小数部の有効桁数を表わす 1 桁の数字。有効な範囲は、0 か
ら 6 です。デフォルトは 6 です。
AT LOCAL
現在のセッションのタイムゾーンに基づくタイムゾーン変位を使用します。
AT SOURCE [TIME ZONE]
次の場合に、timestamp_expression に付随するタイムゾーンを使用します。
• AT SOURCE TIME ZONE が指定される。
• AT SOURCE が without TIME ZONE で指定され、範囲に source という列がない。
その他の場合、AT SOURCE が without TIME ZONE で指定され、source という列が
存在する場合、SOURCE はこの列を参照し、列の値は CAST のタイムゾーン変位と
して使用されます。必要な場合、列値が型 INTERVAL HOUR(2) TO MINUTE に暗黙
的に変換されます。
AT [TIME ZONE] expression
time_zone_string は、タイムゾーン変位を決定します。
式で定義されたタイムゾーンの変位を使用します。
expression のデータ型は INTERVAL HOUR(2) TO MINUTE か、暗黙的に INTERVAL
HOUR(2) TO MINUTE に変換できるデータ型でなければなりません。
AT [TIME ZONE] time_zone_string
time_zone_string は、タイムゾーン変位を決定します。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
AT 句は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、Teradata 変換構文を使用した TIME (タイムゾーンの有無
は関係なし)の TIME WITH TIME ZONE への変換に、AT 句がサポートされるように
634
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIME から TIME への変換
なりました。また、INTERVAL 式の他にも追加の式を使用して、タイムゾーン変位
を指定することができます。
注: TIME (without time zone)は、ANSI SQL:2011 互換ではありません。Teradata
Database は、現行セッションのタイムゾーン、または指定されたタイムゾーンに基
づいて、TIME 値を内部的に UTC に変換します。
使用上の注意
変換先データ タイプにタイムゾーンがない TIME[(n)]の AT 句を指定すると、エラー
が返されます。
変換先データ タイプが TIME[(n)] WITH TIME ZONE の AT 句を指定した場合の、
CAST 関数、または各種の指定オプションに基づいた Teradata 変換の結果を以下の
表に示します。変換先の精度が変換元の精度より高い場合、精度を調整するために
結果の末尾にゼロが追加されます。変換先の精度が変換元の精度より低い場合、エ
ラーが返されます。
指定内容
time_expression の
データ型
THEN...
AT LOCAL
TIME ZONE の有無は
関係なし
THEN...
AT SOURCE
WITH TIME ZONE
変換元の time_expression (UTC)と、現在のセッ
ションのタイムゾーンに基づくタイムゾーン変位
から結果が生成されます。
(SOURCE はキーワードであり、
列参照ではありません)
AT SOURCE
time_expression のデータ型がタイムゾーンなしの
ときには、AT 句を指定しない場合と同じ結果にな
ります。
without TIME ZONE
(SOURCE はキーワードであり、
列参照ではありません)
変換元の time_expression の時間部分(UTC)と、
time_expression に関連付けられたタイムゾーン変
位から結果が生成されます。
これは、AT 句を指定しない場合と同じ結果になり
ます。
AT SOURCE TIME ZONE
WITH TIME ZONE
変換元の time_expression の時間部分(UTC)と、
time_expression に関連付けられたタイムゾーン変
位から結果が生成されます。
これは、AT 句を指定しない場合と同じ結果になり
ます。
AT SOURCE TIME ZONE
without TIME ZONE
エラーが戻されます。
AT 式または
AT TIME ZONE expression
TIME ZONE の有無は
関係なし
変換元の time_expression の時間部分(UTC)と、
expression で定義されるタイムゾーン変位から結
果が生成されます。
SQL 関数、演算子、式および述部
635
第 13 章 データ型の変換
TIME から TIME への変換
time_expression の
データ型
指定内容
AT time_zone_string
TIME ZONE の有無は
または
関係なし
AT TIME ZONE time_zone_string
THEN...
変換元の time_expression の時間部分(UTC)と、
time_zone_string で定義されるタイムゾーン変位か
ら結果が生成されます。タイムゾーン変位は、
time_zone_string、CURRENT_TIMESTAMP AT
'00:00'、および time_expression の TIME 値(UTC)
に基づいて決定されます。
例
例
この例では、現在のセッションのタイムゾーン変位 INTERVAL '01:00' HOUR TO
MINUTE を使用して、TIME 定数の UTC 値'07:30:00'を決定しています。
CAST の結果は、変換元の式値の時間部分'07:30:00' (UTC)と、現在のタイムゾーン
変位 INTERVAL '01:00' HOUR TO MINUTE から生成されます。
UTC での CAST '07:30:00'の結果値がタイムゾーン変位 INTERVAL '01:00' HOUR TO
MINUTE に調整され、SELECT 文の結果は次のようになります。TIME
'08:30:00+01:00'
SELECT 文の結果は、UTC の値に基づいて値が比較されるため、TIME
'07:30:00+00:00'と等しくなります。
SET TIME ZONE INTERVAL '01:00' HOUR TO MINUTE;
SELECT CAST(TIME '08:30:00' AS TIME(0) WITH TIME ZONE);
SELECT CAST(TIME '08:30:00' AS TIME(0) WITH TIME ZONE AT LOCAL);
例
この例では、文字列定数 INTERVAL '04:00' HOUR TO MINUTE で指定されたタイム
ゾーン変位を使用して、TIME 定数の UTC 値'04:30:00'を決定しています。
CAST の結果は、変換元の式値の時間部分'04:30:00' (UTC)と、現在のセッションの
タイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE から生成されます。
UTC での CAST '04:30:00'の結果値はそのタイムゾーン変位 INTERVAL -'08:00' HOUR
TO MINUTE に調整され、SELECT 文の結果は次のようになります。TIME
'20:30:00-08:00'
SELECT 文の結果は、TIME '04:30+00:00'と等しくなります。
SET TIME ZONE INTERVAL -'08:00' HOUR TO MINUTE;
SELECT CAST(TIME '08:30:00+04:00' AS TIME(0)
WITH TIME ZONE AT LOCAL);
636
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIME から TIME への変換
例
次の SELECT 文は、変換元の式にタイムゾーン変位が存在しないために、エラーを
返します。
SELECT CAST(TIME '08:30:00' AS TIME(0)
WITH TIME ZONE AT SOURCE TIME ZONE);
例
この例では、文字列定数 INTERVAL '04:00' HOUR TO MINUTE で指定されたタイム
ゾーン変位を使用して、TIME 定数の UTC 値'04:30:00'を決定しています。
CAST の結果は、変換元の式値の時間部分'04:30:00' (UTC)と、変換元の式のタイム
ゾーン変位 INTERVAL '04:00' HOUR TO MINUTE から生成されます。
UTC での CAST '04:30:00'の結果値がタイムゾーン変位 INTERVAL '04:00:00' HOUR
TO MINUTE に調整され、SELECT 文の結果は次のようになります。TIME
'08:30:00+04:00'
SELECT 文の結果は、TIME '04:30:00+00:00'と等しくなります。現在のセッション
のタイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE は、影響しません。
SET TIME ZONE INTERVAL -'08:00' HOUR TO MINUTE;
SELECT CAST(TIME '08:30:00+04:00' AS TIME(0) WITH TIME ZONE);
SELECT CAST(TIME '08:30:00+04:00' AS TIME(0)
WITH TIME ZONE AT SOURCE);
例
この例では、現在のセッションのタイムゾーン変位 INTERVAL -'04:00' HOUR TO
MINUTE を使用して、TIME 定数の UTC 値'12:30:00'を決定しています。
CAST の結果は、変換元の式値の時間部分'12:30:00' (UTC)と、指定したタイムゾー
ン変位 INTERVAL -'08:00' HOUR TO MINUTE から生成されます。
UTC での CAST '12:30:00'の結果値はそのタイムゾーン変位 INTERVAL -'08:00'
HOUR TO MINUTE に調整され、SELECT 文の結果は次のようになります。TIME
'04:30:00-08:00'
SELECT 文の結果は、TIME '12:30:00+00:00'と等しくなります。
SET TIME ZONE INTERVAL -'04:00' HOUR TO MINUTE;
SELECT CAST(TIME '08:30:00' AS TIME(0) WITH TIME ZONE AT -8);
例
この例では、文字列定数 INTERVAL '04:00' HOUR TO MINUTE で指定されたタイム
ゾーン変位を使用して、TIME 定数の UTC 値'04:30:00'を決定しています。
CAST の結果は、変換元の式値の時間部分'04:30:00' (UTC)と、指定したタイムゾー
ン変位 INTERVAL -'08:00' HOUR TO MINUTE から生成されます。
SQL 関数、演算子、式および述部
637
第 13 章 データ型の変換
TIME から TIMESTAMP への変換
UTC での CAST '04:30:00'の結果値はそのタイムゾーン変位 INTERVAL -'08:00' HOUR
TO MINUTE に調整され、SELECT 文の結果は次のようになります。TIME
'20:30:00-08:00'
SELECT 文の結果は、TIME '04:30:00+00:00'と等しくなります。現在のセッション
のタイムゾーン変位 INTERVAL '08:00' HOUR TO MINUTE は、影響しません。
SET TIME ZONE INTERVAL '08:00' HOUR TO MINUTE;
SELECT CAST(TIME '08:30:00+04:00' AS TIME(0)
WITH TIME ZONE AT -8);
例
この例では、現在のタイムスタンプは次のとおりです。
Current TimeStamp(6)
-------------------------------2010-03-09 19:23:27.620000+00:00
次の文では、TIME 値'08:30:00'を、TIME WITH TIME ZONE 値に変換します。ここ
でのタイムゾーン変位はタイムゾーン文字列'America Pacific'に基づきます。
SELECT CAST(TIME '08:30:00' AS TIME(0) WITH TIME ZONE
AT 'America Pacific');
08:30:00
-------------00:30:00-08:00
関連トピック
詳細は、以下を参照してください。
• データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
• 詳細については、「AT LOCAL および AT TIME ZONE タイムゾーン指定子」を参
照してください。範囲に source という列が複数ある場合は、エラーが戻されます。
TIME から TIMESTAMP への変換
目的
TIIME または TIME WITH TIME ZONE を、任意選択のデータ属性を使用して
TIMESTAMP または TIMESTAMP WITH TIME ZONE に変換します。
638
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIME から TIMESTAMP への変換
CAST 構文
CAST
( time_expression
AS
A
TIMESTAMP
(fractional_seconds_precision)
B
A
WITH TIME ZONE
AT
LOCAL
SOURCE
TIME ZONE
expression
TIME ZONE
time_zone_string
)
B
data_attribute
構文要素
time_expression
変換する TIME 式。
fractional_seconds_precision
SECOND フィールドの小数部の有効桁数を表わす 1 桁の数字。有効な範囲は、0 か
ら 6 です。デフォルトは 6 です。
AT LOCAL
現在のセッションのタイムゾーンに基づくタイムゾーン変位を使用します。
AT SOURCE [TIME ZONE]
次の場合に、timestamp_expression に付随するタイムゾーンを使用します。
• AT SOURCE TIME ZONE が指定される。
• AT SOURCE が without TIME ZONE で指定され、範囲に source という列がない。
その他の場合、AT SOURCE が without TIME ZONE で指定され、source という列が
存在する場合、SOURCE はこの列を参照し、列の値は CAST のタイムゾーン変位と
して使用されます。必要な場合、列値が型 INTERVAL HOUR(2) TO MINUTE に暗黙
的に変換されます。
AT [TIME ZONE] expression
time_zone_string は、タイムゾーン変位を決定します。
式で定義されたタイムゾーンの変位を使用します。
expression のデータ型は INTERVAL HOUR(2) TO MINUTE か、暗黙的に INTERVAL
HOUR(2) TO MINUTE に変換できるデータ型でなければなりません。
SQL 関数、演算子、式および述部
639
第 13 章 データ型の変換
TIME から TIMESTAMP への変換
AT [TIME ZONE] time_zone_string
time_zone_string は、タイムゾーン変位を決定します。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI の拡張として、CAST では、日時データの代替出力の書式化を可能にするため
に、FORMAT 句を使用することができます。
AT 句は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、CAST を使用した TIME から TIMESTAMP への変換に、AT
句がサポートされるようになりました。また、INTERVAL 式の他にも追加の式を使
用して、タイムゾーン変位を指定することができます。
注: TIME (without time zone)と TIMESTAMP (without time zone)は ANSI SQL:2011
互換ではありません。Teradata Database は、現行セッションのタイムゾーン、また
は指定されたタイムゾーンに基づいて、TIMESTAMP 値を内部的に UTC に変換しま
す。
Teradata 変換構文
time_expression
(
A
TIMESTAMP
(fractional_seconds_precision)
data_attribute ,
B
A
, WITH TIME ZONE
AT
LOCAL
SOURCE
TIME ZONE
expression
TIME ZONE
B
time_zone_string
)
, data_attribute
640
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIME から TIMESTAMP への変換
構文要素
time_expression
変換する TIME 式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
fractional_seconds_precision
SECOND フィールドの小数部の有効桁数を表わす 1 桁の数字。有効な範囲は、0 か
ら 6 です。デフォルトは 6 です。
AT LOCAL
現在のセッションのタイムゾーンに基づくタイムゾーン変位を使用します。
AT SOURCE [TIME ZONE]
次の場合に、timestamp_expression に付随するタイムゾーンを使用します。
• AT SOURCE TIME ZONE が指定される。
• AT SOURCE が without TIME ZONE で指定され、範囲に source という列がない。
その他の場合、AT SOURCE が without TIME ZONE で指定され、source という列が
存在する場合、SOURCE はこの列を参照し、列の値は CAST のタイムゾーン変位と
して使用されます。必要な場合、列値が型 INTERVAL HOUR(2) TO MINUTE に暗黙
的に変換されます。
AT [TIME ZONE] expression
time_zone_string は、タイムゾーン変位を決定します。
式で定義されたタイムゾーンの変位を使用します。
expression のデータ型は INTERVAL HOUR(2) TO MINUTE か、暗黙的に INTERVAL
HOUR(2) TO MINUTE に変換できるデータ型でなければなりません。
AT [TIME ZONE] time_zone_string
time_zone_string は、タイムゾーン変位を決定します。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
AT 句は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、Teradata 変換構文を使用した TIME から TIMESTAMP へ
の変換に、AT 句がサポートされるようになりました。また、INTERVAL 式の他にも
追加の式を使用して、タイムゾーン変位を指定することができます。
SQL 関数、演算子、式および述部
641
第 13 章 データ型の変換
TIME から TIMESTAMP への変換
注: TIME (without time zone)と TIMESTAMP (without time zone)は ANSI SQL:2011
互換ではありません。Teradata Database は、現行セッションのタイムゾーン、また
は指定されたタイムゾーンに基づいて、TIMESTAMP 値を内部的に UTC に変換しま
す。
使用上の注意
変換先データ型にタイムゾーンがない TIMESTAMP[(n)]の AT 句を指定したときに、
CAST 関数、または各種の指定オプションに基づいた Teradata 変換の結果を以下の
表に示します。変換先の精度が変換元の精度より高い場合、精度を調整するために
結果の末尾にゼロが追加されます。変換先の精度が変換元の精度より低い場合、エ
ラーが返されます。
指定内容
time_expression の
データ型
AT LOCAL
TIME ZONE の有無は 変換元の time_expression (UTC)は、現在のセッショ
関係なし
ンのタイムゾーンに基づくタイムゾーン変位を追加
することで調整されます。ローカルのタイムスタン
プ値は、上記のタイムゾーン変位での
CURRENT_DATE と、前回の調整後に取得した
time_expression の時間部分から生成されます。結
果は、このローカルのタイムスタンプ値から上記の
タイムゾーン変位を引いて UTC に調整した、タイ
ムスタンプ値になります。
THEN...
これは、AT 句を指定しない場合と同じ結果になり
ます。
AT SOURCE
WITH TIME ZONE
変換元の time_expression (UTC)は、
time_expression のタイムゾーン変位を加えること
で調整されます。ローカルのタイムスタンプ値は、
CURRENT_DATE (time_expression のタイムゾーン
変位に基づく)と、前回の調整後に取得した
time_expression の時間部分から生成されます。結
果は、このローカルのタイムスタンプ値から、
time_expression のタイムゾーン変位を引いて UTC
に調整されたタイムスタンプ値になります。
without TIME ZONE
エラーが戻されます。
WITH TIME ZONE
変換元の time_expression (UTC)は、
time_expression のタイムゾーン変位を加えること
で調整されます。ローカルのタイムスタンプ値は、
CURRENT_DATE (time_expression のタイムゾーン
(SOURCE はキーワードであり、列参
照ではありません)
AT SOURCE
(SOURCE はキーワードであり、列参
照ではありません)
AT SOURCE TIME ZONE
642
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIME から TIMESTAMP への変換
time_expression の
データ型
指定内容
THEN...
変位に基づく)と、前回の調整後に取得した
time_expression の時間部分から生成されます。結
果は、このローカルのタイムスタンプ値から、
time_expression のタイムゾーン変位を引いて UTC
に調整されたタイムスタンプ値になります。
AT SOURCE TIME ZONE
without TIME ZONE
エラーが戻されます。
AT 式または
AT TIME ZONE expression
TIME ZONE の有無は 変換元の time_expression (UTC)は、expression で
関係なし
定義されたタイムゾーン変位を加えることで調整さ
れます。
ローカルのタイムスタンプ値は、上記のタイムゾー
ン変位での CURRENT_DATE と、上記の調整後に取
得した time_expression の時間部分から生成されま
す。結果は、このローカルのタイムスタンプ値から
上記のタイムゾーン変位を引いて UTC に調整した、
タイムスタンプ値になります。
AT time_zone_string
または
AT TIME ZONE time_zone_string
TIME ZONE の有無は 変換元の time_expression (UTC)は、
関係なし
time_zone_string に基づくタイムゾーン変位を加え
ることで調整されます。タイムゾーン変位は、
time_zone_string、CURRENT_TIMESTAMP AT
'00:00'、および time_expression の TIME 値(UTC)
に基づいて決定されます。
ローカルのタイムスタンプ値は、上記のタイムゾー
ン変位での CURRENT_DATE と、上記の調整後に取
得した time_expression の時間部分から生成されま
す。結果は、このローカルのタイムスタンプ値から
上記のタイムゾーン変位を引いて UTC に調整した、
タイムスタンプ値になります。
変換先データ型が TIMESTAMP[(n)] WITH TIME ZONE の AT 句を指定したときの、
CAST 関数、または各種の指定オプションに基づいた Teradata 変換の結果を以下の
表に示します。変換先の精度が変換元の精度より高い場合、精度を調整するために
結果の末尾にゼロが追加されます。変換先の精度が変換元の精度より低い場合、エ
ラーが返されます。
指定内容
time_expression の
データ型
AT LOCAL
TIME ZONE の有無は 変換元の time_expression (UTC)は、現在のセッショ
関係なし
ンのタイムゾーンに基づくタイムゾーン変位を追加
することで調整されます。ローカルのタイムスタン
プ値は、上記のタイムゾーン変位での
SQL 関数、演算子、式および述部
THEN...
643
第 13 章 データ型の変換
TIME から TIMESTAMP への変換
指定内容
time_expression の
データ型
THEN...
CURRENT_DATE と、上記の調整後に取得した
time_expression の時刻部分から生成されます。こ
の結果のタイムスタンプは UTC に調整され、CAST
の結果値(UTC)は、上記のタイムゾーン変位に調整
されます。
time_expression のデータ タイプがタイムゾーンな
しのときには、AT 句を指定しない場合と同じ結果に
なります。
AT SOURCE
WITH TIME ZONE
変換元の time_expression (UTC)は、
time_expression のタイムゾーン変位を加えること
で調整されます。ローカルのタイムスタンプ値は、
CURRENT_DATE (time_expression のタイムゾーン
変位に基づく)と、前回の調整後に取得した
time_expression の時間部分から生成されます。こ
の結果のタイムスタンプは UTC に調整され、CAST
の結果値(UTC)は、time_expression のタイムゾーン
変位に調整されます。
without TIME ZONE
エラーが戻されます。
AT SOURCE TIME ZONE
WITH TIME ZONE
変換元の time_expression (UTC)は、
time_expression のタイムゾーン変位を加えること
で調整されます。ローカルのタイムスタンプ値は、
CURRENT_DATE (time_expression のタイムゾーン
変位に基づく)と、前回の調整後に取得した
time_expression の時間部分から生成されます。こ
の結果のタイムスタンプは UTC に調整され、CAST
の結果値(UTC)は、time_expression のタイムゾーン
変位に調整されます。
AT SOURCE TIME ZONE
without TIME ZONE
エラーが戻されます。
AT 式または
AT TIME ZONE expression
TIME ZONE の有無は 変換元の time_expression (UTC)は、expression で定
関係なし
義されるタイムゾーン変位を加えることで調整され
ます。
(SOURCE はキーワードであり、列参
照ではありません)
AT SOURCE
(SOURCE はキーワードであり、列参
照ではありません)
ローカルのタイムスタンプ値は、上記のタイムゾー
ン変位での CURRENT_DATE と、上記の調整後に取
得した time_expression の時刻部分から生成されま
644
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIME から TIMESTAMP への変換
time_expression の
データ型
指定内容
THEN...
す。この結果のタイムスタンプは UTC に調整され、
CAST の結果値(UTC)は、上記のタイムゾーン変位に
調整されます。
AT time_zone_string
または
AT TIME ZONE time_zone_string
TIME ZONE の有無は 変換元の time_expression (UTC)は、
関係なし
time_zone_string に基づくタイムゾーン変位を追加
することで調整されます。タイムゾーン変位は、
time_zone_string、CURRENT_TIMESTAMP AT
'00:00'、および time_expression の TIME 値(UTC)
に基づいて決定されます。
ローカルのタイムスタンプ値は、上記のタイムゾー
ン変位での CURRENT_DATE と、上記の調整後に取
得した time_expression の時刻部分から生成されま
す。この結果のタイムスタンプは UTC に調整され、
CAST の結果値(UTC)は、上記のタイムゾーン変位に
調整されます。
TIME から TIMESTAMP への暗黙的変換
Teradata Database は、場合によっては、TIME から TIMESTAMP データ型への暗黙
の変換を実行します。ただし、TIME から TIMESTAMP への暗黙的な変換は、比較
ではサポートされていません。「DateTime 型の暗黙的変換」を参照してください。
以下の変換をサポートします。
変換元タイプ
変換先タイプ
TIME
TIMESTAMP
TIMESTAMP WITH TIME ZONE
TIME WITH TIME ZONE
TIMESTAMP
TIMESTAMP WITH TIME ZONE
例
例
タイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE での現在の日付が DATE
'2008-05-14' と仮定すると、次の SELECT 文は次の結果を返します。TIMESTAMP
'2008-05-14 08:30:00'
SQL 関数、演算子、式および述部
645
第 13 章 データ型の変換
TIME から TIMESTAMP への変換
SET TIME ZONE INTERVAL '09:00' HOUR TO MINUTE;
SELECT CAST(TIME '08:30:00' AS TIMESTAMP(0));
SELECT CAST(TIME '08:30:00' AS TIMESTAMP(0) AT LOCAL);
現在のセッションのタイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE を使用
して、文字列定数の UTC 値'23:30:00'を決定します。
CAST の場合は、変換元の式値'23:30:00' (UTC)が、現在のセッションのタイムゾー
ン変位 INTERVAL '09:00' TO MINUTE に調整され、'08:30:00'が導き出されます。
タイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE での現在の日付'2008-05-14'
と、変換元の式値'08:30:00'からタイムスタンプが生成されます。タイムゾーン変位
INTERVAL '09:00' HOUR TO MINUTE での、このタイムスタンプ'2008-05-14
08:30:00'は UTC に合わせて調整されるため、CAST の結果は UTC で'2008-05-13
23:30:00'になります。
UTC での CAST の結果値は現在のセッションのタイムゾーン変位 INTERVAL
'09:00:00' HOUR TO MINUTE に調整されるため、SELECT 文の結果は次のようにな
ります。TIMESTAMP '2008-05-14 08:30:00'
例
タイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE での現在の日付が DATE
'2008-05-14'と仮定すると、次の SELECT 文は次の結果を返します。TIMESTAMP
'2008-05-14 13:30:00'
SET TIME ZONE INTERVAL '09:00' HOUR TO MINUTE;
SELECT CAST(TIME '08:30:00+04:00' AS TIMESTAMP(0));
SELECT CAST(TIME '08:30:00+04:00' AS TIMESTAMP(0) AT LOCAL);
文字列定数のタイムゾーン変位 INTERVAL '04:00' HOUR TO MINUTE を使用して、
UTC 値'04:30:00'と、その文字列定数のタイムゾーン変位 INTERVAL '04:00' HOUR
TO MINUTE が決定されます。CAST の場合は、変換元の式値'04:30:00' (UTC)が、現
在のセッションのタイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE に調整さ
れ、'13:30:00'が導き出されます。
タイムゾーン変位 INTERVAL HOUR '09:00' TO MINUTE での現在の日付'2008-05-14'
と、変換元の式値'13:30:00'からタイムスタンプが生成されます。タイムゾーン変位
INTERVAL '09:00' HOUR TO MINUTE での、このタイムスタンプ'2008-05-14
13:30:00'は UTC に合わせて調整されるため、CAST の結果は UTC で'2008-05-14
04:30:00'になります。
UTC での CAST の結果値は現在のセッションのタイムゾーン変位 INTERVAL '09:00'
HOUR TO MINUTE に調整されるため、SELECT 文の結果は次のようになります。
TIMESTAMP '2008-05-14 13:30:00'
例
次の SELECT 文は、変換元の式にタイムゾーンが存在しないために、エラーを返し
ます。
646
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIME から TIMESTAMP への変換
SELECT CAST(TIME '08:30:00'
SELECT CAST(TIME '08:30:00'
SELECT CAST(TIME '08:30:00'
AT SOURCE TIME ZONE);
SELECT CAST(TIME '08:30:00'
AT SOURCE);
AS TIMESTAMP(0) AT SOURCE TIME ZONE);
AS TIMESTAMP(0) AT SOURCE);
AS TIMESTAMP(0) WITH TIME ZONE
AS TIMESTAMP(0) WITH TIME ZONE
例
タイムゾーン変位 INTERVAL '9:00' HOUR TO MINUTE での現在の日付が DATE
'2008-05-14'で、タイムゾーン変位 INTERVAL '04:00' HOUR TO MINUTE での現在
の日付は DATE '2008-05-13'だと仮定します。次の SELECT 文は、次の結果を返し
ます。TIMESTAMP '2008-05-13 13:30:00'
SET TIME ZONE INTERVAL '09:00' HOUR TO MINUTE;
SELECT CAST(TIME '08:30:00+04:00' AS TIMESTAMP(0)
AT SOURCE TIME ZONE);
文字列定数のタイムゾーン変位 INTERVAL '04:00' HOUR TO MINUTE を使用して、
UTC 値'04:30:00'と、その文字列定数のタイムゾーン変位 INTERVAL '04:00' HOUR
TO MINUTE が決定されます。CAST の場合は、変換元の式値'04:30:00' (UTC)が、
変換元のタイムゾーン変位 INTERVAL '04:00' HOUR TO MINUTE に調整されて、
'08:30:00'が導き出されます。
タイムゾーン変位 INTERVAL '04:00' HOUR TO MINUTE での現在の日付
'2008-05-13'と、上記の調整後に取得した変換元の式値の時間部分'08:30:00'からタ
イムスタンプが生成されます。タイムゾーン変位 INTERVAL '04:00' HOUR TO
MINUTE での、このタイムスタンプ'2008-05-13 08:30:00'は UTC に合わせて調整
されるため、CAST の結果は UTC で'2008-05-13 04:30:00'になります。
UTC での CAST の結果値は現在のセッションのタイムゾーン変位 INTERVAL
'09:00:00' HOUR TO MINUTE に調整されるため、SELECT 文の結果は次のようにな
ります。TIMESTAMP '13.05.08 13:30:00'
例
タイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE での現在の日付が DATE
'2008-05-14'で、タイムゾーン INTERVAL -'08:00' HOUR TO MINUTE での現在の
日付は DATE '2008-05-13'だと仮定します。次の SELECT 文は、次の結果を返しま
す。TIMESTAMP '2008-05-14 08:30:00'
SET TIME ZONE INTERVAL '09:00' HOUR TO MINUTE;
SELECT CAST(TIME '08:30:00' AS TIMESTAMP(0) AT -8);
現在のセッションのタイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE を使用
して、文字列定数の UTC 値'23:30:00'を決定します。CAST の場合は、変換元の式
値'23:30:00' (UTC)が、変換先のタイムゾーン変位 INTERVAL -'08:00' HOUR TO
MINUTE に調整され、'15:30:00'が導き出されます。
SQL 関数、演算子、式および述部
647
第 13 章 データ型の変換
TIME から TIMESTAMP への変換
タイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE での現在の日付
'2008-05-13'と、上記の調整後に取得した変換元の式値の時間部分'15:30:00'からタ
イムスタンプが生成されます。タイムゾーン変位 INTERVAL -'08:00' HOUR TO
MINUTE での、この結果のタイムスタンプ'2008-05-13 15:30:00'は UTC に合わせ
て調整されるため、CAST の結果は UTC で'2008-05-13 23:30:00'になります。
UTC での CAST の結果値は現在のセッションのタイムゾーン変位 INTERVAL
'09:00:00' HOUR TO MINUTE に調整されるため、SELECT 文の結果は次のようにな
ります。TIMESTAMP '2008-05-14 08:30:00'
例
タイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE での現在の日付が DATE
'2008-05-14'で、タイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE での現在
の日付は DATE '2008-05-13'だと仮定します。次の SELECT 文は、次の結果を返し
ます。TIMESTAMP '2008-05-14 13:30:00'
SET TIME ZONE INTERVAL '09:00' HOUR TO MINUTE;
SELECT CAST(TIME '08:30:00+04:00' AS TIMESTAMP(0) AT -8);
文字列定数のタイムゾーン変位 INTERVAL '04:00' HOUR TO MINUTE を使用して、
UTC 値'04:30:00'と、その文字列定数のタイムゾーン変位 INTERVAL '04:00' HOUR
TO MINUTE が決定されます。CAST の場合は、変換元の式値'04:30:00' (UTC)が、変
換先のタイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE に調整され、
'20:30:00'が導き出されます。
タイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE での現在の日付
'2008-05-13'と、上記の調整後に取得した変換元の式値の時間部分'20:30:00'からタ
イムスタンプが生成されます。タイムゾーン変位 INTERVAL -'08:00' HOUR TO
MINUTE での、このタイムスタンプ'2008-05-13 20:30:00'は UTC に合わせて調整
されるため、CAST の結果は UTC で'2008-05-14 04:30:00'になります。
UTC での CAST の結果値は現在のセッションのタイムゾーン変位 INTERVAL '09:00'
HOUR TO MINUTE に調整されるため、SELECT 文の結果は次のようになります。
TIMESTAMP '2008-05-14 13:30:00'
例
タイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE での現在の日付が DATE
'2008-05-14' と仮定すると、次の SELECT 文は次の結果を返します。 TIMESTAMP
'2008-05-14 08:30:00+09:00'
SET TIME ZONE INTERVAL '09:00' HOUR TO MINUTE;
SELECT CAST(TIME '08:30:00' AS TIMESTAMP(0) WITH TIME ZONE);
SELECT CAST(TIME '08:30:00' AS TIMESTAMP(0) WITH TIME ZONE AT LOCAL);
現在のセッションのタイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE を使用
して、文字列定数の UTC 値'23:30:00'を決定します。CAST の場合は、変換元の式
値'23:30:00' (UTC)が、現在のセッションのタイムゾーン変位 INTERVAL '09:00'
HOUR TO TO MINUTE に調整され、'08:30:00'が導き出されます。
648
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIME から TIMESTAMP への変換
タイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE での現在の日付
'2008-05-14'と、上記の調整後に取得した変換元の式値の時間部分'08:30:00'からタ
イムスタンプが生成されます。タイムゾーン変位 INTERVAL '09:00' HOUR TO
MINUTE での、このタイムスタンプ'2008-05-14 08:30:00'は UTC に合わせて調整
されるため、CAST の結果は UTC で'2008-05-13 23:30:00'と、タイムゾーン変位
INTERVAL '09:00' HOUR TO MINUTE を併せたものになります。
UTC での CAST の結果値はタイムゾーン変位 INTERVAL '09:00:00' HOUR TO
MINUTE に調整されるため、SELECT 文の結果は次のようになります。TIMESTAMP
'2008-05-14 08:30:00+09:00'
例
タイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE での現在の日付が DATE
'2008-05-14'だと仮定すると、次の SELECT 文は次の結果を返します。TIMESTAMP
'2008-05-14 13:30:00+09:00'
SET TIME ZONE INTERVAL '09:00' HOUR TO MINUTE;
SELECT CAST(TIME '08:30:00+04:00' AS TIMESTAMP(0)
WITH TIME ZONE AT LOCAL);
文字列定数のタイムゾーン変位 INTERVAL '04:00' HOUR TO MINUTE を使用して、
UTC 値'04:30:00'と、その文字列定数のタイムゾーン変位 INTERVAL '04:00' HOUR
TO MINUTE が決定されます。CAST の場合は、変換元の式値'04:30:00' (UTC)が、
現在のセッションのタイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE に調整
され、'13:30:00'が導き出されます。
タイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE での現在の日付
'2008-05-14'と、上記の調整後に取得した変換元の式値の時間部分'13:30:00'からタ
イムスタンプが生成されます。タイムゾーン変位 INTERVAL '09:00' HOUR TO
MINUTE での、このタイムスタンプ'2008-05-14 13:30:00'は UTC に合わせて調整
されるため、CAST の結果は UTC で'2008-05-14 04:30:00'と、タイムゾーン変位
INTERVAL '09:00' HOUR TO MINUTE を併せたものになります。
UTC での CAST の結果値はタイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE
に調整されるため、SELECT 文の結果は次のようになります。TIMESTAMP
'2008-05-14 13:30:00+09:00'
例
タイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE での現在の日付が DATE
'2008-05-14'で、タイムゾーン変位 INTERVAL '04:00' HOUR TO MINUTE での現在
の日付は DATE '2008-05-13'だと仮定します。次の SELECT 文は、次の結果を返し
ます。TIMESTAMP '2008-05-14 08:30:00+04:00'
SET TIME ZONE INTERVAL '09:00' HOUR TO MINUTE;
SELECT CAST(TIME '08:30:00+04:00' AS TIMESTAMP(0) WITH TIME ZONE);
文字列定数のタイムゾーン変位 INTERVAL '04:00' HOUR TO MINUTE を使用して、
UTC 値'04:30:00'と、その文字列定数のタイムゾーン変位 INTERVAL '04:00' HOUR
SQL 関数、演算子、式および述部
649
第 13 章 データ型の変換
TIME から TIMESTAMP への変換
TO MINUTE が決定されます。CAST の場合は、変換元の式値'04:30:00' (UTC)が、現
在のセッションのタイムゾーン変位 INTERVAL '09:00' HOUR TO TO MINUTE に調
整され、'13:30:00'が導き出されます。
タイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE での現在の日付'2008-05-14'
と、上記の調整後に取得した変換元の式値の時間部分'13:30:00'からタイムスタンプ
が生成されます。タイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE での、こ
のタイムスタンプ'2008-05-14 13:30:00'は UTC に合わせて調整されるため、CAST
の結果は UTC で'2008-05-14 04:30:00'と、タイムゾーン変位 INTERVAL '04:00'
HOUR TO MINUTE を併せたものになります。
UTC での CAST の結果値はタイムゾーン変位 INTERVAL '04:00' INTERVAL TO
MINUTE に調整されるため、SELECT 文の結果は次のようになります。TIMESTAMP
'2008-05-14 08:30:00+04:00'
例
タイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE での現在の日付が DATE
'2008-05-14'で、タイムゾーン変位 INTERVAL '04:00' HOUR TO MINUTE での現在
の日付は DATE '2008-05-13'だと仮定します。次の SELECT 文は、次の結果を返し
ます。TIMESTAMP '2008-05-13 08:30:00+04:00'
SET TIME ZONE INTERVAL '09:00' HOUR TO MINUTE;
SELECT CAST(TIME '08:30:00+04:00' AS TIMESTAMP(0) WITH TIME ZONE
AT SOURCE);
文字列定数のタイムゾーン変位 INTERVAL '04:00' HOUR TO MINUTE を使用して、
UTC 値'04:30:00'と、その文字列定数のタイムゾーン変位 INTERVAL '04:00' HOUR
TO MINUTE が決定されます。CAST の場合は、変換元の式値'04:30:00' (UTC)が、変
換元の式のタイムゾーン変位 INTERVAL '04:00' HOUR TO MINUTE に調整されて、
'08:30:00'が導き出されます。
タイムゾーン変位 INTERVAL '04:00' HOUR TO MINUTE での現在の日付'2008-05-13'
と、上記の調整後に取得した変換元の式値の時間部分'08:30:00'からタイムスタンプ
が生成されます。タイムゾーン変位 INTERVAL '04:00' HOUR TO MINUTE での、こ
のタイムスタンプ'2008-05-13 08:30:00'は UTC に合わせて調整されるため、CAST
の結果は UTC で'2008-05-13 04:30:00'と、タイムゾーン変位 INTERVAL '04:00'
HOUR TO MINUTE を併せたものになります。
UTC での CAST の結果値はタイムゾーン INTERVAL '04:00' HOUR TO MINUTE に調
整されるため、SELECT 文の結果は次のようになります。TIMESTAMP '13.05.08
08:30:00+04:00'現在のセッションのタイムゾーンは影響しません。
例
タイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE での現在の日付が DATE
'2008-05-14'で、タイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE での現在
の日付は DATE '2008-05-13'だと仮定します。次の SELECT 文は、次の結果を返し
ます。TIMESTAMP '13.05.08 15:30:00-08:00'
650
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIME から TIMESTAMP への変換
SET TIME ZONE INTERVAL '09:00' HOUR TO MINUTE;
SELECT CAST(TIME '08:30:00' AS TIMESTAMP(0) WITH TIME ZONE AT -8);
現在のセッションのタイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE を使用
して、文字列定数の UTC 値'23:30:00'を決定します。CAST の場合は、変換元の式
値'23:30:00' (UTC)が、変換先のタイムゾーン変位 INTERVAL -'08:00' HOUR TO
MINUTE に調整され、'15:30:00'が導き出されます。
タイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE での現在の日付
'2008-05-13'と、上記の調整後に取得した変換元の式値の時間部分'15:30:00'からタ
イムスタンプが生成されます。タイムゾーン変位 INTERVAL -'08:00' HOUR TO
MINUTE での、このタイムスタンプ'2008-05-13 15:30:00'は UTC に合わせて調整
されるため、CAST の結果は UTC で'2008-05-13 23:30:00'と、タイムゾーン変位
INTERVAL -'08:00' HOUR TO MINUTE を併せたものになります。
UTC での CAST の結果値はタイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE
に調整されるため、SELECT 文の結果は次のようになります。TIMESTAMP
'2008-05-13 15:30:00-08:00'
例
タイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE での現在の日付が DATE
'2008-05-14'で、タイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE での現
在の日付は DATE '2008-05-13'だと仮定します。次の SELECT 文は、次の結果を返
します。TIMESTAMP '13.05.08 20:30:00-08:00'
SET TIME ZONE INTERVAL '09:00' HOUR TO MINUTE;
SELECT CAST(TIME '08:30:00+04:00' AS TIMESTAMP(0) WITH TIME ZONE
AT -8);
文字列定数のタイムゾーン変位 INTERVAL '04:00' HOUR TO MINUTE を使用して、
UTC 値'04:30:00'と、その文字列定数のタイムゾーン変位 INTERVAL '04:00' HOUR
TO MINUTE が決定されます。CAST の場合は、変換元の式値'04:30:00' (UTC)が、
変換先のタイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE に調整され、
'20:30:00'が導き出されます。
タイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE での現在の日付
'2008-05-13'と、上記の調整後に取得した変換元の式値の時間部分'20:30:00'からタ
イムスタンプが生成されます。タイムゾーン変位 INTERVAL -'08:00' HOUR TO
MINUTE での、このタイムスタンプ'2008-05-13 20:30:00'は UTC に合わせて調整
されるため、CAST の結果は UTC で'14.05.08 04:30:00'と、タイムゾーン変位
INTERVAL -'08:00' HOUR TO MINUTE を併せたものになります。
UTC での CAST の結果値はタイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE
に調整されるため、SELECT 文の結果は次のようになります。TIMESTAMP
'2008-05-13 20:30:00-08:00'現在のセッションのタイムゾーンは影響しません。
例
この例では、現在のタイムスタンプは次のとおりです。
SQL 関数、演算子、式および述部
651
第 13 章 データ型の変換
TIME から UDT への変換
Current TimeStamp(6)
-------------------------------2010-03-09 19:23:27.620000+00:00
次の文では、TIME 値'08:30:00'を、TIMESTAMP 値に変換します。ここでのタイム
ゾーン変位は、タイムゾーン文字列'America Pacific'に基づきます。
SELECT CAST(TIME '08:30:00' AS TIMESTAMP(0) AT 'America Pacific');
問合わせの結果は、次のとおりです。
08:30:00
------------------2010-03-09 08:30:00
例
この例では、現在のタイムスタンプは次のとおりです。
Current TimeStamp(6)
-------------------------------2010-03-09 19:23:27.620000+00:00
次の文では、TIME 値'08:30:00+04:00'を、TIMESTAMP 値に変換します。ここでの
タイムゾーン変位は、タイムゾーン文字列'America Pacific'に基づきます。
SELECT CAST(TIME '08:30:00+04:00' AS TIMESTAMP(0)
AT 'America Pacific');
問合わせの結果は、次のとおりです。
08:30:00+04:00
------------------2010-03-10 04:30:00
関連トピック
データ型およびデータ属性について、詳細は< SQL データ型とリテラル、B035-1143>
を参照してください。
TIME から UDT への変換
目的
TIME データを UDT データに変換します。
652
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIME から UDT への変換
CAST 構文
CAST
( timestamp_expression
AS
UDT_data_type (
構文要素
time_expression
変換する TIME 式。
UDT_data_definition
式が変換される UDT の型(FORMAT、NAMED、または TITLE データ属性句が続く)。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、FORMAT などのデータ属性句を CAST で使用できます。
使用上の注意
Teradata 変換構文を使った TIME から UDT への明示的な変換はサポートされてい
ません。
UDT の関与するデータ型の変換には、その UDT に適した CAST 定義が必要です。
UDT の CAST を定義するには、CREATE CAST 文を使用します。CREATE CAST の詳
細は、<SQL データ定義言語 - 構文規則および例、B035-1144>を参照してください。
TIME から UDT への暗黙的変換
Teradata Database は、以下の操作に対して TIME から UDT への暗黙的変換を実行
します。
• UPDATE
• INSERT
• ストアド プロシージャ、外部ストアド プロシージャ、UDF、および UDM への
引数の引渡し。
• このマニュアル中の他の箇所に明記されている特定のシステム演算子と関数 (DBS
制御レコードの DisableUDTImplCastForSysFuncOp フィールドが TRUE に設定さ
れていない場合に限る)。
暗黙のデータ型変換を実行するには、AS ASSIGNMENT 句を指定する適切な CAST
定義(「使用上の注意」を参照)が存在する必要があります。
TIME から UDT への暗黙的なキャスト定義が存在しない場合、Teradata Database は
TIME から UDT への暗黙的なキャスト定義に代用できる CHAR から UDT への、ま
たは VARCHAR から UDT への暗黙的なキャスト定義を検索します。Teradata
Database は TIME 型を文字データ型に暗黙的にキャストしてから、暗黙的なキャス
SQL 関数、演算子、式および述部
653
第 13 章 データ型の変換
TIMESTAMP から文字への変換
ト定義を使用して、その文字データ型から UDT へのキャストを行なえるため、代用
は有効です。文字から UDT への暗黙の CAST 定義が複数存在する場合、Teradata
Database は SQL エラーを戻します。
関連トピック
データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
TIMESTAMP から文字への変換
目的
TIMESTAMP データを文字列に変換します。
CAST 構文
CAST
( timestamp_expression
AS
A
character_data_type
)
A
CHARACTER SET
server_character_set
data_attribute
構文要素
timestamp_expression
変換する TIME 式。
character_data_type
式が変換されるデータ型。
server_character_set
変換に使用するサーバー文字セット。CHARACTER SET 句を省略した場合は、ユー
ザー デフォルトのサーバー文字セットが使用されます。
character_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
654
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIMESTAMP から文字への変換
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、CAST で文字データ属性句を使用できます。
Teradata 変換構文
timestamp_expression
(
character_data_type
A
data_attribute ,
)
A
,
data_attribute
CHARACTER SET
server_character_set
構文要素
timestamp_expression
変換する TIMESTAMP 式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
character_data_type
式が変換されるデータ型。
server_character_set
変換に使用するサーバー文字セット。CHARACTER SET 句を省略した場合は、ユー
ザー デフォルトのサーバー文字セットが使用されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
TIMESTAMP から CHAR(n)または VARCHAR(n)への変換時に、n は、文字列定数に
よって表わされた TIMESTAMP 値の長さと等しいかそれよりも長くなければなりま
せん。
SQL 関数、演算子、式および述部
655
第 13 章 データ型の変換
TIMESTAMP から文字への変換
変換先データ タイプ
n
CHAR(n)
文字列定数で表わされた
末尾の埋め込み文字が表記を埋める
TIMESTAMP 値の長さより ために追加される。
長い
小さすぎる
VARCHAR(n)
結果
文字切り捨てエラーが戻される。
文字列定数で表わされた
ブランク埋め込みは文字表記に追加
TIMESTAMP 値の長さより されない。
長い
小さすぎる
文字切り捨てエラーが戻される。
TIMESTAMP から CLOB への変換はサポートされていません。
サーバー文字セットが GRAPHIC の場合は、TIME 値を文字列に変換することはでき
ません。
TIMESTAMP から文字への変換に対する CAST での FORMAT の強制
TIMESTAMP から文字への変換のデフォルトの書式は、TIMESTAMP 値に有効な書式
を使用します。
この書式をオーバーライドするには、FORMAT 句を使って、TIMESTAMP 値を文字
列に変換できます。ただし、結果の書式は、TIMESTAMP 値と同じになります。文
字列値で別の書式を使用する場合は、以下で説明するように CAST を併用する必要
があります。
TIMESTAMP 値に関連する書式にかかわらず、TIMESTAMP から CHAR に値を変換
し、その結果において明示的な FORMAT を強制するには、入れ子 CAST 操作を行な
う必要があります。これは、FORMAT 句をデータ タイプに突き合わせるための規則
によるものです。
例
テーブル INTTIMESTAMP のフィールド TS1 は、明示的なフォーマット'Y4-MMDDBHH:MI:SSDS(6)'を使用した TIMESTAMP 値です。この値を CHAR(19)の値に変換
し、'M3BDD,BY4BHHhMIm'の明示的な出力フォーマットにすると仮定します。
SELECT TS1 FROM INTTIMESTAMP;
結果(タイプの変更はなし)は、以下のレポートになります。
TS1
-------------------------1900-12-31 08:25:37.899231
入れ子 CAST 句と FORMAT を使って、目的の結果を入手します。つまり、文字書式
のレポートです。
656
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIMESTAMP から DATE への変換
SELECT
CAST( (CAST (TS1 AS FORMAT 'M3BDD,BY4BHHhMIm'))
AS CHAR(19))
FROM INTTIMESTAMP;
入れ子 CAST の結果は、以下のレポートになります。
TS1
------------------Dec 31, 1900 08h25m
内部 CAST は TIMESTAMP 値の表示書式を確立し、外部 CAST は必要な結果のデー
タ タイプを示します。
関連トピック
データ型およびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
TIMESTAMP から DATE への変換
目的
TIMESTAMP データを DATE 値に変換します。
CAST 構文
CAST
( timestamp_expression
AS
A
DATE
)
A
AT
LOCAL
data_attribute
SOURCE
TIME ZONE
expression
TIME ZONE
time_zone_string
構文要素
timestamp_expression
変換する TIMESTAMP 式。
SQL 関数、演算子、式および述部
657
第 13 章 データ型の変換
TIMESTAMP から DATE への変換
AT LOCAL
現在のセッションのタイムゾーンに基づくタイムゾーン変位を使用します。
AT SOURCE [TIME ZONE]
次の場合に、timestamp_expression に付随するタイムゾーンを使用します。
• AT SOURCE TIME ZONE が指定される。
• AT SOURCE が without TIME ZONE で指定され、範囲に source という列がない。
その他の場合、AT SOURCE が without TIME ZONE で指定され、source という列が
存在する場合、SOURCE はこの列を参照し、列の値は CAST のタイムゾーン変位と
して使用されます。必要な場合、列値が型 INTERVAL HOUR(2) TO MINUTE に暗黙
的に変換されます。
AT [TIME ZONE] expression
式で定義されたタイムゾーンの変位を使用します。
expression のデータ タイプは INTERVAL HOUR(2) TO MINUTE か、暗黙的に
INTERVAL HOUR(2) TO MINUTE に変換できるデータ タイプでなければなりません。
AT [TIME ZONE] time_zone_string
time_zone_string は、タイムゾーン変位を決定します。
date_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、代替書式を可能にする FORMAT などの DATE データ属性
句を CAST で使用できます。
AT 句は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、CAST を使用した TIMESTAMP から DATE への変換に、AT
句がサポートされるようになりました。また、INTERVAL 式の他にも追加の式を使
用して、タイムゾーン変位を指定することができます。
注: TIMESTAMP (without time zone)は、ANSI SQL:2011 互換ではありません。
Teradata Database は、現行セッションのタイムゾーン、または指定されたタイム
ゾーンに基づいて、TIMESTAMP 値を内部的に UTC に変換します。
658
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIMESTAMP から DATE への変換
Teradata 変換構文
timestamp_expression
(
B
DATE
data_attribute ,
)
B
AT
LOCAL
, data_attribute
SOURCE
TIME ZONE
expression
TIME ZONE
time_zone_string
構文要素
timestamp_expression
変換する TIME 式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
fractional_seconds_precision
SECOND フィールドの小数部の有効桁数を表わす 1 桁の数字。有効な範囲は、0 か
ら 6 です。デフォルトは 6 です。
AT LOCAL
現在のセッションのタイムゾーンに基づくタイムゾーン変位を使用します。
AT SOURCE [TIME ZONE]
次の場合に、timestamp_expression に付随するタイムゾーンを使用します。
• AT SOURCE TIME ZONE が指定される。
• AT SOURCE が without TIME ZONE で指定され、範囲に source という列がない。
その他の場合、AT SOURCE が without TIME ZONE で指定され、source という列が
存在する場合、SOURCE はこの列を参照し、列の値は CAST のタイムゾーン変位と
して使用されます。必要な場合、列値が型 INTERVAL HOUR(2) TO MINUTE に暗黙
的に変換されます。
AT [TIME ZONE] expression
式で定義されたタイムゾーンの変位を使用します。
SQL 関数、演算子、式および述部
659
第 13 章 データ型の変換
TIMESTAMP から DATE への変換
expression のデータ タイプは INTERVAL HOUR(2) TO MINUTE か、暗黙的に
INTERVAL HOUR(2) TO MINUTE に変換できるデータ タイプでなければなりません。
AT [TIME ZONE] time_zone_string
time_zone_string は、タイムゾーン変位を決定します。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
AT 句は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、Teradata 変換構文を使用した TIMESTAMP から DATE への
変換に、AT 句がサポートされるようになりました。また、INTERVAL 式の他にも追
加の式を使用して、タイムゾーン変位を指定することができます。
注: TIMESTAMP (without time zone)は、ANSI SQL:2011 互換ではありません。
Teradata Database は、現行セッションのタイムゾーン、または指定されたタイム
ゾーンに基づいて、TIMESTAMP 値を内部的に UTC に変換します。
使用上の注意
次の表は、CAST 関数、または各種の指定オプションに基づいた Teradata 変換の結
果を示しています。タイムゾーンの調整により、DATE 値の YEAR、MONTH、およ
び DAY フィールドが変更される場合があります。
指定内容
timestamp_expressio THEN...
n のデータ型
AT LOCAL
TIME ZONE の有無は 現在のセッションのタイムゾーンに基づくタイムゾー
関係なし
ン変位を加えることで UTC 値を調整した後の、変換
元の timestamp_expression の日付部分が結果になり
ます。
これは、AT 句を指定しない場合と同じ結果になりま
す。
AT SOURCE
WITH TIME ZONE
timestamp_expression に関連付けられたタイムゾー
ン変位を加えることで UTC 値を調整した後の、変換
元の timestamp_expression の日付部分が結果になり
ます。
without TIME ZONE
エラーが戻されます。
(SOURCE はキーワードであり、列参
照ではありません)
AT SOURCE
(SOURCE はキーワードであり、列参
照ではありません)
660
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIMESTAMP から DATE への変換
指定内容
timestamp_expressio THEN...
n のデータ型
AT SOURCE TIME ZONE
WITH TIME ZONE
timestamp_expression に関連付けられたタイムゾー
ン変位を加えることで UTC 値を調整した後の、変換
元の timestamp_expression の日付部分が結果になり
ます。
AT SOURCE TIME ZONE
without TIME ZONE
エラーが戻されます。
AT 式または
AT TIME ZONE expression
TIME ZONE の有無は expression で定義されるタイムゾーン変位を加える
関係なし
ことで UTC 値を調整した後の、変換元の
timestamp_expression の日付部分が結果になりま
す。
AT time_zone_string または
AT TIME ZONE time_zone_string
TIME ZONE の有無は 結果は、time_zone_string に基づくタイムゾーン変
関係なし
位を追加してその UTC 値を調整した後の変換元
timestamp_expression の日付部分です。タイムゾー
ン変位は、time_zone_string と、
timestamp_expression の TIMESTAMP 値を基に決
定されます。
TIMESTAMP から DATE への暗黙的変換
Teradata Database は、TIMESTAMP タイプから DATE への暗黙的変換を実行する場
合があります。「DateTime 型の暗黙的変換」を参照してください。
以下の変換をサポートします。
変換元タイプ
変換先タイプ
TIMESTAMP
DATE
TIMESTAMP WITH TIME ZONE
ANSIDate 日付形式モードまたは IntegerDate
日付形式モード
TIMESTAMP 値は、比較の場合には常に DATE に変換されます。
例
例
単一列のテーブルに、TIMESTAMP(0) WITH TIME ZONE タイプの行が 3 つあります。
フィールド値を要求し、それらを DATE としてキャストする問合せが、その現地の
タイムゾーンが-’08:00’に定義されているセッション時に実行されます。
結果として得られるテーブルは、以下のとおりです。
TimeStampWithTimeZone
CastAsDate
-------------------------------------------------
SQL 関数、演算子、式および述部
661
第 13 章 データ型の変換
TIMESTAMP から DATE への変換
1997-10-07 15:43:00+08:00 1997-10-06
1997-10-07 15:47:52-08:00 1997-10-07
1997-10-07 15:43:00-00:00 1997-10-07
格納されたタイムゾーンと現地タイムゾーンの差は最初の行では 16 時間ですが、同
時に TimeStamp 値は 15:43 であり、16 時間よりも少ない点に注意する必要があり
ます。
このような結果の不一致は、TIMESTAMP(0)として TIMESTAMP(0) WITH TIME
ZONE をキャストする類似した問合わせを使用してタイムゾーン情報を省略すると、
解決することができます。
この問合わせの結果のテーブルは、以下のとおりです。
TimeStampWithTimeZone
CastAsTimeStamp
------------------------------------------------1997-10-07 15:43:00+08:00 1997-10-06 23:43:00
1997-10-07 15:47:52-08:00 1997-10-07 15:47:52
1997-10-07 15:43:00-00:00 1997-10-07 07:43:00
CAST の後、値はすべて現地タイムゾーンで表示され、最初の行の値は 16 時間調整
されて、日付が 1 日戻った遅い時間を示します。
例
次の文を考えてみましょう。
SET TIME ZONE INTERVAL '01:00' HOUR TO MINUTE;
SELECT CAST(TIMESTAMP '2008-05-31 22:30:00-08:00'
AS DATE AT SOURCE TIME ZONE);
SELECT TIMESTAMP '2008-06-01 06:30:00+00:00' AT '-08:00'
(DATE, AT SOURCE);
SELECT TIMESTAMP '2008-06-01 06:30:00+00:00' (DATE, AT -8);
SELECT TIMESTAMP '2008-06-01 07:30:00' (DATE, AT -8);
これらの SELECT 文は、タイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE の
日付を返します。つまり、これらの文は'08/05/31'を返します。これらの SELECT
文に AT 句が指定されていない、または AT LOCAL 句が指定されている場合は、現
在のセッションのタイムゾーン変位 INTERVAL '01:00' HOUR TO MINUTE の
'08/06/01'が返されることになります。
次に、AT 句が指定されていなかった場合の、SELECT 文の結果を示します。
SET TIME ZONE INTERVAL '01:00' HOUR TO MINUTE;
SELECT CAST(TIMESTAMP '2008-05-31 22:30:00-08:00' AS DATE);
2008-05-31 22:30:00-08:00
------------------------08/06/01
SELECT TIMESTAMP '2008-06-01 06:30:00+00:00'
AT TIME ZONE INTERVAL -'08:00' HOUR TO MINUTE;
662
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIMESTAMP から DATE への変換
2008-06-01 06:30:00+00:00 AT TIME ZONE INTERVAL -8:00 HOUR TO MINUTE
-------------------------------------------------------------------2008-05-31 22:30:00-08:00
SELECT TIMESTAMP '2008-06-01 06:30:00+00:00'
AT TIME ZONE INTERVAL -'08:00' HOUR TO MINUTE (DATE);
2008-06-01 06:30:00+00:00 AT TIME ZONE INTERVAL -8:00 HOUR TO MINUTE
-------------------------------------------------------------------08/06/01
SELECT TIMESTAMP '2008-06-01 06:30:00+00:00' (DATE);
2008-06-01 06:30:00+00:00
------------------------08/06/01
SELECT TIMESTAMP '2008-06-01 07:30:00' (DATE);
2008-06-01 07:30:00
------------------08/06/01
次に、現在のセッションのタイムゾーン変位が INTERVAL -'08:00' HOUR TO MINUTE
で、AT 句が指定されていない SELECT 文の結果を示します。
SET TIME ZONE INTERVAL -'08:00' HOUR TO MINUTE;
SELECT CAST(TIMESTAMP '2008-05-31 22:30:00-08:00' AS DATE);
2008-05-31 22:30:00-08:00
------------------------08/05/31
SELECT TIMESTAMP '2008-06-01 06:30:00+00:00'
AT TIME ZONE INTERVAL -'08:00' HOUR TO MINUTE (DATE);
2008-06-01 06:30:00+00:00 AT TIME ZONE INTERVAL -8:00 HOUR TO MINUTE
-------------------------------------------------------------------08/05/31
SELECT TIMESTAMP '2008-06-01 06:30:00+00:00' (DATE);
2008-06-01 06:30:00+00:00
------------------------08/05/31
SELECT CAST(TIMESTAMP '2008-06-01 07:30:00+01:00'
AS TIMESTAMP(0)) (DATE);
2008-06-01 07:30:00+01:00
------------------------08/05/31
例
次の文を考えてみましょう。
SET TIME ZONE INTERVAL '01:00' HOUR TO MINUTE;
SELECT CAST(TIMESTAMP '2008-06-02 04:30:00+09:00'
AS DATE AT SOURCE TIME ZONE);
SQL 関数、演算子、式および述部
663
第 13 章 データ型の変換
TIMESTAMP から DATE への変換
SELECT TIMESTAMP '2008-06-01 20:30:00+01:00'
AT TIME ZONE INTERVAL '09' HOUR (DATE, AT SOURCE);
SELECT TIMESTAMP '2008-06-01 20:30:00' (DATE, AT +9);
これらの SELECT 文は、タイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE の
日付を返します。つまり、これらの文は'08/06/02'を返します。これらの SELECT
文に AT 句が指定されていない、または AT LOCAL 句が指定されている場合は、現
在のセッションのタイムゾーン変位 INTERVAL '01:00' HOUR TO MINUTE の
'08/06/01'が返されることになります。
次に、AT 句が指定されていなかった場合の、SELECT 文の結果を示します。
SET TIME ZONE INTERVAL '01:00' HOUR TO MINUTE;
SELECT CAST(TIMESTAMP '2008-06-02 04:30:00+09:00' AS DATE);
2008-06-02 04:30:00+09:00
------------------------08/06/01
SELECT TIMESTAMP '2008-06-01 20:30:00+01:00'
AT TIME ZONE INTERVAL '09:00' HOUR TO MINUTE;
2008-06-01 20:30:00+01:00 AT TIME ZONE INTERVAL 9:00 HOUR TO MINUTE
-------------------------------------------------------------------2008-06-02 04:30:00+09:00
SELECT TIMESTAMP '2008-06-01 20:30:00+01:00'
AT TIME ZONE INTERVAL '09:00' HOUR TO MINUTE (DATE);
2008-06-01 20:30:00+01:00 AT TIME ZONE INTERVAL 9:00 HOUR TO MINUTE
-------------------------------------------------------------------08/06/01
SELECT TIMESTAMP '2008-06-01 20:30:00' (DATE);
2008-06-01 20:30:00
------------------08/06/01
次に、現在のセッションのタイムゾーン変位が INTERVAL '09:00' TO MINUTE で、
AT 句が指定されていない SELECT 文の結果を示します。
SET TIME ZONE INTERVAL '09:00' HOUR TO MINUTE;
SELECT CAST(TIMESTAMP '2008-06-02 04:30:00+09:00' AS DATE);
2008-06-02 04:30:00+09:00
------------------------08/06/02
SELECT TIMESTAMP '2008-06-01 20:30:00+01:00'
AT TIME ZONE INTERVAL '09:00' HOUR TO MINUTE (DATE);
2008-06-01 20:30:00+01:00 AT TIME ZONE INTERVAL 9:00 HOUR TO MINUTE
-------------------------------------------------------------------08/06/02
SELECT CAST(TIMESTAMP '2008-06-01 20:30:00+01:00'
AS TIMESTAMP(0)) (DATE);
664
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIMESTAMP から DATE への変換
2008-06-01 20:30:00+01:00
------------------------08/06/02
例
次の文を考えてみましょう。
SET TIME ZONE INTERVAL '10:00' HOUR TO MINUTE;
SELECT CAST((TIMESTAMP '2008-06-01 18:30:00+01:00' AT '05:45')
AS DATE AT SOURCE);
SELECT CAST((TIMESTAMP '2008-06-01 18:30:00+01:00' AT 5.75)
AS DATE AT SOURCE);
SELECT TIMESTAMP '2008-06-01 23:15:00+05:45'
(DATE, AT SOURCE TIME ZONE);
SELECT TIMESTAMP '2008-06-02 03:30:00' (DATE, AT '05:45');
SELECT TIMESTAMP '2008-06-02 03:30:00' (DATE, AT 5.75);
これらの SELECT 文は、タイムゾーン変位 INTERVAL '05:45' HOUR TO MINUTE の
日付を返します。つまり、これらの文は'08/06/01'を返します。これらの SELECT
文に AT 句が指定されていない、または AT LOCAL 句が指定されている場合は、現
在のセッションのタイムゾーン変位 INTERVAL '10:00' HOUR TO MINUTE の
'08/06/02'が返されることになります。
次に、AT 句が指定されていなかった場合の、SELECT 文の結果を示します。
SET TIME ZONE INTERVAL '10:00' HOUR TO MINUTE;
SELECT TIMESTAMP '2008-06-01 18:30:00+01:00'
AT TIME ZONE INTERVAL '05:45' HOUR TO MINUTE;
2008-06-01 18:30:00+01:00 AT TIME ZONE INTERVAL 5:45 HOUR TO MINUTE
-------------------------------------------------------------------2008-06-01 23:15:00+05:45
SELECT CAST((TIMESTAMP '2008-06-01 18:30:00+01:00'
AT TIME ZONE INTERVAL '05:45' HOUR TO MINUTE) AS DATE);
2008-06-01 18:30:00+01:00 AT TIME ZONE INTERVAL 5:45 HOUR TO MINUTE
-------------------------------------------------------------------08/06/02
SELECT TIMESTAMP '2008-06-01 23:15:00+05:45' (DATE);
2008-06-01 23:15:00+05:45
------------------------08/06/02
SELECT TIMESTAMP '2008-06-02 03:30:00' (DATE);
2008-06-02 03:30:00
------------------08/06/02
次に、現在のセッションのタイムゾーン変位が INTERVAL '05:45' HOUR TO MINUTE
で、AT 句が指定されていない SELECT 文の結果を示します。
SQL 関数、演算子、式および述部
665
第 13 章 データ型の変換
TIMESTAMP から DATE への変換
SET TIME ZONE INTERVAL '05:45' HOUR TO MINUTE;
SELECT CAST((TIMESTAMP '2008-06-01 18:30:00+01:00'
AT TIME ZONE INTERVAL'05:45' HOUR TO MINUTE) AS DATE);
2008-06-01 18:30:00+01:00 AT TIME ZONE INTERVAL 5:45 HOUR TO MINUTE
-------------------------------------------------------------------08/06/01
SELECT TIMESTAMP '2008-06-01 23:15:00+05:45' (DATE);
2008-06-01 23:15:00+05:45
------------------------08/06/01
SELECT CAST(TIMESTAMP '2008-06-02 03:30:00+10:00'
AS TIMESTAMP(0)) (DATE);
2008-06-02 03:30:00+10:00
------------------------08/06/01
例
次の文を考えてみましょう。
SET TIME ZONE +1;
SELECT CAST((TIMESTAMP '2008-06-01 08:30:00' AT TIME ZONE -8)
AS DATE AT SOURCE TIME ZONE);
この SELECT 文は、タイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE の日付
を返します。つまり、この文は'08/05/31'を返します。この SELECT 文に AT 句が指
定されていない、または AT LOCAL 句が指定されている場合は、現在のセッション
のタイムゾーン変位 INTERVAL HOUR '01:00' MINUTE の'08/06/01'が返されること
になります。
次に、AT 句が指定されていなかった場合の、SELECT 文の結果を示します。
SET TIME ZONE INTERVAL '01:00' HOUR TO MINUTE;
SELECT TIMESTAMP '2008-06-01 08:30:00'
AT TIME ZONE INTERVAL -'08:00' HOUR TO MINUTE;
2008-06-01 08:30:00 AT TIME ZONE INTERVAL -8:00 HOUR TO MINUTE
-------------------------------------------------------------2008-05-31 23:30:00-08:00
SELECT CAST((TIMESTAMP '2008-06-01 08:30:00'
AT TIME ZONE INTERVAL -'08:00' HOUR TO MINUTE) AS DATE);
2008-06-01 08:30:00 AT TIME ZONE INTERVAL -8:00 HOUR TO MINUTE
-------------------------------------------------------------08/06/01
次に、現在のセッションのタイムゾーン変位が INTERVAL -'08:00' HOUR TO MINUTE
で、AT 句が指定されていない SELECT 文の結果を示します。
666
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIMESTAMP から DATE への変換
SET TIME ZONE INTERVAL -'08:00' HOUR TO MINUTE;
SELECT CAST((CAST(TIMESTAMP '2008-06-01 08:30:00+01:00'
AS TIMESTAMP(0)) AT TIME ZONE INTERVAL -'08:00' HOUR TO MINUTE)
AS DATE);
2008-06-01 08:30:00+01:00 AT TIME ZONE INTERVAL -8:00 HOUR TO MINUTE
-------------------------------------------------------------------08/05/31
例
この例では、現在のタイムスタンプは次のとおりです。
Current TimeStamp(6)
-------------------------------2010-03-09 19:23:27.620000+00:00
次の文では、TIMESTAMP 値'2010-03-09 22:30:00-08:00'を、DATE 値に変換しま
す。ここでのタイムゾーン変位は、タイムゾーン文字列'America Pacific'に基づきま
す。
SELECT CAST(TIMESTAMP '2010-03-09 22:30:00-08:00' AS DATE
AT 'America Pacific');
問合わせの結果は、次のとおりです。
2010-03-09 22:30:00-08:00
------------------------10/03/09
例
次の SELECT 文は、変換元の式に TIMESTAMP WITH TIME ZONE データ タイプが
存在しないために、エラーを返します。
SELECT
SELECT
SELECT
SELECT
CAST(TIMESTAMP '2008-06-01 08:30:00' AS DATE AT SOURCE);
CAST(TIME '08:30:00+03:00' AS DATE AT SOURCE TIME ZONE);
CAST(TIME '08:30:00' AS DATE AT SOURCE);
CAST(DATE '2008-06-01' AS DATE AT SOURCE TIME ZONE);
関連トピック
データ型およびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
SQL 関数、演算子、式および述部
667
第 13 章 データ型の変換
TIMESTAMP から Period への変換
TIMESTAMP から Period への変換
目的
TIMESTAMP 値を PERIOD(DATE)、PERIOD(TIME[(n)][WITH TIME ZONE])、または
PERIOD(TIMESTAMP[(n)][WITH TIME ZONE])として変換します。
CAST 構文
CAST
( time_expression
AS
)
period_data_type
data_attribute
構文要素
timestamp_expression
変換する TIMESTAMP 式。
period_data_type
式が変換されるデータ型。
period_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、CAST でデータ属性句を使用できます。
使用上の注意
TIMESTAMP(n) [WITH TIME ZONE]値は、CAST 関数を使用すると PERIOD(DATE)、
PERIOD(TIME[(n)] [WITH TIME ZONE])、または PERIOD(TIMESTAMP[(n)] [WITH
TIME ZONE])としてキャストできます。
変換先タイプが PERIOD(TIME(n) [WITH TIME ZONE])または
PERIOD(TIMESTAMP(n)[WITH TIME ZONE])の場合、次のようになります。
• 変換先の精度が変換元の精度より高い場合、精度を調整するために結果の境界の
末尾にゼロが追加されます。
• 変換先の精度が変換元の精度より低い場合、エラーが報告されます。
668
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIMESTAMP から Period への変換
変換先のタイプが PERIOD(DATE)の場合、結果の開始境界は現在のセッションのタ
イムゾーンに調整された変換元の開始境界の日付部分になります。
変換先のタイプが PERIOD(TIME[(n)])の場合、結果の開始境界は変換元の(UTC で
の)値の時間部分になります。
変換先のタイプが PERIOD(TIME[(n)] WITH TIME ZONE)の場合、結果の開始境界
は、変換元の値の(UTC での)時間部分と、変換元のタイプが WITH TIME ZONE の場
合は変換元のタイムゾーン変位から、また変換元のタイプが WITH TIME ZONE で
ない場合は現在のセッションのタイムゾーン変位から作成されます。
変換先のタイプが PERIOD(TIMESTAMP[(n)])の場合、結果の開始境界は変換元の
(UTC での)値のタイムスタンプ部分になります。
変換先のタイプが PERIOD(TIMESTAMP[(n)] WITH TIME ZONE)の場合、結果の開始
境界は、変換元の(UTC での)値のタイムスタンプ部分と、変換元のタイプが WITH
TIME ZONE の場合は変換元のタイムゾーン変位から、また変換元のタイプが WITH
TIME ZONE でない場合は現在のセッションのタイムゾーン変位から作成されます。
変換元の TIMESTAMP 値にうるう秒が含まれている場合、秒部分は変換先の精度に
まで精度を切り詰めた 59.999999 に調整されます。
結果の終了要素は、結果の開始境界に変換先タイプの 1 最小単位を加算したものに
設定されます。結果の終了境界が、PERIOD(DATE)または PERIOD(TIMESTAMP[(n)])
の変換先タイプに許容された DATE または TIMESTAMP のそれぞれの最大値を超え
る場合や、終了境界の値が、UTC 形式で PERIOD(TIME[(n)])の変換先タイプの結果
の開始境界より小さい場合には、エラーが報告されます。
注: 変換先タイプが WITH TIME ZONE の場合、結果の開始境界および終了境界は同
じタイムゾーンでなければなりません。
また、結果は開始境界と最後の値が同じ値になることに注意してください。
例
以下の例では、TIMESTAMP(6)リテラルを PERIOD(DATE)としてキャストします。
結果の開始要素は変換元の値の日付部分に設定されます。結果の終了要素は、結果
の開始境界に INTERVAL '1' DAY を加算したものに設定されます。
SELECT CAST(TIMESTAMP '2005-02-03 12:12:12.340000' AS PERIOD(DATE));
次の結果が返されます。
('2005-02-03', '2005-02-04')
関連トピック
データ型およびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
SQL 関数、演算子、式および述部
669
第 13 章 データ型の変換
TIMESTAMP から TIME への変換
TIMESTAMP から TIME への変換
目的
TIMESTAMP データを TIME 値に変換します。
CAST 構文
CAST
( timestamp_expression
AS
A
TIME
(fractional_seconds_precision)
B
A
WITH TIME ZONE
AT
LOCAL
SOURCE
TIME ZONE
TIME ZONE
expression
time_zone_string
)
B
data_attribute
構文要素
timestamp_expression
変換する TIMESTAMP 式。
fractional_seconds_precision
SECOND フィールドの小数部の有効桁数を表わす 1 桁の数字。有効な範囲は、0 か
ら 6 です。デフォルトは 6 です。
AT LOCAL
現在のセッションのタイムゾーンに基づくタイムゾーン変位を使用します。
AT SOURCE [TIME ZONE]
次の場合に、timestamp_expression に付随するタイムゾーンを使用します。
• AT SOURCE TIME ZONE が指定される。
• AT SOURCE が without TIME ZONE で指定され、範囲に source という列がない。
その他の場合、AT SOURCE が without TIME ZONE で指定され、source という列が
存在する場合、SOURCE はこの列を参照し、列の値は CAST のタイムゾーン変位と
して使用されます。必要な場合、列値が型 INTERVAL HOUR(2) TO MINUTE に暗黙
的に変換されます。
AT [TIME ZONE] expression
式で定義されたタイムゾーンの変位を使用します。
670
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIMESTAMP から TIME への変換
expression のデータ タイプは INTERVAL HOUR(2) TO MINUTE か、暗黙的に
INTERVAL HOUR(2) TO MINUTE に変換できるデータ タイプでなければなりません。
AT [TIME ZONE] time_zone_string
time_zone_string は、タイムゾーン変位を決定します。
time_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、CAST で TIME データ属性句を使用できます。
AT 句は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、CAST を使用した TIMESTAMP から TIME への変換に、AT
句がサポートされるようになりました。また、INTERVAL 式の他にも追加の式を使
用して、タイムゾーン変位を指定することができます。
注: TIME(タイムゾーンなし)と TIMESTAMP(タイムゾーンなし)は ANSI SQL:2011 準
拠ではありません。Teradata Database は、現行セッションのタイムゾーンまたは指
定されたタイムゾーンに基づいて TIME 値または TIMESTAMP 値を UTC に内部的に
変換します。
Teradata 変換構文
CAST
( timestamp_expression
AS
A
TIME
(fractional_seconds_precision)
B
A
WITH TIME ZONE
AT
LOCAL
SOURCE
TIME ZONE
TIME ZONE
expression
time_zone_string
)
B
data_attribute
SQL 関数、演算子、式および述部
671
第 13 章 データ型の変換
TIMESTAMP から TIME への変換
構文要素
timestamp_expression
変換する TIMESTAMP 式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
fractional_seconds_precision
SECOND フィールドの小数部の有効桁数を表わす 1 桁の数字。有効な範囲は、0 か
ら 6 です。デフォルトは 6 です。
AT LOCAL
現在のセッションのタイムゾーンに基づくタイムゾーン変位を使用します。
AT SOURCE [TIME ZONE]
次の場合に、timestamp_expression に付随するタイムゾーンを使用します。
• AT SOURCE TIME ZONE が指定される。
• AT SOURCE が without TIME ZONE で指定され、範囲に source という列がない。
その他の場合、AT SOURCE が without TIME ZONE で指定され、source という列が
存在する場合、SOURCE はこの列を参照し、列の値は CAST のタイムゾーン変位と
して使用されます。必要な場合、列値が型 INTERVAL HOUR(2) TO MINUTE に暗黙
的に変換されます。
AT [TIME ZONE] expression
式で定義されたタイムゾーンの変位を使用します。
expression のデータ タイプは INTERVAL HOUR(2) TO MINUTE か、暗黙的に
INTERVAL HOUR(2) TO MINUTE に変換できるデータ タイプでなければなりません。
AT [TIME ZONE] time_zone_string
time_zone_string は、タイムゾーン変位を決定します。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
AT 句は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、Teradata 変換構文を使用した TIMESTAMP から TIME への
変換に、AT 句がサポートされるようになりました。また、INTERVAL 式の他にも追
加の式を使用して、タイムゾーン変位を指定することができます。
672
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIMESTAMP から TIME への変換
注: TIME (without time zone)と TIMESTAMP (without time zone)は ANSI SQL:2011
互換ではありません。Teradata Database は、現行セッションのタイムゾーン、また
は指定されたタイムゾーンに基づいて、TIMESTAMP 値を内部的に UTC に変換しま
す。
使用上の注意
変換先データ タイプにタイムゾーンがない TIME[(n)]の AT 句を指定すると、エラー
が返されます。
変換先データ タイプが TIME[(n)] WITH TIME ZONE の AT 句を指定した場合の、
CAST 関数、または各種の指定オプションに基づいた Teradata 変換の結果を以下の
表に示します。変換先の精度が変換元の精度より高い場合、精度を調整するために
結果の末尾にゼロが追加されます。変換先の精度が変換元の精度より低い場合、エ
ラーが返されます。
指定内容
timestamp_expressio THEN...
n のデータ型
AT LOCAL
TIME ZONE の有無は 変換元の timestamp_expression (UTC)と、現在の
関係なし
セッションのタイムゾーンに基づくタイムゾーン変
位から結果が生成されます。
timestamp_expression のデータ型がタイムゾーンな
しのときには、AT 句を指定しない場合と同じ結果に
なります。
AT SOURCE
WITH TIME ZONE
(SOURCE はキーワードであり、列参
照ではありません)
変換元の timestamp_expression の時間部分(UTC)
と、timestamp_expression に関連付けられたタイム
ゾーン変位から結果が生成されます。
これは、AT 句を指定しない場合と同じ結果になりま
す。
AT SOURCE
without TIME ZONE
エラーが戻されます。
WITH TIME ZONE
変換元の timestamp_expression の時間部分(UTC)
と、timestamp_expression に関連付けられたタイム
ゾーン変位から結果が生成されます。
(SOURCE はキーワードであり、列参
照ではありません)
AT SOURCE TIME ZONE
これは、AT 句を指定しない場合と同じ結果になりま
す。
AT SOURCE TIME ZONE
without TIME ZONE
AT 式または
AT TIME ZONE expression
TIME ZONE の有無は 変換元の timestamp_expression の時間部分(UTC)
関係なし
と、expression で定義されるタイムゾーン変位から
結果が生成されます。
SQL 関数、演算子、式および述部
エラーが戻されます。
673
第 13 章 データ型の変換
TIMESTAMP から TIME への変換
指定内容
timestamp_expressio THEN...
n のデータ型
AT time_zone_string
または
AT TIME ZONE time_zone_string
TIME ZONE の有無は 結果は変換元 timestamp_expression (UTC)の時間部
関係なし
分と、time_zone_string に基づくタイムゾーン変位
から生成されます。タイムゾーン変位は、
time_zone_string と、UTC での
timestamp_expression の TIMESTAMP 値に基づい
て決定されます。
TIMESTAMP から TIME への暗黙的変換
Teradata Database は、場合によっては、TIMESTAMP から TIME データ型への暗黙
の変換を実行します。ただし、TIMESTAMP から TIME への暗黙的な変換は、比較で
はサポートされていません。「DateTime 型の暗黙的変換」を参照してください。
以下の変換をサポートします。
変換元タイプ
変換先タイプ
TIMESTAMP
TIME
TIME WITH TIME ZONE
TIMESTAMP WITH TIME ZONE
TIME
TIME WITH TIME ZONE
例
例
この例では、現在のセッションのタイムゾーン変位 INTERVAL '01:00' HOUR TO
MINUTE を使用して、TIMESTAMP 定数の UTC 値'2008-06-01 07:30:00'を決定して
います。
CAST の結果は、変換元の式値'2008-06-01 07:30:00' (UTC)の時間部分と、現在の
タイムゾーン変位 INTERVAL '01:00' HOUR TO MINUTE から生成された時間になり
ます。
UTC での CAST '07:30:00'の結果値がタイムゾーン変位 INTERVAL '01:00' HOUR TO
MINUTE に調整され、SELECT 文の結果は次のようになります。TIME
'08:30:00+01:00'
SELECT 文の結果は、UTC の値に基づいて値が比較されるため、TIME
'07:30:00+00:00'と等しくなります。
SET TIME ZONE INTERVAL '01:00' HOUR TO MINUTE;
SELECT CAST(TIMESTAMP '2008-06-01 08:30:00' AS TIME(0)
674
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIMESTAMP から TIME への変換
WITH TIME ZONE);
SELECT CAST(TIMESTAMP '2008-06-01 08:30:00' AS TIME(0)
WITH TIME ZONE AT LOCAL);
例
この例では、文字列定数 INTERVAL '04:00' HOUR TO MINUTE で指定されたタイム
ゾーン変位を使用して、TIMESTAMP 定数の UTC 値'2008-06-01 04:30:00'を決定
しています。
CAST の結果は、変換元の式値'2008-06-01 04:30:00' (UTC)の時間部分と、現在の
セッションのタイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE から生成さ
れます。
UTC での CAST '04:30:00'の結果値はそのタイムゾーン変位 INTERVAL -'08:00'
HOUR TO MINUTE に調整され、SELECT 文の結果は次のようになります。TIME
'20:30:00-08:00'
SELECT 文の結果は、TIME '04:30+00:00'と等しくなります。
SET TIME ZONE INTERVAL -'08:00' HOUR TO MINUTE;
SELECT CAST(TIMESTAMP '2008-06-01 08:30:00+04:00'
AS TIME(0) WITH TIME ZONE AT LOCAL);
例
次の SELECT 文は、変換元の式にタイムゾーン変位が存在しないために、エラーを
返します。
SELECT CAST(TIMESTAMP '2008-06-01 08:30:00'
AS TIME(0) WITH TIME ZONE AT SOURCE);
例
この例では、文字列定数 INTERVAL '04:00' HOUR TO MINUTE で指定されたタイム
ゾーン変位を使用して、TIMESTAMP 定数の UTC 値'2008-06-01 04:30:00'を決定
しています。
CAST の結果は、変換元の式値'2008-06-01 04:30:00' (UTC)の時間部分と、変換元
の式のタイムゾーン変位 INTERVAL '04:00' HOUR TO MINUTE から生成されます。
UTC での CAST '04:30:00'の結果値がタイムゾーン変位 INTERVAL '04:00:00' HOUR
TO MINUTE に調整され、SELECT 文の結果は次のようになります。TIME
'08:30:00+04:00'
SELECT 文の結果は、TIME '04:30:00+00:00'と等しくなります。現在のセッション
のタイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE は、影響しません。
SET TIME ZONE INTERVAL -'08:00' HOUR TO MINUTE;
SELECT CAST(TIMESTAMP '2008-06-01 08:30:00+04:00'
AS TIME(0) WITH TIME ZONE);
SQL 関数、演算子、式および述部
675
第 13 章 データ型の変換
TIMESTAMP から TIME への変換
SELECT CAST(TIMESTAMP '2008-06-01 08:30:00+04:00'
AS TIME(0) WITH TIME ZONE AT SOURCE TIME ZONE);
例
この例では、現行セッションのタイムゾーン変位 INTERVAL -'04:00' HOUR TO
MINUTE を使用して、TIMESTAMP 定数の UTC 値'2008-06-01 12:30:00'を決定して
います。
CAST の結果は、ソース式の値の時刻部分'2008-06-01 12:30:00'(UTC)と、指定した
タイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE から生成された時間です。
UTC での CAST '12:30:00'の結果値はそのタイムゾーン変位 INTERVAL -'08:00' HOUR
TO MINUTE に調整され、SELECT 文の結果は次のようになります。TIME
'04:30:00-08:00'
SELECT 文の結果は、TIME '12:30:00+00:00'と等しくなります。
SET TIME ZONE INTERVAL -'04:00' HOUR TO MINUTE;
SELECT CAST(TIMESTAMP '2008-06-01 08:30:00'
AS TIME(0) WITH TIME ZONE AT -8);
例
この例では、文字列定数 INTERVAL '04:00' HOUR TO MINUTE で指定されたタイム
ゾーン変位を使用して、TIMESTAMP 定数の UTC 値'2008-06-01 04:30:00'を決定し
ています。
CAST の結果は、ソース式の値の時刻部分'2008-06-01 04:30:00'(UTC)と、指定した
タイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE から生成された時間です。
UTC での CAST '04:30:00'の結果値はそのタイムゾーン変位 INTERVAL -'08:00' HOUR
TO MINUTE に調整され、SELECT 文の結果は次のようになります。TIME
'20:30:00-08:00'
SELECT 文の結果は、TIME '04:30:00+00:00'と等しくなります。現在のセッション
のタイムゾーン変位 INTERVAL '08:00' HOUR TO MINUTE は、影響しません。
SET TIME ZONE INTERVAL '08:00' HOUR TO MINUTE;
SELECT CAST(TIMESTAMP '2008-06-01 08:30:00+04:00'
AS TIME(0) WITH TIME ZONE AT -8);
例
この例では、現在のタイムスタンプは次のとおりです。
Current TimeStamp(6)
-------------------------------2010-03-09 19:23:27.620000+00:00
676
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIMESTAMP から TIMESTAMP への変換
次の文は、TIMESTAMP 値'2010-03-09 08:30:00'を、TIMESTAMP WITH TIME
ZONE 値に変換します。ここでのタイムゾーン変位は、タイムゾーン文字列'America
Pacific'に基づきます。
SELECT CAST(TIMESTAMP '2010-03-09 08:30:00' AS TIME(0) WITH TIME ZONE
AT 'America Pacific');
問合わせの結果は、次のとおりです。
2010-03-09 08:30:00
------------------00:30:00-08:00
関連トピック
データ型およびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
TIMESTAMP から TIMESTAMP への変換
目的
TIMESTAMP データを、精度情報が異なる、または WITH TIME ZONE 定義の
TIMESTAMP 値に変換します。
CAST 構文
CAST
A
(
timestamp_expression
A
AS
B
TIMESTAMP
(fractional_seconds_precision)
WITH TIME ZONE
B
)
AT
LOCAL
data_attribute
SOURCE
TIME ZONE
expression
TIME ZONE
time_zone_string
構文要素
timestamp_expression
変換する TIMESTAMP 式。
SQL 関数、演算子、式および述部
677
第 13 章 データ型の変換
TIMESTAMP から TIMESTAMP への変換
fractional_seconds_precision
SECOND フィールドの小数部の有効桁数を表わす 1 桁の数字。有効な範囲は、0 か
ら 6 です。デフォルトは 6 です。
AT LOCAL
現在のセッションのタイムゾーンに基づくタイムゾーン変位を使用します。
AT SOURCE [TIME ZONE]
次の場合に、timestamp_expression に付随するタイムゾーンを使用します。
• AT SOURCE TIME ZONE が指定される。
• AT SOURCE が without TIME ZONE で指定され、範囲に source という列がない。
その他の場合、AT SOURCE が without TIME ZONE で指定され、source という列が
存在する場合、SOURCE はこの列を参照し、列の値は CAST のタイムゾーン変位と
して使用されます。必要な場合、列値が型 INTERVAL HOUR(2) TO MINUTE に暗黙
的に変換されます。
AT [TIME ZONE] expression
式で定義されたタイムゾーンの変位を使用します。
expression のデータ タイプは INTERVAL HOUR(2) TO MINUTE か、暗黙的に
INTERVAL HOUR(2) TO MINUTE に変換できるデータ タイプでなければなりません。
AT [TIME ZONE] time_zone_string
time_zone_string は、タイムゾーン変位を決定します。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI の拡張として、CAST では、日時および間隔データの文字表現の代替出力の書
式化を可能にするために、FORMAT 句を使用することができます。
AT 句は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、CAST を使用した TIMESTAMP から TIMESTAMP への変換
に、AT 句がサポートされるようになりました。また、INTERVAL 式の他にも追加の
式を使用して、タイムゾーン変位を指定することができます。
注: TIMESTAMP (without time zone)は、ANSI SQL:2011 互換ではありません。
Teradata Database は、現行セッションのタイムゾーン、または指定されたタイム
ゾーンに基づいて、TIMESTAMP 値を内部的に UTC に変換します。
678
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIMESTAMP から TIMESTAMP への変換
Teradata 変換構文
timestamp_expression
(
A
TIMESTAMP
(fractional_seconds_precision)
data_attribute ,
B
A
, WITH TIME ZONE
AT
LOCAL
SOURCE
TIME ZONE
expression
TIME ZONE
B
time_zone_string
)
, data_attribute
構文要素
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
timestamp_expression
変換する TIMESTAMP 式。
fractional_seconds_precision
SECOND フィールドの小数部の有効桁数を表わす 1 桁の数字。有効な範囲は、0 か
ら 6 です。デフォルトは 6 です。
AT LOCAL
現在のセッションのタイムゾーンに基づくタイムゾーン変位を使用します。
AT SOURCE [TIME ZONE]
次の場合に、timestamp_expression に付随するタイムゾーンを使用します。
• AT SOURCE TIME ZONE が指定される。
• AT SOURCE が without TIME ZONE で指定され、範囲に source という列がない。
その他の場合、AT SOURCE が without TIME ZONE で指定され、source という列が
存在する場合、SOURCE はこの列を参照し、列の値は CAST のタイムゾーン変位と
して使用されます。必要な場合、列値が型 INTERVAL HOUR(2) TO MINUTE に暗黙
的に変換されます。
AT [TIME ZONE] expression
式で定義されたタイムゾーンの変位を使用します。
SQL 関数、演算子、式および述部
679
第 13 章 データ型の変換
TIMESTAMP から TIMESTAMP への変換
expression のデータ タイプは INTERVAL HOUR(2) TO MINUTE か、暗黙的に
INTERVAL HOUR(2) TO MINUTE に変換できるデータ タイプでなければなりません。
AT [TIME ZONE] time_zone_string
time_zone_string は、タイムゾーン変位を決定します。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
AT 句は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、Teradata 変換構文を使用した TIMESTAMP から
TIMESTAMP への変換に、AT 句がサポートされるようになりました。また、
INTERVAL 式の他にも追加の式を使用して、タイムゾーン変位を指定することがで
きます。
注: TIMESTAMP (without time zone)は、ANSI SQL:2011 互換ではありません。
Teradata Database は、現行セッションのタイムゾーン、または指定されたタイム
ゾーンに基づいて、TIMESTAMP 値を内部的に UTC に変換します。
使用上の注意
変換先のデータ タイプにタイムゾーンがない TIMESTAMP[(n)]の AT 句を指定する
と、エラーが返されます。
変換先データ タイプが TIMESTAMP[(n)] WITH TIME ZONE の AT 句を指定したとき
の、CAST 関数、または各種の指定オプションに基づいた Teradata 変換の結果を以
下の表に示します。変換先の精度が変換元の精度より高い場合、精度を調整するた
めに結果の末尾にゼロが追加されます。変換先の精度が変換元の精度より低い場合、
エラーが返されます。
指定内容
timestamp_expressio THEN...
n のデータ型
AT LOCAL
TIME ZONE の有無は 変換元の timestamp_expression のタイムスタンプ部
関係なし
分(UTC)と、現在のセッションのタイムゾーンに基
づいた結果のタイムゾーン変位から結果が生成され
ます。
変換元のデータ タイプにタイムゾーンがないときに
は、AT 句を指定していない場合と同じになります。
AT SOURCE
(SOURCE はキーワードであり、列参
照ではありません)
WITH TIME ZONE
変換元の timestamp_expression のタイムスタンプ部
分(UTC)と、timestamp_expression に関連付けられ
たタイムゾーン変位から結果が生成されます。
これは、AT 句を指定しない場合と同じ結果になりま
す。
680
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIMESTAMP から TIMESTAMP への変換
指定内容
timestamp_expressio THEN...
n のデータ型
AT SOURCE
without TIME ZONE
エラーが戻されます。
WITH TIME ZONE
変換元の timestamp_expression のタイムスタンプ部
分(UTC)と、timestamp_expression に関連付けられ
たタイムゾーン変位から結果が生成されます。
(SOURCE はキーワードであり、列参
照ではありません)
AT SOURCE TIME ZONE
これは、AT 句を指定しない場合と同じ結果になりま
す。
AT SOURCE TIME ZONE
without TIME ZONE
エラーが戻されます。
AT 式または
AT TIME ZONE expression
TIME ZONE の有無は 変換元の timestamp_expression のタイムスタンプ部
関係なし
分(UTC)と、expression で定義されるタイムゾーン
変位から結果が生成されます。
AT time_zone_string
または
AT TIME ZONE time_zone_string
TIME ZONE の有無は 結果は変換元 timestamp_expression (UTC)のタイム
関係なし
スタンプ部分と、 time_zone_string. に基づくタイム
ゾーン変位から生成されます。タイムゾーン変位は、
time_zone_string と、UTC での
timestamp_expression の TIMESTAMP 値に基づい
て決定されます。
例
例
次の SELECT 文は、エラーを返します。これは、変換先のデータ タイプに
TIMESTAMP WITH TIME ZONE データ タイプが存在しないためです。
SELECT CAST(TIMESTAMP '2008-06-01
AT LOCAL);
SELECT CAST(TIMESTAMP '2008-06-01
AT LOCAL);
SELECT CAST(TIMESTAMP '2008-06-01
AT SOURCE TIME ZONE);
SELECT CAST(TIMESTAMP '2008-06-01
AT SOURCE);
SELECT CAST(TIMESTAMP '2008-06-01
SELECT CAST(TIMESTAMP '2008-06-01
AT -6);
SQL 関数、演算子、式および述部
08:30:00' AS TIMESTAMP(0)
08:30:00+01:00' AS TIMESTAMP(0)
08:30:00' AS TIMESTAMP(0)
08:30:00+01:00' AS TIMESTAMP(0)
08:30:00' AS TIMESTAMP(0) AT +3);
08:30:00+01:00' AS TIMESTAMP(0)
681
第 13 章 データ型の変換
TIMESTAMP から TIMESTAMP への変換
例
この例では、文字列定数 INTERVAL '04:00' HOUR TO MINUTE で指定されたタイム
ゾーン変位を使用して、UTC 値'2008-06-01 04:30:00'と、文字列定数のタイムゾー
ン変位 INTERVAL '04:00' HOUR TO MINUTE を決定しています。
CAST の結果は、変換元の値式'2008-06-01 04:30:00'(UTC)と、現在のセッションの
タイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE を併せたものになります。
UTC での CAST の結果値はタイムゾーン変位 INTERVAL '09:00' HOUR TO MINUTE
に調整され、SELECT 文の結果は次のようになります。TIMESTAMP '01.06.08
13:30:00+09:00'
SET TIME ZONE INTERVAL '09:00' HOUR TO MINUTE;
SELECT CAST(TIMESTAMP '2008-06-01 08:30:00+04:00'
AS TIMESTAMP(0) WITH TIME ZONE AT LOCAL);
例
次の SELECT 文は、変換元の式にタイムゾーン変位が存在しないために、エラーを
返します。
SELECT CAST(TIMESTAMP '2008-06-01
AS TIMESTAMP(0) WITH TIME ZONE
SELECT CAST(TIMESTAMP '2008-06-01
AS TIMESTAMP(0) WITH TIME ZONE
08:30:00'
AT SOURCE TIME ZONE);
08:30:00'
AT SOURCE);
例
この例では、文字列定数 INTERVAL '04:00' HOUR TO MINUTE で指定されたタイム
ゾーン変位を使用して、UTC 値'2008-06-01 04:30:00'と、文字列定数のタイムゾー
ン変位 INTERVAL '04:00' HOUR TO MINUTE を決定しています。
CAST の結果は、変換元の値式'2008-06-01 04:30:00'(UTC)と、それのタイムゾーン
変位 INTERVAL '04:00' HOUR TO MINUTE を併せたものになります。
UTC での CAST の結果値はタイムゾーン変位 INTERVAL '04:00' HOUR TO MINUTE
に調整され、SELECT の結果は次のようになります。TIMESTAMP '01.06.08
08:30:00+04:00'現在のセッションのタイムゾーンは影響しません。
SET TIME ZONE INTERVAL '09:00' HOUR TO MINUTE;
SELECT CAST(TIMESTAMP '2008-06-01 08:30:00+04:00'
AS TIMESTAMP(0) WITH TIME ZONE);
SELECT CAST(TIMESTAMP '2008-06-01 08:30:00+04:00'
AS TIMESTAMP(0) WITH TIME ZONE AT SOURCE TIME ZONE);
例
この例では、現在のセッションのタイムゾーン変位 INTERVAL '09:00' HOUR TO
MINUTE を使用して、文字列定数の UTC 値'2008-05-31 23:30:00'を決定しています。
682
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIMESTAMP から TIMESTAMP への変換
CAST の結果は、変換元の値式 UTC で'2008-05-31 23:30:00'と、変換先のタイム
ゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE を併せたものになります。
UTC での CAST の結果値はタイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE
に調整され、SELECT 文の結果は次のようになります。TIMESTAMP '2008-05-31
15:30:00-08:00'
SET TIME ZONE INTERVAL '09:00' HOUR TO MINUTE;
SELECT CAST(TIMESTAMP '2008-06-01 08:30:00' AS TIMESTAMP(0)
WITH TIME ZONE AT -8);
例
この例では、文字列定数 INTERVAL '04:00' HOUR TO MINUTE で指定されたタイム
ゾーン変位を使用して、UTC 値'2008-06-01 04:30:00'と、文字列定数のタイムゾー
ン変位 INTERVAL '04:00' HOUR TO MINUTE を決定しています。
CAST の結果は、変換元の値式 UTC で'2008-06-01 04:30:00'と、変換先のタイム
ゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE を併せたものになります。
UTC での CAST の結果値はタイムゾーン変位 INTERVAL -'08:00' HOUR TO MINUTE
に調整され、SELECT 文の結果は次のようになります。TIMESTAMP '2008-05-31
20:30:00-08:00' 現在のセッションのタイムゾーンは影響しません。
SET TIME ZONE INTERVAL '09:00' HOUR TO MINUTE;
SELECT CAST(TIMESTAMP '2008-06-01 08:30:00+04:00'
AS TIMESTAMP(0) WITH TIME ZONE AT -8);
例
この例では、現在のタイムスタンプは次のとおりです。
Current TimeStamp(6)
-------------------------------2010-03-09 19:23:27.620000+00:00
次の文は、TIMESTAMP 値'2010-03-09 08:30:00'を、TIMESTAMP WITH TIME
ZONE 値に変換します。ここでのタイムゾーン変位は、タイムゾーン文字列'America
Pacific'に基づきます。
SELECT CAST(TIMESTAMP '2010-03-09 08:30:00' AS TIMESTAMP(0)
WITH TIME ZONE AT 'America Pacific');
問合わせの結果は、次のとおりです。
2010-03-09 08:30:00
------------------------2010-03-09 00:30:00-08:00
SQL 関数、演算子、式および述部
683
第 13 章 データ型の変換
TIMESTAMP から TIMESTAMP への変換
例
この例では、table1 の tswz 列に、次のタイムスタンプ データが格納されています。
SELECT * FROM table1;
問合わせの結果は、次のとおりです。
tswz
----------------------------------2011-11-04 13:14:00.860000-07:00
SELECT 問合わせでタイムゾーン文字列を指定した AT 句を使用して、異なるタイム
ゾーン内の同じ時間を取得できます。たとえば、
SELECT CAST(tswz AS TIMESTAMP WITH TIME ZONE AT 'gmt')
FROM table1;
問合わせの結果は、次のとおりです。
tswz
----------------------------------2011-11-04 20:14:00.860000+00:00
同様に、タイムゾーン変位を指定した AT 句を使用して、同じ結果を得ることができ
ます。
SELECT CAST(tswz AS TIMESTAMP WITH TIME ZONE AT TIME ZONE '00:00')
FROM table1;
問合わせの結果は、次のとおりです。
tswz
----------------------------------2011-11-04 20:14:00.860000+00:00
次の問合わせは、明示的な CAST なしで同じ結果を生成します。
SELECT tswz AT 'gmt' FROM table1;
問合わせの結果は、次のとおりです。
tswz AT TIME ZONE 'gmt'
----------------------------------2011-11-04 20:14:00.860000+00:00
関連トピック
データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
684
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
TIMESTAMP から UDT への変換
詳細については、AT LOCAL および AT TIME ZONE タイムゾーン指定子を参照して
ください。
TIMESTAMP から UDT への変換
目的
TIMESTAMP データを UDT データに変換します。
CAST 構文
CAST
( timestamp_expression
AS
UDT_data_type (
構文要素
timestamp_expression
変換する TIMESTAMP 式。
UDT_data_definition
式が変換される UDT の型(FORMAT、NAMED、または TITLE データ属性句が続く)。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、FORMAT などのデータ属性句を CAST で使用できます。
使用上の注意
Teradata 変換構文を使った TIMESTAMP から UDT への明示的な変換はサポートさ
れていません。
UDT の関与するデータ型の変換には、その UDT に適した CAST 定義が必要です。
UDT の CAST を定義するには、CREATE CAST 文を使用します。
TIMESTAMP から UDT への暗黙的変換
Teradata Database は、以下の操作に対して TIMESTAMP から UDT への暗黙的変換
を実行します。
• UPDATE
• INSERT
• ストアド プロシージャ、外部ストアド プロシージャ、UDF、および UDM への
引数の引渡し。
SQL 関数、演算子、式および述部
685
第 13 章 データ型の変換
TRYCAST
• このマニュアル中の他の箇所に明記されている特定のシステム演算子と関数 (DBS
制御レコードの DisableUDTImplCastForSysFuncOp フィールドが TRUE に設定さ
れていない場合に限る)。
暗黙のデータ型変換を実行するには、AS ASSIGNMENT 句を指定する適切な CAST 定
義(「使用上の注意」を参照)が存在する必要があります。
TIMESTAMP から UDT への暗黙的なキャスト定義が存在しない場合、Teradata
Database は代用できる CHAR から UDT への、または VARCHAR から UDT への暗黙
的なキャスト定義を検索します。Teradata Database は TIMESTAMP 型を文字データ
型に暗黙的にキャストしてから、暗黙的なキャスト定義を使用して、文字データ型
から UDT へのキャストを行なえるため、代用は有効です。文字から UDT への暗黙
の CAST 定義が複数存在する場合、Teradata Database は SQL エラーを戻します。
関連トピック
データ型およびデータ属性について、詳細は< SQL データ型とリテラル、B035-1143>
を参照してください。
CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>を
参照してください。
TRYCAST
目的
TRYCAST は文字列を受け取り、 AS キーワードの後に指定されたデータ型にキャス
トしようとします(CAST と似ています)。変換が失敗した場合、TRYCAST はエラーで
はなく NULL を返します。
構文
構文要素
instring
LATIN または UNICODE 文字セット内の CHAR または VARCHAR 式。
data_type
以下のサポート対象データ型のいずれか 1 つ。
•
•
•
•
686
BYTEINT
SMALLINT
INT
BIGINT
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
UDT からバイトへの変換
•
•
•
•
•
•
•
•
•
FLOAT
DECIMAL
NUMBER
CHAR(LATIN または UNICODE)
VARCHAR(LATIN または UNICODE)
DATE
TIME(ゾーン付き)
TIMESTAMP(ゾーン付き)
すべての INTERVAL 型
出力
エラーがなければ、変換の結果が返されます。エラーがある場合は、NULL が返さ
れます。結果のデータ型は、data_type 入力によって指定されたデータ型になります。
例
例
SELECT TRYCAST('-2.5' AS DECIMAL(5,2));
*** Query completed. One row found. One column returned.
*** Total elapsed time was 1 second.
TRYCAST('-2.5')
---------------2.50
例: TRYCAST 変換の失敗
TRYCAST 変換の失敗例:
SELECT TRYCAST('abc' AS DECIMAL(5,2));
*** Query completed. One row found. One column returned.
*** Total elapsed time was 1 second.
TRYCAST('abc')
--------------?
UDT からバイトへの変換
目的
UDT 式をバイト データ タイプに変換します。
SQL 関数、演算子、式および述部
687
第 13 章 データ型の変換
UDT からバイトへの変換
CAST 構文
CAST
( UDT_expression
AS
byte_data_type )
構文要素
UDT_expression
UDT データ型となる式。
byte_data_definition
UDT_expression の変換先の BLOB、BYTE または VARBYTE バイト型(任意選択の
FORMAT、NAMED または TITLE 属性句が続く)。
ANSI への準拠
これは、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、FORMAT などのデータ属性句を CAST で使用できます。
Teradata 変換構文
UDT_expression
(
byte_data_type
data_attribute ,
)
, data_attribute
構文要素
UDT_expression
UDT データ型となる式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
byte_data_type
UDT_expression の変換先の BLOB、BYTE または VARBYTE バイト タイプ。
ANSI への準拠
これは、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
688
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
UDT からバイトへの変換
使用上の注意
UDT の関与するデータ型の変換には、その UDT に適した CAST 定義が必要です。
UDT の CAST を定義するには、CREATE CAST 文を使用します。
暗黙タイプ変換
Teradata Database は、以下の操作に対して UDT からバイトへの暗黙的変換を実行
します。
• UPDATE
• INSERT
• ストアド プロシージャ、外部ストアド プロシージャ、UDF、および UDM への
引数の引渡し。
• このマニュアル中の他の箇所に明記されている特定のシステム演算子と関数 (DBS
制御レコードの DisableUDTImplCastForSysFuncOp フィールドが TRUE に設定さ
れていない場合に限る)。
UDT からバイトへの暗黙のデータ型変換を実行するには、以下を指定する CAST 定
義(「使用上の注意」を参照)が必要です。
• AS ASSIGNMENT 句
• BYTE、VARBYTE、または BLOB ターゲット データ タイプ
CAST 定義の変換先のデータ タイプは、暗黙タイプ変換の変換先と正確に一致し
ている必要はありません。
UDT から別々のバイト タイプへの変換の場合に複数の暗黙 CAST 定義が存在する場
合、Teradata Database は優先順位の最も高いバイト タイプの暗黙 CAST 定義を使
用します。以下のリストでは、バイト タイプの優先順位が最低から最高の順に並べ
られています。
• BYTE
• VARBYTE
• BLOB
例
image が UDT である次のようなテーブルの定義を考えます。
CREATE TABLE history
(id INTEGER
,information image );
image UDT に適した CAST 定義が存在するという想定で、以下の文は、information
列の値を BYTE に変換します。
SQL 関数、演算子、式および述部
689
第 13 章 データ型の変換
UDT から文字への変換
SELECT CAST (information AS BYTE(20))
FROM history
WHERE id = 100121;
関連トピック
詳細は、以下を参照してください。
• データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
• 結果が UDT データ タイプとなる式については、SQL UDF を参照してください。
• CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>
を参照してください。
UDT から文字への変換
目的
UDT 式を文字データ タイプに変換します。
CAST 構文
CAST
( UDT_expression
AS
character_data_type )
構文要素
UDT_expression
UDT データ型となる式。
character_data_definition
式が変換されるデータ型(FORMAT、NAMED、または TITLE 属性句が続く)。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、FORMAT などのデータ属性句を CAST で使用できます。
Teradata 変換構文
UDT_expression
(
character_data_type
data_attribute ,
690
)
, data_attribute
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
UDT から文字への変換
構文要素
UDT_expression
UDT データ型となる式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
character_data_type
式が変換される CHAR や VARCHAR などのデータ型。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
UDT の関与するデータ型の変換には、その UDT に適した CAST 定義が必要です。
UDT の CAST を定義するには、CREATE CAST 文を使用します。
暗黙タイプ変換
Teradata Database は、以下の操作に対して UDT から文字への暗黙的変換を実行し
ます。
• UPDATE
• INSERT
• ストアド プロシージャ、外部ストアド プロシージャ、UDF、および UDM への
引数の引渡し。
• このマニュアル中の他の箇所に明記されている特定のシステム演算子と関数 (DBS
制御レコードの DisableUDTImplCastForSysFuncOp フィールドが TRUE に設定さ
れていない場合に限る)。
暗黙のデータ型変換を実行するには、AS ASSIGNMENT 句を指定する適切な CAST
定義(「使用上の注意」を参照)が存在する必要があります。
キャスト定義のターゲット文字型は、暗黙の変換のターゲット文字型と正確に一致
している必要はありません。Teradata Database では、CHAR、VARCHAR、または
CLOB ターゲット型を指定する暗黙的なキャスト定義を使用することができます。
UDT から別々の文字型への変換の場合に複数の暗黙的なキャスト定義が存在する場
合、Teradata Database は優先順位の最も高い文字型の暗黙的なキャスト定義を使用
SQL 関数、演算子、式および述部
691
第 13 章 データ型の変換
UDT から文字への変換
します。以下のリストでは、文字型の優先順位が最低から最高の順に並べられてい
ます。
• CHAR
• VARCHAR
• CLOB
UDT から文字への暗黙的なキャスト定義が存在しない場合、Teradata Database は
UDT から文字への暗黙的なキャスト定義に代用できるその他のキャスト定義を検索
します。
存在する暗黙 CAST 定義の組み合わせ
Teradata Database の動作
UDT-to- UDT-to- UDT-to- UDT-tonumeric DATE
TIME
TIMESTAM
P
X
UDT から数値への暗黙 CAST 定義を使用する。
UDT から数値への暗黙の CAST 定義が複数存在
する場合、Teradata Database は SQL エラーを
戻します。
X
UDT から DATE への暗黙 CAST 定義を使用する。
X
UDT から TIME への暗黙 CAST 定義を使用する。
X
X
X
X
エラーを報告する。
X
X
X
X
X
X
X
X
X
X
X
X
X
X
UDT から TIMESTAMP への暗黙 CAST 定義を使
用する。
X
X
X
X
X
X
X
X
X
X
X
Teradata Database は暗黙的なキャスト定義を使用して UDT を代用データ型にキャ
ストしてから、その代用データ型を文字型に暗黙的にキャストできるため、代用は
有効です。
692
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
UDT から DATE への変換
例
euro が UDT である次のようなテーブルの定義を考えます。
CREATE TABLE euro_sales_table
(quarter INTEGER
,region VARCHAR(20)
,sales euro );
euro UDT に適した CAST 定義が存在するという想定で、以下の文は、sales 列の値
を CHAR(10)に変換します。
SELECT region, CAST (sales AS CHAR(10))
FROM euro_sales_table
WHERE quarter = 1;
関連トピック
詳細は、以下を参照してください。
• データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
• CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>
を参照してください。
UDT から DATE への変換
目的
UDT 式を DATE データ タイプに変換します。
CAST 構文
CAST
( UDT_expression
AS
DATE
)
data_attribute
構文要素
UDT_expression
UDT データ型となる式。
date_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
SQL 関数、演算子、式および述部
693
第 13 章 データ型の変換
UDT から DATE への変換
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、FORMAT などのデータ属性句を CAST で使用できます。
Teradata 変換構文
UDT_expression
(
DATE
data_attribute ,
)
, data_attribute
構文要素
UDT_expression
UDT データ型となる式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
UDT の関与するデータ型の変換には、その UDT に適した CAST 定義が必要です。
UDT の CAST を定義するには、CREATE CAST 文を使用します。
暗黙タイプ変換
暗黙のデータ型変換を実行するには、AS ASSIGNMENT 句を指定する適切な CAST 定
義(「使用上の注意」を参照)が存在する必要があります。
Teradata Database は、以下の操作に対して UDT から DATE への暗黙的変換を実行
します。
• UPDATE
• INSERT
694
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
UDT から DATE への変換
• ストアド プロシージャ、外部ストアド プロシージャ、UDF、および UDM への
引数の引渡し。
• このマニュアル中の他の箇所に明記されている特定のシステム演算子と関数 (DBS
制御レコードの DisableUDTImplCastForSysFuncOp フィールドが TRUE に設定さ
れていない場合に限る)。
UDT から DATE への暗黙的なキャスト定義が存在しない場合、Teradata Database
は UDT から DATE への暗黙的なキャスト定義に代用できるその他のキャスト定義を
検索します。
存在する暗黙 CAST 定義の組み合
わせ
Teradata Database の動作
UDT-to-Numeric UDT-to-Character
(non-CLOB)
X
UDT から数値への暗黙 CAST 定義を使用する。
UDT から数値への暗黙の CAST 定義が複数存在する場
合、Teradata Database は SQL エラーを戻します。
X
UDT から文字への暗黙 CAST 定義を使用する。
UDT から文字への暗黙の CAST 定義が複数存在する場
合、Teradata Database は SQL エラーを返します。
X
X
エラーを報告する。
Teradata Database は暗黙的なキャスト定義を使用して UDT を代用データ型にキャ
ストしてから、その代用データ型を DATE 型に暗黙的にキャストできるため、代用
は有効です。
例
datetime_record が UDT である次のようなテーブルの定義を考えます。
CREATE TABLE support
(id INTEGER
,information datetime_record );
datetime_record UDT に適した CAST 定義が存在するという想定で、以下の文は、
information 列の値を DATE に変換します。
SELECT id, CAST (information AS DATE) FROM support;
関連トピック
詳細は、以下を参照してください。
• データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
SQL 関数、演算子、式および述部
695
第 13 章 データ型の変換
UDT から INTERVAL への変換
• CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>
を参照してください。
UDT から INTERVAL への変換
目的
UDT 式を INTERVAL データ タイプに変換します。
CAST 構文
CAST
( UDT_expression
AS
interval_data_type )
構文要素
UDT_expression
UDT データ型となる式。
interval_data_definition
変換先の事前定義の間隔型(任意選択の NAMED または TITLE 属性句が続く)。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、FORMAT などのデータ属性句を CAST で使用できます。
Teradata 変換構文
UDT_expression
(
interval_data_type
data_attribute ,
)
, data_attribute
構文要素
UDT_expression
UDT データ型となる式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• NAMED
• TITLE
696
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
UDT から INTERVAL への変換
interval_data_type
UDT_expression の変換先である事前定義された INTERVAL 型。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
UDT の関与するデータ型の変換には、その UDT に適した CAST 定義が必要です。
UDT の CAST を定義するには、CREATE CAST 文を使用します。
暗黙タイプ変換
暗黙のデータ型変換を実行するには、以下を指定する CAST 定義(「使用上の注意」
を参照)が必要です。
• AS ASSIGNMENT 句
• 暗黙 CAST の変換先と同じ INTERVAL ファミリー内にある次のようなターゲッ
ト データ タイプ。
INTERVAL データ タイプ
属している INTERVAL ファミリー
• INTERVAL YEAR
Year-Month
• INTERVAL YEAR TO MONTH
• INTERVAL MONTH
• INTERVAL DAY
Day-Time
• INTERVAL DAY TO HOUR
• INTERVAL DAY TO MINUTE
• INTERVAL DAY TO SECOND
• INTERVAL HOUR
• INTERVAL HOUR TO MINUTE
• INTERVAL HOUR TO SECOND
• INTERVAL MINUTE
• INTERVAL MINUTE TO SECOND
• INTERVAL SECOND
CAST 定義の変換先のデータ タイプは、暗黙タイプ変換の変換先と正確に一致して
いる必要はありません。
Teradata Database は、以下の操作に対して UDT から INTERVAL への暗黙的変換を
実行します。
• UPDATE
SQL 関数、演算子、式および述部
697
第 13 章 データ型の変換
UDT から数値への変換
• INSERT
• ストアド プロシージャ、外部ストアド プロシージャ、UDF、および UDM への引
数の引渡し。
• このマニュアル中の他の箇所に明記されている特定のシステム演算子と関数 (DBS
制御レコードの DisableUDTImplCastForSysFuncOp フィールドが TRUE に設定さ
れていない場合に限る)。
例
datetime_record が UDT である次のようなテーブルの定義を考えます。
CREATE TABLE support
(id INTEGER
,information datetime_record );
datetime_record UDT に適した CAST 定義が存在するという想定で、以下の文は、
information 列の値を INTERVAL MONTH に変換します。
SELECT id, CAST (information AS INTERVAL MONTH) FROM support;
関連トピック
詳細は、以下を参照してください。
• データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
• CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>
を参照してください。
UDT から数値への変換
目的
UDT 式を数値データ タイプに変換します。
CAST 構文
CAST
( UDT_expression
AS
numeric_data_type )
構文要素
UDT_expression
UDT データ型となる式。
698
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
UDT から数値への変換
numeric_data_definition
変換先の事前定義の数値型(任意選択の FORMAT、NAMED または TITLE 属性句が続
く)。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、FORMAT などのデータ属性句を CAST で使用できます。
Teradata 変換構文
UDT_expression
(
numeric_data_type
data_attribute ,
)
, data_attribute
構文要素
UDT_expression
UDT データ型となる式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
numeric_data_type
UDT_expression の変換先の事前定義の数値型。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
UDT の関与するデータ型の変換には、その UDT に適した CAST 定義が必要です。
UDT の CAST を定義するには、CREATE CAST 文を使用します。
暗黙タイプ変換
Teradata Database は、以下の操作に対して UDT から数値への暗黙的変換を実行し
ます。
SQL 関数、演算子、式および述部
699
第 13 章 データ型の変換
UDT から数値への変換
• UPDATE
• INSERT
• ストアド プロシージャ、外部ストアド プロシージャ、UDF、および UDM への引
数の引渡し。
• このマニュアル中の他の箇所に明記されている特定のシステム演算子と関数 (DBS
制御レコードの DisableUDTImplCastForSysFuncOp フィールドが TRUE に設定さ
れていない場合に限る)。
暗黙のデータ型変換を実行するには、AS ASSIGNMENT 句を指定する適切な CAST 定
義(「使用上の注意」を参照)が存在する必要があります。
キャスト定義のターゲット数値型は、暗黙の変換のターゲット数値型と正確に一致
している必要はありません。Teradata Database は、BYTEINT、SMALLINT、
INTEGER、BIGINT、DECIMAL/NUMERIC、NUMBER、または REAL/FLOAT/
DOUBLE ターゲット型を指定する暗黙的なキャスト定義を使用することができます。
UDT から別々の数値型への変換の場合に複数の暗黙的なキャスト定義が存在する場
合、Teradata Database は優先順位の最も高い数値型の暗黙的なキャスト定義を使用
します。以下のリストでは、数値型の優先順位が最低から最高の順に並べられてい
ます。
•
•
•
•
•
•
•
BYTEINT
SMALLINT
INTEGER
BIGINT
DECIMAL/NUMERIC
NUMBER
REAL/FLOAT/DOUBLE
UDT から数値への暗黙的なキャスト定義が存在しない場合、Teradata Database は
UDT から数値への暗黙的なキャスト定義に代用できるその他のキャスト定義を検索
します。
存在する暗黙 CAST 定義の組 Teradata Database の動作
み合わせ
UDT-toDATE
UDT-toCharacter
X
UDT から DATE への暗黙 CAST 定義を使用する。
X
UDT から文字への暗黙 CAST 定義を使用する。
CLOB は文字タイプにはなりません。
UDT から文字への暗黙の CAST 定義が複数存在する場合、
Teradata Database は SQL エラーを返します。
X
700
X
エラーを報告する。
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
UDT から TIME への変換
Teradata Database は暗黙的なキャスト定義を使用して UDT を代用データ型にキャ
ストしてから、その代用データ型を数値型に暗黙的にキャストできるため、代用は
有効です。
例
euro が UDT である次のようなテーブルの定義を考えます。
CREATE TABLE euro_sales_table
(quarter INTEGER
,region VARCHAR(20)
,sales euro );
euro UDT に適した CAST 定義が存在するという想定で、以下の文は、sales 列の値
を DECIMAL(10,2)に変換します。
SELECT SUM (CAST (sales AS DECIMAL(10,2))) FROM euro_sales_table;
関連トピック
詳細は、以下を参照してください。
• データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
• CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>
を参照してください。
UDT から TIME への変換
目的
UDT 式を TIME データ タイプに変換します。
CAST 構文
CAST
( UDT_expression
AS
A
TIME
(fractional_seconds_precision)
)
A
WITH TIME ZONE
SQL 関数、演算子、式および述部
data_attribute
701
第 13 章 データ型の変換
UDT から TIME への変換
構文要素
UDT_expression
UDT データ型となる式。
fractional_seconds_precision
SECOND フィールドの小数部の有効桁数を表わす 1 桁の数字。有効な範囲は、0 か
ら 6 です。デフォルトは 6 です。
time_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、FORMAT などのデータ属性句を CAST で使用できます。
Teradata 変換構文
UDT_expression
(
A
TIME
data_attribute ,
A
)
(fractional_seconds_precision)
,
data_attribute
WITH TIME ZONE
構文要素
UDT_expression
UDT データ型となる式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
fractional_seconds_precision
SECOND フィールドの小数部の有効桁数を表わす 1 桁の数字。有効な範囲は、0 か
ら 6 です。デフォルトは 6 です。
702
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
UDT から TIME への変換
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
UDT の関与するデータ型の変換には、その UDT に適した CAST 定義が必要です。
UDT の CAST を定義するには、CREATE CAST 文を使用します。
暗黙タイプ変換
Teradata Database は、以下の操作に対して UDT から TIME への暗黙的変換を実行
します。
• UPDATE
• INSERT
• ストアド プロシージャ、外部ストアド プロシージャ、UDF、および UDM への
引数の引渡し。
• このマニュアル中の他の箇所に明記されている特定のシステム演算子と関数 (DBS
制御レコードの DisableUDTImplCastForSysFuncOp フィールドが TRUE に設定さ
れていない場合に限る)。
暗黙のデータ型変換を実行するには、AS ASSIGNMENT 句を指定する適切な CAST
定義(「使用上の注意」を参照)が存在する必要があります。
TIME から UDT への暗黙的なキャスト定義が存在しない場合、Teradata Database は
TIME から UDT への暗黙的なキャスト定義に代用できる CHAR から UDT への、ま
たは VARCHAR から UDT への暗黙的なキャスト定義を検索します。Teradata
Database は暗黙的なキャスト定義を使用して UDT を文字データ型にキャストして
から、その文字データ型を DATE 型に暗黙的にキャストできるため、代用は有効で
す。UDT から文字への暗黙の CAST 定義が複数存在する場合、Teradata Database は
SQL エラーを戻します。
例
datetime_record が UDT である次のようなテーブルの定義を考えます。
CREATE TABLE support
(id INTEGER
,information datetime_record );
datetime_record UDT に適した CAST 定義が存在するという想定で、以下の文は、
information 列の値を TIME WITH TIME ZONE に変換します。
SELECT id, CAST (information AS TIME WITH TIME ZONE) FROM support;
SQL 関数、演算子、式および述部
703
第 13 章 データ型の変換
UDT から TIMESTAMP への変換
関連トピック
詳細は、以下を参照してください。
• データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
• CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>
を参照してください。
UDT から TIMESTAMP への変換
目的
UDT 式を TIMESTAMP データ タイプに変換します。
CAST 構文
CAST
( UDT_expression
AS
A
TIMESTAMP
(fractional_seconds_precision)
)
A
WITH TIME ZONE
data_attribute
構文要素
UDT_expression
UDT データ型となる式。
fractional_seconds_precision
SECOND フィールドの小数部の有効桁数を表わす 1 桁の数字。有効な範囲は、0 か
ら 6 です。デフォルトは 6 です。
time_data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、FORMAT などのデータ属性句を CAST で使用できます。
704
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
UDT から TIMESTAMP への変換
Teradata 変換構文
UDT_expression
A
TIMESTAMP
(
data_attribute ,
A
)
(fractional_seconds_precision)
,
data_attribute
WITH TIME ZONE
構文要素
UDT_expression
UDT データ型となる式。
data_attribute
以下のデータ属性のいずれか 1 つ。
• FORMAT
• NAMED
• TITLE
fractional_seconds_precision
SECOND フィールドの小数部の有効桁数を表わす 1 桁の数字。有効な範囲は、0 か
ら 6 です。デフォルトは 6 です。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
UDT の関与するデータ型の変換には、その UDT に適した CAST 定義が必要です。
UDT の CAST を定義するには、CREATE CAST 文を使用します。CREATE CAST の詳
細は、<SQL データ定義言語 - 構文規則および例、B035-1144>を参照してください。
暗黙タイプ変換
Teradata Database は、以下の操作に対して UDT から TIME への暗黙的変換を実行
します。
• UPDATE
• INSERT
• ストアド プロシージャ、外部ストアド プロシージャ、UDF、および UDM への
引数の引渡し。
SQL 関数、演算子、式および述部
705
第 13 章 データ型の変換
UDT から UDT への変換
• このマニュアル中の他の箇所に明記されている特定のシステム演算子と関数 (DBS
制御レコードの DisableUDTImplCastForSysFuncOp フィールドが TRUE に設定さ
れていない場合に限る)。
暗黙のデータ型変換を実行するには、AS ASSIGNMENT 句を指定する適切な CAST 定
義(使用上の注意を参照)が存在していなければなりません。
UDT から TIME への暗黙的なキャスト定義が存在しない場合、Teradata Database は
UDT から TIME への暗黙的なキャスト定義に代用できる UDT から CHAR への、また
は UDT から VARCHAR へのキャスト定義を検索します。Teradata Database は暗黙
的なキャスト定義を使用して UDT を文字データ型にキャストしてから、その文字
データ型を DATE 型に暗黙的にキャストできるため、代用は有効です。UDT から文
字への暗黙的なキャスト定義が複数存在する場合、Teradata Database は SQL エラー
を戻します。
例
datetime_record が UDT である次のようなテーブルの定義を考えます。
CREATE TABLE support
(id INTEGER
,information datetime_record );
datetime_record UDT に適した CAST 定義が存在するという想定で、以下の文は、
information 列の値を TIME WITH TIME ZONE に変換します。
SELECT id, CAST (information AS TIME WITH TIME ZONE) FROM support;
関連トピック
詳細は、以下を参照してください。
• データ タイプおよびデータ属性について、詳細は< SQL データ型とリテラル、
B035-1143>を参照してください。
• 結果が UDT データ タイプとなる式については、「SQL UDF」を参照してください。
• CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>
を参照してください。
UDT から UDT への変換
目的
UDT 式を別の UDT タイプに変換します。
706
SQL 関数、演算子、式および述部
第 13 章 データ型の変換
UDT から UDT への変換
CAST 構文
CAST
( UDT_expression
AS
UDT_data_type )
構文要素
UDT_expression
UDT データ型となる式。
UDT_data_definition
式が変換される UDT の型(FORMAT、NAMED、または TITLE データ属性句が続く)。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
ANSI を拡張したことで、FORMAT などのデータ属性句を CAST で使用できます。
使用上の注意
Teradata 変換構文を使った UDT から UDT への明示的な変換はサポートされていま
せん。
UDT の関与するデータ型の変換には、その UDT に適した CAST 定義が必要です。
UDT の CAST を定義するには、CREATE CAST 文を使用します。
暗黙タイプ変換
Teradata Database は、以下の操作に対して UDT から UDT への暗黙的なキャストを
実行します。
• UPDATE
• INSERT
• ストアド プロシージャ、外部ストアド プロシージャ、UDF、および UDM への
引数の引渡し。
• このマニュアル中の他の箇所に明記されている特定のシステム演算子と関数 (DBS
制御レコードの DisableUDTImplCastForSysFuncOp フィールドが TRUE に設定さ
れていない場合に限る)。
UDT が関与する暗黙のデータ タイプ変換を実行できるのは、CAST 定義に AS
ASSIGNMENT 句を指定した場合のみです。詳細については、<SQL データ定義言語
- 構文規則および例、B035-1144>の「CREATE CAST」を参照してください。
例
euro と us_dollar が UDT である次のようなテーブルの定義を考えます。
SQL 関数、演算子、式および述部
707
第 13 章 データ型の変換
UDT から UDT への変換
CREATE TABLE euro_sales_table
(euro_quarter INTEGER
,euro_region VARCHAR(20)
,euro_sales euro );
CREATE TABLE us_sales_table
(us_quarter INTEGER
,us_region VARCHAR(20)
,us_sales us_dollar );
euro UDT を us_dollar UDT に変換するのに適した CAST 定義が存在するという想定
で、以下の文は、us_dollar UDT から euro UDT への変換を実行します。
INSERT INTO euro_sales_table
SELECT us_quarter, us_region, CAST (us_sales AS euro)
FROM us_sales_table;
関連トピック
詳細は、以下を参照してください。
• 暗黙的な型の変換。
• 明示的なデータ型の変換における CAST
• 詳細については、<SQL データ定義言語 - 構文規則および例、B035-1144>の
「CREATE CAST」を参照してください。
• CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>
を参照してください。
708
SQL 関数、演算子、式および述部
第 14 章
データ タイプ変換関数
TO_BYTES
目的
特定のエンコーディングでの文字の並びをビットの並びにデコードします。以下の
エンコーディングがサポートされています 。
• BaseX
• BaseY
• Base64M (MIME)
• ASCII
X は 2 の累乗(たとえば、2、8、16)、Y は 2 の累乗ではありません(たとえば、10
や 36)。
構文
TO_BYTES
(instring, in_encoding )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
instring
文字列値(デコード対象の文字の並び)。
in_encoding
instring で指定した文字の並びを返すために TO_BYTES が使用するエンコード。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
SQL 関数、演算子、式および述部
709
第 14 章 データ タイプ変換関数
TO_BYTES
呼出し
TO_BYTES は埋め込みサービス システム関数です 。埋め込みサービス関数の有効化
と呼び出しについて、詳細は埋め込みサービス システム関数 を参照してください。
引数のタイプと規則
この関数に渡された式は、次のデータ タイプを持っている必要があります。
• instring = VARCHAR または CLOB
• in_encoding = VARCHAR(64)
TO_BYTES への 2 つの入力パラメータは、同じ文字セットを使用する必要がありま
す。パラメータは、Latin と Unicode など、異なる文字セットを使用することはでき
ません。
in_encoding がサポートされているエンコーディングの 1 つでない場合は、エラー
が返されます。
instring と in_encoding のどちらかが NULL の場合、結果は NULL になります。
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
CLOB または BLOB の最大入力または出力サイズは 4,000,000 バイトです。サイズ
が超過すると、エラーが報告されます。
結果のタイプ
結果のデータ タイプは VARBYTE または BLOB です。
例
例: 文字のシーケンスを Base16 にデコードする
以下の問合わせを実行します。
SELECT CAST (TO_BYTES ('5A', 'base16') as BTYE (16));
TO_BYTES('5A','base16')
'5A-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00'が返ります。
例: 文字のシーケンスを Base36 にデコードする
以下の問合わせを実行します。
710
SQL 関数、演算子、式および述部
第 14 章 データ タイプ変換関数
FROM_BYTES
SELECT CAST (TO_BYTES ('-22EEVX', 'base36') as BYTE (16));
TO_BYTES('-22EEVX','base36')
'F8-8D-33-23-00-00-00-00-00-00-00-00-00-00-00-00'が返ります。
関連トピック
詳細については、<SQL 外部ルーチン プログラミング 、B035-1147>の「互換デー
タ型」を参照してください。
FROM_BYTES
目的
ビットの並びを文字列の並びにエンコードします。文字の並びは、そのエンコーディ
ングでの表現になります。以下のエンコーディングがサポートされています 。
• BaseX
• BaseY
• Base64M (MIME)
• ASCII
X は 2 の累乗(たとえば、2、8、16)、Y は 2 の累乗ではありません(たとえば、10
や 36)。
構文
FROM_BYTES
(instring, out_encoding )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
instring
2 進数列値(エンコード対象の文字の並び)。
out_encoding
エンコーディング。FROM_BYTES では、このエンコーディングを使用して、instring
で指定した文字列の並びをエンコードします。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
SQL 関数、演算子、式および述部
711
第 14 章 データ タイプ変換関数
FROM_BYTES
呼出し
FROM_BYTES は埋め込みサービス システム関数です。埋め込みサービス関数の有効
化と呼び出しについて、詳細は埋め込みサービス システム関数を参照してください。
引数のタイプと規則
この関数に渡された式は、次のデータ タイプを持っている必要があります。
• instring = VARBYTE または BLOB
• out_encoding = VARCHAR(64)
out_encoding がサポートされているエンコーディングの 1 つでない場合は、エラー
が返されます。
変換の結果が結果のデータ タイプの長さを超えた場合は、エラーが生成されます。
instring と out_encoding のどちらかが NULL の場合、結果は NULL になります。
戻り型の文字セットは、Latin または Unicode に設定されます。戻り型の文字セット
は、エンコーディング入力パラメータの文字セットに一致するように設定されます。
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
CLOB または BLOB の最大入力または出力サイズは 4,000,000 バイトです。サイズ
が超過すると、エラーが報告されます。
結果のタイプ
結果のデータ タイプは VARCHAR または CLOB です。戻り値は NULL になる場合が
あります。
例
例 1: Base10 ビットのシーケンスを文字シーケンスにエンコードする
以下の問合わせを実行します。
SELECT from_bytes('5A1B'XB, 'base10');
'23067'が返ります。
例 2: ASCII ビットのシーケンスを文字シーケンスにエンコードする
以下の問合わせを実行します。
SELECT from_bytes('5A3F'XB, 'ASCII');
712
SQL 関数、演算子、式および述部
第 14 章 データ タイプ変換関数
TO_NUMBER
'Z\ESC 'が返ります。
例 3: Base16 ビットのシーケンスを文字シーケンスにエンコードする
以下の問合わせを実行します。
SELECT from_bytes('5A1B'XB, 'base16');
'5A1B'が返ります。
関連トピック
詳細については、<SQL 外部ルーチン プログラミング、B035-1147>の「互換デー
タ型」を参照してください。
TO_NUMBER
目的
string_expr を NUMBER データ タイプに変換します。
構文
)
TO_NUMBER ( string_expr
TD_SYSFNLIB.
, format_arg
, NLS_param
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
string_expr
文字式。string_expr には format_arg で指定されたフォーマットで数値が含まれま
す。変換に失敗すると NULL が返されます。
format_arg
文字式。
この構文要素が無効な場合、エラーが返されます。
この構文要素が NULL の場合、NULL が返されます。
NLS_param
文字式。
NLS_param では、次の数値書式構成要素で返される文字を指定します。
• 10 進数文字
SQL 関数、演算子、式および述部
713
第 14 章 データ タイプ変換関数
TO_NUMBER
•
•
•
•
グループ分離文字
ローカルの通貨記号
二重通貨記号
国際通貨記号
param の有効な値は、次のとおりです。
NUMERIC_CHARACTERS = ' 'dg ' '
CURRENCY = ' ' text ' '
DUAL_CURRENCY = ' ' text ' '
ISO_CURRENCY= ' ' text ' '
•
•
•
•
文字 d と g は、それぞれ 10 進数文字とグループ分離記号を表わします。これらは、
異なる単一バイトの文字にする必要があります。text は単一引用符で囲む必要があ
ります。通貨記号は、10 文字まで使用できます。
SDF (データの表示方法の使用)ファイルを使用して、デフォルト フォーマッティン
グが決定されます。NLS_param を指定することで、SDF ファイルで指定されたデ
フォルトを上書きします。
NLS_param が NULL の場合は NULL が返されます。
format_arg 書式構成要素
書式構成要素
Example...
戻り値
, (カンマ)
9,999
指定した位置にカンマが返されます。
• 数値書式の先頭をカンマにすることはできません。
• 数値書式の 10 進数文字またはピリオドの右側にカンマを指定する
ことはできません。
. (ピリオド)
9.99
小数点。
数値書式内では 1 つのピリオドのみ指定できます。
$
$9999
先頭にドル記号($)の付いた値。
0
09999
先頭にゼロ。
9990
末尾にゼロ。
9
9999
指定した桁数の値。正の場合は先頭に空白が追加され、負の場合は先
頭にマイナス記号が追加されます。
B
B9999
固定小数点数の整数部分の空白(整数部分がゼロの場合)。
C
C999
ISO 通貨記号(SDF ファイル内の ISOCurrency 構成要素で指定されます)。
D
99D99
非通貨値の整数部と小数部を分離する文字。
これは、SDF ファイル内の RadixSeparator 構成要素で指定されていま
す。
EEEE
714
9.9EEEE
科学表記法での値。
SQL 関数、演算子、式および述部
第 14 章 データ タイプ変換関数
TO_NUMBER
書式構成要素
Example...
戻り値
G
9G999
グループ分離記号。非通貨値の整数部の桁グループを分離する文字。
これは、SDF ファイル内の GroupSeparator 構成要素で指定されていま
す。
L
L999
ローカル通貨。ローカル通貨を表わす文字列(SDF ファイル内の
Currency 構成要素で指定されています)。
MI
9999MI
末尾のマイナス記号(値が負の場合)。
MI 書式構成要素は、数値書式の最後の部分にのみ指定できます。
PR
9999PR
<山括弧>で囲まれた負の値。
または、空白で囲まれた正の値。
PR 書式構成要素は、数値書式の最後の部分にのみ指定できます。
S
S9999
9999S
先頭または末尾にマイナス記号が付いた負の値。
先頭または末尾にプラス記号が付いた正の値。
S 書式構成要素は、数値書式の最後の部分にのみ指定できます。
TM
TM
TM9
TME
テキスト最小フォーマット。できるだけ少ない文字数を返します。こ
の構成要素は、大文字と小文字が区別されません。
TM または TM9 は、数値を固定表記法で返します(出力が 64 文字を超
えない場合)。出力が 64 文字を超える場合、数値は科学表記法で返さ
れます。
TME は、数値を最小文字数の科学表記で返します。
この構成要素を他の構成要素の前に指定することはできません。この
要素の後ろには 9 または E (または e)を 1 つ指定できますが、それらを
組み合わせることはできません。
U
U9999
二重通貨。二重通貨を表わす文字列(SDF ファイル内の DualCurrency
構成要素で指定されています)。
V
999V99
値を n 回だけ 10 倍します(必要に応じて丸めが実行されます)。この n
は、V の後ろの 9 の数になります。
X
XXXXX
xxxxx
指定した桁数の 16 進数値。指定した数値が整数でない場合、この関数
はその数値を整数に丸めます。
この構成要素は、正またはゼロのみを受け入れます。負の値の場合、
エラーを返します。この構成要素の前にはゼロ(先行ゼロを返します)ま
たは FM を指定できます。それ以外の構成要素の場合、エラーを返し
ます。ゼロまたは FM を指定していない場合、戻される値の先頭には
常に空白が追加されます。
SQL 関数、演算子、式および述部
715
第 14 章 データ タイプ変換関数
TO_NUMBER
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
TO_NUMBER は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡された式は、VARCHAR データ タイプでなければなりません。
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のデータ タイプに変
換できる、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
結果のタイプ
TO_NUMBER は戻り値のデータ タイプが NUMBER のスカラー関数です。
使用上の注意
次に、Teradata がサポートする TO_NUMBER 構文の例を示します。いずれの例も、
Oracle がサポートする TO_NUMBER 構文とは異なります。この関数には次の特徴が
あります。
• 閉じ山括弧のない PR 書式構成要素をサポートしません。この例では、数値が正
しい書式ではないため、NULL が返されます。
SELECT TO_NUMBER ('<123', '999PR')
• PR 書式構成要素を使用し、数値が正数である場合には、数値の最後にスペースを
挿入できます。この例では、123 が返されます。
SELECT TO_NUMBER (' 123 ', '999PR')
• 複数桁を科学表記法で指定できます。この例では、12000 が返されます。
SELECT TO_NUMBER ('12E3', '99EEEE')
• 科学表記法の整数部分でカンマを使用できます。この例では、1234000 が返さ
れます。
SELECT TO_NUMBER ('1,234E3', '9,999EEEE')
• 書式に小数がないときでも、引数が 2 つあるときには、カンマを検証します。こ
の例では、数値が正しい書式ではないため、NULL が返されます。
716
SQL 関数、演算子、式および述部
第 14 章 データ タイプ変換関数
TO_CHAR(Numeric)
SELECT TO_NUMBER ('1234', '9,999')
• 空の文字列をそれ以外の文字列と同じように扱います。この例では、書式が有効
でないため、NULL ではなくエラーが返されます。
SELECT TO_NUMBER ('', 'BAD Format')
• ピリオド(.)およびカンマ(,)と、D および G を同じ書式文字列で使用できます。こ
の例では、1234.99 が返されます。
SELECT TO_NUMBER ('1,234.99', '9,999D99')
例
例: string_expr の NUMBER データ型への変換
以下の問合わせは結果として 1789.96 を返します。
SELECT TO_NUMBER ('1789.96', '9999.99');
例: ドルの金額を NUMBER データ型に変換する
以下の問合わせは 123 を返します。
SELECT TO_NUMBER('dollar123','L999','NLS_CURRENCY=''dollar''');
関連トピック
詳細は、以下を参照してください。
• 詳細については、<SQL 外部ルーチン プログラミング、B035-1147>の「互換デー
タ型」を参照してください。
• 埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービ
ス システム関数 」を参照してください。
TO_CHAR(Numeric)
目的
numeric_expr を文字列に変換します。
構文
TO_CHAR
TD_SYSFNLIB.
( numeric_expr
)
, format_arg
, NLS_param
SQL 関数、演算子、式および述部
717
第 14 章 データ タイプ変換関数
TO_CHAR(Numeric)
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
numeric_expr
数値式。
変換に失敗すると、'#'文字が返されます。数値の整数部分が書式文字列で指定した
桁数に満たない場合、可変個数の'#'文字による文字列が返されます。返される'#'文
字の個数は、書式文字列または numeric_expr のデータ型に基づいた結果の文字列に
許容された、最大サイズと等しくなります。これには、任意選択のプラス/マイナス
記号を表わす 1 つの'#'文字が含まれます。
以下に例を示します。
SELECT TO_CHAR(12345678,'99')
'###'が返ります。
SELECT TO_CHAR(12345678,'99999')
'######'が返ります。
SELECT TO_CHAR(12345678,'99V9')
'####'が返ります。
format_arg
文字式。
format_arg は、数値をフォーマットするために使用されます。format_arg が省略さ
れると、numeric_expr は、その値の有効桁数を過不足なく保持できる長さの文字列
に変換されます。
この構文要素が無効な場合、エラーが返されます。
format_arg 値については、「TO_NUMBER」を参照してください。
NLS_param
文字式。
NLS_param では、次の数値書式構成要素で返される文字を指定します。
•
•
•
•
•
10 進数文字
グループ分離文字
ローカルの通貨記号
二重通貨記号
国際通貨記号
param の有効な値は、次のとおりです。
• NUMERIC_CHARACTERS = ' 'dg ' '
• CURRENCY = ' ' text ' '
• DUAL_CURRENCY = ' ' text ' '
718
SQL 関数、演算子、式および述部
第 14 章 データ タイプ変換関数
TO_CHAR(Numeric)
• ISO_CURRENCY= ' ' text ' '
文字 d と g は、それぞれ 10 進数文字とグループ分離記号を表わします。これらは、
異なる単一バイトの文字にする必要があります。text は単一引用符で囲む必要があ
ります。通貨記号は、10 文字まで使用できます。
SDF (データの表示方法の使用)ファイルを使用して、デフォルト フォーマッティン
グが決定されます。NLS_param を指定することで、SDF ファイルで指定されたデ
フォルトを上書きします。
NLS_param が NULL の場合は NULL が返されます。
NLS_param 値については、「TO_NUMBER」を参照してください。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
TO_CHAR(Numeric)は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡された式は、次のデータ タイプを持っている必要があります。
• numeric_expr = BYTEINT、SMALLINT、INTEGER、BIGINT、DECIMAL/
NUMERIC、FLOAT/REAL/DOUBLE PRECISION、または NUMBER
• format_arg = CHAR または VARCHAR
• NLS_param=CHAR または VARCHAR
結果のタイプ
TO_CHAR(Numeric)は戻りデータ タイプが VARCHAR CHARACTER SET UNICODE
のスカラー関数です。
例: numeric_expr から文字列への変換
以下の問合わせを実行します。
SELECT TO_CHAR(50000, '$99,999.99');
'$50,000.00'が返されます。
関連トピック
埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービス シ
ステム関数」を参照してください。
SQL 関数、演算子、式および述部
719
第 14 章 データ タイプ変換関数
TO_CHAR(DateTime)
TO_CHAR(DateTime)
目的
date_timestamp_value を文字列に変換します。
構文
TO_CHAR
( date_timestamp_value
TD_SYSFNLIB.
)
, format_arg
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
date_timestamp_value
日時または間隔の引数。
format_arg
文字式。
有効な format_arg 値については、「TO_DATE」を参照してください。
format_arg は、数値を書式化するために使用されます。format_arg が省略される
と、numeric_expr は、その値の有効桁数を過不足なく保持できる長さの文字列に変
換されます。
この構文要素が無効な場合、エラーが返されます。
この構文要素が NULL の場合、NULL が返されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
TO_CHAR(DateTime)は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡された式は、次のデータ タイプを持っている必要があります。
• date_timestamp_value = DATE、TIME、TIME WITH TIME ZONE、TIMESTAMP、
TIMESTAMP WITH TIME ZONE、または INTERVAL YEAR TO MONTH などの間
隔データ型。
720
SQL 関数、演算子、式および述部
第 14 章 データ タイプ変換関数
TO_DATE
• format_arg = CHAR または VARCHAR
結果のタイプ
TO_CHAR(DateTime)は戻りデータ タイプが VARCHAR CHARACTER SET UNICODE
のスカラー関数です。
例: date_timestamp_value から文字列への変換
以下の問合わせを実行します。
SELECT TO_CHAR(DATE '2003-12-23', 'DD-MON-YYYY');
結果として'23-DEC-2003'を返します。
関連トピック
埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービス シ
ステム関数」を参照してください。
TO_DATE
目的
string_expr を DATE データ タイプに変換します。
TO_DATE は、データを別の日時データ タイプに変換することはありません。
string_expr が DATE 値の TO_DATE 関数を使用してはいけません。返される DATE
値の最初の 2 桁は、format_arg またはデフォルトのデータ書式に応じて、元の
string_expr と異なることがあります。
構文
TO_DATE
( string_expr, format_arg )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
string_expr
文字式。
変換に失敗すると、TO_DATE はエラーを戻します。
SQL 関数、演算子、式および述部
721
第 14 章 データ タイプ変換関数
TO_DATE
format_arg
文字の引数。
format_arg は、string_expr のフォーマットを指定する日付フォーマットです 。
format_arg を省略した場合、次に示すデフォルトの日付書式が使用されます。YYYY-
MM-DD
format_arg が NULL の場合、TO_DATE は NULL を返します。
formal_arg が有効でない場合はエラーが返されます。
format_arg 書式構成要素
構成要素
説明
-
句読点文字は無視され、引用符で囲まれたテキストも無視されま
す。
/
,
.
;
:
「テキスト」
AD
A.D.
AD 識別子。
AM
A.M.
正午識別子。
BC
B.C.
BC 識別子。
CC
SCC
世紀。
4 桁で表わした年の最後の 2 桁が 01 から 99 の範囲以内にある
場合、世紀は、その年の最初の 2 桁よりも 1 だけ大きくなります。
4 桁で表わした年の最後の 2 桁が 00 の場合、世紀は、その年の
最初の 2 桁と同じになります。
注: CC および SCC は、TO_CHAR 関数でのみサポートされていま
す。
722
D
曜日(1 から 7)。
DAY
曜日の名前。
DD
月の日にち(1-31)。
SQL 関数、演算子、式および述部
第 14 章 データ タイプ変換関数
TO_DATE
構成要素
説明
DDD
年の日にち(1-366)。
DL
詳細表記の日付。フォーマット文字列'FMDay, Month FMDD,
YYYY'と同じです。
注: DL は TO_CHAR 関数でのみサポートされています。
DS
省略表記の日付。書式文字列'FMMM/DD/YYYYFM'と同じです。
注: DS は TO_CHAR 関数でのみサポートされています。
DY
曜日名の略語。
E
サポートしていません。
EE
サポートしていません。
FF [1..9]
小数秒。
[1..9]を使用して小数桁の数を指定します。
FF の後ろに続く数字がない場合は、入力データ タイプの小数秒
の数と等しい桁数の 10 進数値が出力されます。そのデータ タイ
プに小数桁がない場合、FF はなにも出力しません。
注: 6 桁を超える小数桁は切り捨てられます。
FM
書式最小モード。先頭や末尾に空白が付加されていない値が返さ
れます。これは、最小スペースを使用する必要のあるセクション
の前と後に、'FM'を追加することでオンとオフを切り替えること
ができます。
注: FM は TO_CHAR 関数でのみサポートされています。
FX
文字データと書式モデルが完全一致することが必要になります。
注: FX は TO_CHAR 関数ではサポートされていません。
HH
HH12
1 日の時間(1-12)。
HH24
1 日の時間(0-23)。
IW
ISO モデルに基づいた年の週(1 から 52、または 1 から 53)。
注: IW は TO_CHAR 関数でのみサポートされています。
IYY
IY
I
IYYY
SQL 関数、演算子、式および述部
ISO 年の後ろ 3 桁、2 桁、または 1 桁。
注: I、IY、および IYY は、TO_CHAR 関数でのみサポートされて
います。
ISO 年に基づいた 4 桁の年。
723
第 14 章 データ タイプ変換関数
TO_DATE
構成要素
説明
注: IYYY は TO_CHAR 関数でのみサポートされています。
J
ユリウス日。紀元前 4713 年 1 月 1 日からの日数。J を付けて指
定する日数は整数でなければなりません。
Teradata では、ユリウス日との一連の計算にグレゴリオ暦を使
用します。
MI
分(0 から 59)。
MM
月(01 から 12)。
MON
月の略語。
MONTH
月の名前。
PM
P.M.
正午識別子。
Q
年の四半期(1、2、3、4)。
注: Q は TO_CHAR 関数でのみサポートされています。
RM
ローマ数字の月(I から XII)。
RR
2 桁のみを使用して 20 世紀の日付を 21 世紀に格納します。現
在の年と、指定された年がどちらも 0 から 49 の範囲内にある場
合、日付は現在の世紀のものになります。
注: RR は TO_CHAR 関数ではサポートされていません。
RRRR
丸めた年。4 桁または 2 桁の入力を受け入れます。2 桁の入力
は、RR と同じ結果が返されます。
注: RRRR は TO_CHAR 関数ではサポートされていません。
SP
つづり。後に SP の付いた数値要素は英単語でつづられます。こ
の単語は構成要素の大文字表記にあわせて、大文字で表記されま
す。
たとえば、次のようになります。'DDDSP'はすべてに大文字を指
定します。'DddSP'は最初の文字に大文字を指定します。また、
'dddSP'はすべてに小文字を指定します。
注: SP は TO_CHAR 関数でのみサポートされています。
724
SS
秒(0 から 59)。
SSSSS
午前 0 時からの経過秒数(0 から 86399)。
TS
省略表記の時間。'HH:MI:SS AM'書式の文字列と同じです。
SQL 関数、演算子、式および述部
第 14 章 データ タイプ変換関数
TO_DATE
構成要素
説明
注: TS は TO_CHAR 関数でのみサポートされています。
TZD
サポートしていません。
TZH
タイムゾーンの時間。
TZM
タイムゾーンの分。
TZR
タイムゾーンの地域。'TZH:TZM'フォーマットの文字列と同じで
す。
注: TZR は TO_CHAR 関数でのみサポートされています。
WW
年の週(1 から 53)。第 1 週は、その年の最初の日から、その年
の 7 日目の日まで続きます。
注: WW は TO_CHAR 関数でのみサポートされています。
W
月の週(1 から 5)。第 1 週は、その月の最初の日から 7 日目の日
で終わります。注:W は TO_CHAR 関数でのみサポートされてい
ます。
X
ローカルの基数文字。
Y,YYY
この位置にカンマの付いた年。
YEAR
SYEAR
省略していない年。S を指定すると紀元前の日付の先頭にマイナ
ス符号が付加されます。
注: YEAR および SYEAR は、TO_CHAR 関数でのみサポートされ
ています。
YYYY
SYYYY
4 桁の年。S を指定すると紀元前の日付の先頭にマイナス符号が
付加されます。
YYY
YY
Y
年の後ろ 3 桁、2 桁、または 1 桁。
現在の年と、指定された年がどちらも 0 から 49 の範囲内にある
場合、日付は現在の世紀のものになります。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
TO_DATE は埋め込みサービス システム関数です 。
SQL 関数、演算子、式および述部
725
第 14 章 データ タイプ変換関数
TO_TIMESTAMP
引数のタイプと規則
この関数に渡された式は、VARCHAR データ タイプでなければなりません。
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
結果のタイプ
TO_DATE は戻り値のデータ タイプが DATE のオーバーロード スカラー関数です。
例: string_expr から DATE データ型への変換
以下の問合わせを実行します。
SELECT TO_DATE ('January 15, 1989, 11:00 A.M.', 'Month dd, YYYY, HH: MI
A.M.');
これは、結果として 15-JAN-89 を返します。
関連トピック
詳細は、以下を参照してください。
• 詳細については、<SQL 外部ルーチン プログラミング、B035-1147>の「互換デー
タ型」を参照してください。
• 埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービ
ス システム関数 」を参照してください。
TO_TIMESTAMP
目的
string_expr または integer_expr を TIMESTAMP データ タイプに変換します。
構文
TO_TIMESTAMP
TD_SYSFNLIB.
726
(
string_expr , format_arg
)
integer_expr
SQL 関数、演算子、式および述部
第 14 章 データ タイプ変換関数
TO_TIMESTAMP
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
string_expr
文字の引数。
変換に失敗すると、TO_TIMESTAMP はエラーを返します。
format_arg
文字式。
format_arg は、string_expr のフォーマットを指定する日付フォーマットです 。
有効な format_arg 値については、「TO_DATE」を参照してください。
指定された小数秒の 6 桁を超える部分は切り捨てられます。
format_arg を省略した場合、TO_TIMESTAMP はデフォルトのタイムスタンプの書
式 YYYY-MM-DD HH24:MI:SS.FF6 を使用します。
この構文要素が NULL の場合、NULL が返されます。
この構文要素が無効な場合、エラーが返されます。
integer_expr
数値の引数。
TO_TIMESTAMP 関数では、 integer_expr がこの関数に渡されると、POSIX 紀元変
換を暗黙的に行ないます。
POSIX 紀元は、協定世界時(UTC)の 1970 年 1 月 1 日午前 0 時から経過した秒数で
す。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
TO_TIMESTAMP は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡された式は、VARCHAR データ タイプまたは次の数値データ タイプで
ある必要があります。
• BYTEINT
• SMALLINT
• INTEGER
SQL 関数、演算子、式および述部
727
第 14 章 データ タイプ変換関数
TO_TIMESTAMP_TZ
• BIGINT
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
結果のタイプ
TO_TIMESTAMP は戻り値のデータ タイプが TIMESTAMP(6)のオーバーロード スカ
ラー関数です。
例
例: string_expr または integer_expr から TIMESTAMP データ型への変換
以下の問合わせを実行します。
SELECT TO_TIMESTAMP ('January 15, 1989, 11:00 A.M.', 'Month dd, YYYY,
HH: MI A.M.');
これは、結果として 1989-01-15 11:00:00.000000 を返します。
例: POSIX 紀元の変換
次の問合わせは、POSIX 紀元変換の例です。
SELECT TO_TIMESTAMP(242525);
これは、結果として 1970-01-03 19:22:05.000000 を返します。
関連トピック
詳細は、以下を参照してください。
• 詳細については、<SQL 外部ルーチン プログラミング、B035-1147>の「互換デー
タ型」を参照してください。
• 埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービ
ス システム関数 」を参照してください。
TO_TIMESTAMP_TZ
目的
string_expr を TIMESTAMP WITH TIME ZONE データ タイプに変換します。
728
SQL 関数、演算子、式および述部
第 14 章 データ タイプ変換関数
TO_TIMESTAMP_TZ
構文
TO_TIMESTAMP_TZ ( string_expr
TD_SYSFNLIB.
)
( , format_arg )
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
string_expr
文字の引数。
変換に失敗すると、TO_TIMESTAMP_TZ はエラーを返します。
format_arg
文字式。
format_arg は、string_expr のフォーマットを指定する日付フォーマットです 。
format_arg は、データを別の日時データ型に変換することはありません。
指定された小数秒の 6 桁を超える部分は切り捨てられます。
format_arg が省略されると、デフォルトのタイムゾーン付きタイムスタンプの書式
YYYY-MM-DD HH24:MI:SS.FF6 TZH:TZM が使用されます。
有効な format_arg 値については、「TO_DATE」を参照してください。
この構文要素が NULL の場合、NULL が返されます。
この構文要素が無効な場合、エラーが返されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
TO_TIMESTAMP_TZ は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡された式は、VARCHAR データ タイプでなければなりません。
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
SQL 関数、演算子、式および述部
729
第 14 章 データ タイプ変換関数
TO_YMINTERVAL
結果のタイプ
TO_TIMESTAMP_TZ は戻り値のデータ タイプが TIMESTAMP(6) WITH TIME ZONE
のオーバーロード スカラー関数です。
例: string_expr を TIMESTAMP WITH TIME ZONE データ型に変換する
以下の問合わせを実行します。
SELECT TO_TIMESTAMP_TZ ('January 15, 1989, 11:00 A.M.', 'Month dd, YYYY,
HH: MI A.M.');
これは、結果として 1989-01-15 11:00:00.000000+00:00 を返します。
関連トピック
詳細は、以下を参照してください。
• 詳細については、<SQL 外部ルーチン プログラミング、B035-1147>の「互換デー
タ型」を参照してください。
• 埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービ
ス システム関数 」を参照してください。
TO_YMINTERVAL
目的
次のいずれかで指定される string_value を
• SQL 間隔書式
• ISO 継続時間書式
INTERVAL YEAR(4) TO MONTH 値に変換します。
INTERVAL(4) YEAR TO MONTH 値を超える値は、エラーの原因になります。
構文
TO_YMINTERVAL
( string_value )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
730
SQL 関数、演算子、式および述部
第 14 章 データ タイプ変換関数
TO_YMINTERVAL
string_value
文字式。
string_value が空の文字列か NULL の場合、NULL が返されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
TO_YMINTERVAL は埋め込みサービス システム関数です 。埋め込みサービス関数
の有効化と呼び出しについて、詳細は埋め込みサービス システム関数を参照してく
ださい。
引数のタイプと規則
この関数に渡される式には、次のいずれかのデータ タイプが含まれている必要があ
ります。
CHAR、VARCHAR
string_value の書式
• SQL 間隔書式
INTERVAL 型の年月の書式は、[+ | -]YY-MM です。YY は 0 から 9999 の整数に
なり、MM は 0 から 11 の整数になります。
• ISO 継続時間書式
継続時間のフォーマットは、[-]P[n]Y[n]M[n]です。n は要素の値を指定します(例
えば、4Y は 4 年間になります)。
これは、ISO 継続時間の書式のサブセットを表わし、P、Y、M 以外の引数を使用
すると、無視されます。先行ゼロや後続ゼロは、任意選択です。構成要素内にス
ペースを入れることはできません。構成要素がゼロの場合は省略できますが、少
なくとも 1 つの構成要素と、その数値が必要になります。
先頭のマイナス記号は、負の間隔を示します。省略されると、間隔は正になりま
す。プラス記号は使用できません。
要素の値は、0 から間隔を超えない任意の値の整数になります。値は、それらの
通常の時間範囲を超えていてもかまいません。たとえば、1 年は 12 ヶ月ですが、
P14M は 14 ヶ月を表わします。ISO 継続時間の文字指定子は、次のような意味
を持ちます(YEAR TO MONTHS の INTERVAL 型に使用できる指定子は、P、Y お
よび M のみです)。
SQL 関数、演算子、式および述部
731
第 14 章 データ タイプ変換関数
TO_YMINTERVAL
ISO 指定子
定義
P
継続時間。常に先頭になります。
Y
年。年数の後に付きます。
M
月。月数の後に付きます。
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
結果のタイプ
戻り値のデータ タイプは INTERVAL YEAR(4) TO MONTH になります。
例
例 1: SQL 間隔書式として指定されている string_value の変換
以下の問合わせでは、SQL 間隔書式を指定します。
SELECT TO_YMINTERVAL('04-10');
これは、結果として'04-10'を返します。
例 2: ISO 継続時間として指定されている string_value の変換
以下の問合わせでは、ISO 継続時間を指定します。
SELECT TO_YMINTERVAL('P100Y4M');
これは、結果として'100-04' (100 年 4 か月)を返します。
例 3: string_value のエラー
以下の問合わせを実行します。
SELECT TO_YMINTERVAL('P20Y3M4DT12H23M34.234S');
これはエラーが返されます。使用可能な指定子が P、Y、および M のみのためです。
例 4: -14 か月の ISO 継続時間として指定された string_value の変換
以下の問合わせでは、-14 か月の ISO 継続時間を指定します。
SELECT TO_YMINTERVAL('-P14M');
これは、結果として'-01-02' (マイナス 1 年 2 か月)を返します。
732
SQL 関数、演算子、式および述部
第 14 章 データ タイプ変換関数
TO_DSINTERVAL
関連トピック
詳細は、以下を参照してください。
• 埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービ
ス システム関数 」を参照してください。
• 詳細については、<SQL 外部ルーチン プログラミング、B035-1147>の「互換デー
タ型」を参照してください。
TO_DSINTERVAL
目的
次のいずれかで指定される string_value を
• SQL 間隔書式
• ISO 継続時間書式
INTERVAL DAY(4) TO SECOND(6)値に変換します。
INTERVAL DAY(4) TO SECOND(6)の値を超える値は、すべてエラーの原因になりま
す。
構文
TO_DSINTERVAL ( string_value )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
string_vsalue
文字式。
string_value が空の文字列か NULL の場合、NULL が返されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
TO_DSINTERVAL は埋め込みサービス システム関数です 。埋め込みサービス関数の
有効化と呼び出しについて、詳細は埋め込みサービス システム関数を参照してくだ
さい。
SQL 関数、演算子、式および述部
733
第 14 章 データ タイプ変換関数
TO_DSINTERVAL
引数のタイプと規則
この関数に渡される式には、次のいずれかのデータ タイプが含まれている必要があ
ります。
• CHAR
• VARCHAR
string_value の書式
• SQL 間隔書式
INTERVAL 型の DAY TO SECOND の書式は、[+ | -]DD HH:MM:SS[.xxxxxx]になり
ます。1 つ以上のスペースで、日付を時間構成要素から分離します。構成要素間
のスペースの数は任意です。DD は 0 から 9999 までの整数、HH は 0 から 23 ま
での整数、MM は 0 から 59 までの整数、および SS は 0 から 59 までの整数にな
ります。任意選択の小数秒は.0 から.999999 までになります。
• ISO 継続時間書式
継続時間の書式は、[-]P[n]DT[n]H[n]M[n][.frac_secs]S になります。この n では、
要素の値を指定します(たとえば、4H は 4 時間になります)。これは、ISO 継続時
間書式のサブセットを表わします。その他の継続時間文字(有効な ISO 文字には、
Y や M などがあります)は、エラーの原因になります。
先行ゼロや後続ゼロは、任意選択です。構成要素内にスペースを入れることはで
きません。構成要素がゼロの場合は省略できますが、少なくとも 1 つの構成要素
と、その数値が必要になります。
先頭のマイナス記号は、負の間隔を示すために使用します。省略されると、間隔
は正になります。プラス記号は使用できません。要素の値は、0 から間隔を超え
ない任意の値の整数になります。小数秒は任意選択であり、.0 から.999999 まで
になります。
T 指定子は、必ず時間構成要素の前に指定します(また、完全な ISO 継続時間構文
内の月(Month)と分(Minute)の M のあいまい性を排除します)。H、M または S の
時間構成要素がない場合、T は無視されます。
値は、それらの通常の時間範囲を超えていてもかまいません。たとえば、1 日は
24 時間ですが、PT72H は 72 時間を表わします。ISO 継続時間の文字指定子は、
次のような意味を持ちます(DAY TO SECOND の INTERVAL 型に使用できる指定子
は P、D、T、H、M および S のみです)。
734
ISO 指定子
定義
P
継続時間。常に先頭になります。
D
日。日数の後に付きます。
T
時間。時間の要素 H、M、および S の前に付きます。
H
時間。時間数の後に付きます。
M
分。分の数の後に付きます。
SQL 関数、演算子、式および述部
第 14 章 データ タイプ変換関数
TO_DSINTERVAL
ISO 指定子
定義
S
秒。秒数の後に付きます。
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
結果のタイプ
戻り値のデータ タイプは INTERVAL DAY(4) TO SECOND(6)になります。
例
例 1: SQL 間隔書式として指定されている string_value の変換
以下の問合わせでは、SQL 間隔書式を指定します。
SELECT TO_DSINTERVAL('100 04:23:59');
これは、結果として'100 04:23:59.000000'を返します。
例 2: SQL 間隔書式として指定されている別の string_value の変換
以下の問合わせでは、SQL 間隔書式を指定します。
SELECT TO_DSINTERVAL('100 04:23:59.543');
これは、結果として'100 04:23:59.543000'を返します。
例 3: ISO 継続時間書式として指定されている string_value の変換
以下の問合わせでは、ISO 継続時間を指定します。
SELECT TO_DSINTERVAL('P100DT4H23M59S');
これは、結果として'100 04:23:59.000000'を返します。
例 4: 73 時間の ISO 継続時間として指定されている string_value の変換
以下の問合わせでは、73 時間の ISO 継続時間を指定します。
SELECT TO_DSINTERVAL('PT73H');
これは、結果として'3 01:00:00.000000' (3 日と 1 時間)を返します。
例 5: string_value の変換エラー
以下の問合わせを実行します。
SELECT TO_DSINTERVAL('P2MT12H');
これはエラーが返されます。月の指定子'2M'が許可されないためです。
SQL 関数、演算子、式および述部
735
第 14 章 データ タイプ変換関数
NUMTODSINTERVAL
関連トピック
詳細については、SQL 外部ルーチン プログラミング、B035-1147 の「互換データ
型」を参照してください。
NUMTODSINTERVAL
目的
numeric_value を INTERVAL DAY(4) TO SECOND(6)の値に変換します。
構文
NUMTODSINTERVAL
( numeric_value, interval_unit )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
numeric_value
数値式。
この構文要素が NULL の場合、NULL が返されます。
interval_unit
文字式。
interval_unit では、numeric_value 値の単位を指定します。これは、以下のいずれか
の値になります(大文字と小文字は区別されません)。
• 'DAY'
• 'HOUR'
• 'MINUTE'
• 'SECOND'
INTERVAL DAY(4) TO SECOND(6)の値を超える値は、すべてエラーの原因になります。
この構文要素が NULL の場合、NULL が返されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
736
SQL 関数、演算子、式および述部
第 14 章 データ タイプ変換関数
NUMTODSINTERVAL
呼出し
NUMTODSINTERVAL は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡された式は、次のデータ タイプを持っている必要があります。
• numeric_value = BYTEINT、SMALLINT、INTEGER、BIGINT、DECIMAL/
NUMERIC、FLOAT/REAL/DOUBLE PRECISION、または NUMBER
• interval_unit = CHAR または VARCHAR
結果のタイプ
戻り値のデータ タイプは INTERVAL DAY(4) TO SECOND(6)になります。
例
例 1: numeric_value の INTERVAL DAY(100) TO SECOND 値への変換
以下の問合わせを実行します。
SELECT NUMTODSINTERVAL(100, 'DAY');
これは、結果として'100 00:00:00.000000' (100 日)を返します。
例 2: numeric_value の INTERVAL DAY(100) TO HOURS 値への変換
以下の問合わせを実行します。
SELECT NUMTODSINTERVAL(100, 'HOURS');
これは、結果として'4 04:00:00.000000' (4 日と 4 時間)を返します。
例 3: numeric_value の INTERVAL DAY(100) TO MINUTES 値への変換
以下の問合わせを実行します。
SELECT NUMTODSINTERVAL(1600, 'MINUTES');
これは、結果として'1 02:40:00.000000' (1 日と 2 時間 40 分)を返します。
例 4: numeric_value の INTERVAL DAY(100) TO HOURS 値への変換
以下の問合わせを実行します。
SELECT NUMTODSINTERVAL(3.5, 'HOURS');
これは、結果として 3 時間 30 分を返します。
SQL 関数、演算子、式および述部
737
第 14 章 データ タイプ変換関数
NUMTOYMINTERVAL
関連トピック
埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービス シ
ステム関数」を参照してください。
NUMTOYMINTERVAL
目的
numeric_value を INTERVAL YEAR(4) TO MONTH の値に変換します。
構文
NUMTOYMINTERVAL
( numeric_value, interval_unit )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
numeric_value
数値式。
この構文要素が NULL の場合、NULL が返されます。
interval_unit
文字式。
interval_unit では、numeric_value 値の単位を指定します。これは、以下のいずれか
の値になります(大文字と小文字は区別されません)。
• 'YEAR'
• 'MONTH'
INTERVAL YEAR(4) TO MONTH の値を超える値は、すべてエラーの原因になります。
この構文要素が NULL の場合、NULL が返されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
NUMTOYMINTERVAL は埋め込みサービス システム関数です 。
738
SQL 関数、演算子、式および述部
第 14 章 データ タイプ変換関数
NUMTOYMINTERVAL
引数のタイプと規則
この関数に渡された式は、次のデータ タイプを持っている必要があります。
• numeric_value = BYTEINT、SMALLINT、INTEGER、BIGINT、DECIMAL/
NUMERIC、FLOAT/REAL/DOUBLE PRECISION、または NUMBER
• exponent_value = CHAR または VARCHAR
結果のタイプ
戻り値のデータ タイプは INTERVAL YEAR(4) TO MONTH になります。
例
例: numeric_value から INTERVAL YEAR(40) TO MONTH 値への変換
以下の問合わせを実行します。
SELECT NUMTOYMINTERVAL(40, 'YEAR');
これは、結果として'40-00' (40 年 0 か月)を返します。
例: numeric_value から INTERVAL YEAR(100) TO MONTH 値への変換
以下の問合わせを実行します。
SELECT NUMTOYMINTERVAL(100, 'MONTHS');
これは、結果として'08-04' (8 年 4 か月)を返します。
関連トピック
埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービス シ
ステム関数」を参照してください。
SQL 関数、演算子、式および述部
739
第 14 章 データ タイプ変換関数
NUMTOYMINTERVAL
740
SQL 関数、演算子、式および述部
第 15 章
日時および間隔の関数と式
概要
この章では、ANSI の日時値と間隔値を演算する関数と式について説明し、さらに
ANSI SQL:2011 規格の拡張機能である Teradata DATE 値を演算する関数と式につい
ても説明します。
ANSI の日時データ タイプ
ANSI の日時データ タイプには次のものがあります。
•
•
•
•
•
DATE
TIME
TIME WITH TIME ZONE
TIMESTAMP
TIMESTAMP WITH TIME ZONE
間隔データ タイプ
ANSI の間隔データ タイプは次の 2 つのカテゴリに分かれます。
• 年-月の間隔。以下のものがあります。
• YEAR
• YEAR TO MONTH
• MONTH
• 日-時の間隔。以下のものがあります。
• DAY
• DAY TO HOUR
• DAY TO MINUTE
• DAY TO SECOND
• HOUR
• HOUR TO MINUTE
• HOUR TO SECOND
• MINUTE
• MINUTE TO SECOND
• SECOND
SQL 関数、演算子、式および述部
741
第 15 章 日時および間隔の関数と式
ANSI の日時および間隔データ タイプの割り当て規則
ANSI の日時および間隔データ タイプの割り当て規則
データ タイプの互換性と変換
ANSI の日時または間隔データ タイプに関連した割り当てには、次の規則が適用され
ます。
ソース タイプ
ターゲット タイプ
結果
DATE
DATE
これらの型は互換性があるので、割り当てに変換
を必要としません。
既存の Teradata の割り当てとの互換性について
は、DATE の INTEGER への割り当てや INTEGER
の DATE の割り当て(検証チェック付き)などの非
ANSI 演算では、既存の Teradata の割り当て規則
に従います。
TIME
TIME
これらの型は互換性があるので、割り当てに変換
を必要としません。
Teradata システムの値 TIME は REAL としてエン
コードされ、ANSI の TIME および TIME WITH
TIME ZONE とは互換性がありません。
TIMESTAMP
TIMESTAMP
年-月の間隔
年-月の間隔
日-時刻の間隔
日-時刻の間隔
数値
DATE
DATE
• 文字
• 数値
• TIMESTAMP
文字
これらの型は互換性があるので、割り当てに変換
を必要としません。
Teradata Database は、割り当ての前に暗黙の型変
換を実行します。
参照整合性ルールについては、「暗黙的な型の変
換」を参照してください。
• DATE
• TIME
• TIMESTAMP
TIME
TIMESTAMP
TIMESTAMP
• DATE
• TIME
間隔
742
絶対数値
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
ANSI の日時および間隔データ タイプの割り当て規則
ソース タイプ
ターゲット タイプ
結果
注: INTERVAL タ
イプはフィールド
が 1 つだけ必要で
す。たとえば、
INTERVAL YEAR
です。
絶対数値
Interval
ANSI の日時と間隔のデータ タイプを伴う割り当てで他のソース/ターゲット デー
タ タイプを組み合わせる場合はすべて、タイプが明示的に変換されなければなりま
せん。
ANSI の DateTime または Interval データ型の明示的変換を実行するには、CAST 関
数を使用します。
構文
CAST
( expression
AS
ansi_sql_data_type
)
data_definition_list
構文要素
expression
異なるデータ型としてキャストされる、データ型が既知の式。
ansi_sql_data_type
式の新しいデータ型。
data_definition_list
式の新しいデータ型またはデータ属性、あるいはその両方。
間隔データ タイプの割り当て規則
年-月の間隔の割り当てには、以下の規則が適用されます。
条件
結果
タイプが一致する
直接的な割り当てになる。
ソースが INTERVAL YEAR でター
ゲットが INTERVAL YEAR TO
MONTH
ターゲットの MONTH の値がゼロに設定される。
SQL 関数、演算子、式および述部
743
第 15 章 日時および間隔の関数と式
ANSI の日時および間隔データ タイプの割り当て規則
条件
結果
ソースが INTERVAL MONTH で
ターゲットが INTERVAL YEAR TO
MONTH
ソースはゼロに初期化されている YEAR フィールドが
組み込まれるように拡張され、その結果の間隔が正規
化される。
たとえば、ソースが'15'の場合、拡張されたソースは
'0-15'になり、'1-03'に正規化されます。
ターゲットが INTERVAL MONTH
でソースが INTERVAL YEAR か
INTERVAL YEAR TO MONTH
割り当ての前にソースが INTERVAL MONTH に変換さ
れる。
たとえば、ソースが '2-11'の場合は'35'に変換されます。
ソースの最下位フィールドがター ソースのフィールドの値は、ターゲットの最下位フィー
ゲットの最下位フィールドより下位 ルドより精度が細かいのものが切り捨てられる。
である
たとえば、INTERVAL '32' MONTH のソースがタイプ
INTERVAL YEAR のターゲット列に割り当てられた場
合、格納される値は'2'になります。
日-時刻の間隔の割り当てには、以下の規則が適用されます。
条件
結果
タイプが一致する
直接的な割り当てになる。
ターゲットにソースの最下位フィー そのフィールドの値はゼロに設定される。
ルドより下位のフィールドがある
たとえば、ソースが INTERVAL '49:30' HOUR TO
MINUTE で、タイプ INTERVAL HOUR(4) TO
SECOND(2)のターゲットの列に割り当てられた場合、
格納される値は'49:30:00.00'です。
ターゲットにソースの最上位フィー ソース タイプはターゲット タイプに一致するように
ルドより上位のフィールドがある 拡張されて新規フィールドがゼロに設定され、最終ス
テップで内容が正規化される。
たとえば、ソースが INTERVAL '49:30' HOUR TO
MINUTE で、タイプ INTERVAL DAY TO MINUTE の
ターゲットの列に割り当てられた場合、格納される値
は'2 1:30'です。
ソースの最下位フィールドがター ソースのフィールドの値は、ターゲットの最下位フィー
ゲットの最下位フィールドより下位 ルドより精度が細かいのものが切り捨てられる。
である
たとえば、ソースが INTERVAL '10:12:58' HOUR TO
SECOND であって、タイプ INTERVAL HOUR TO
MINUTE のターゲット列に割り当てられた場合、格納
される値は'10:12'になります。
744
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
ANSI SQL:2011 の日時および間隔値でのスカラー演算
ANSI SQL:2011 の日時および間隔値でのスカラー演算
Teradata SQL では、ANSI の日時値と間隔値に使用できる一連のスカラー演算子が
定義されています。
スカラー演算には次のものがあります。
演算
説明
日時式
日時値となる結果を生じる式。日時式は、同じく日時式または間隔式
である引数をとります。
間隔式
間隔となる結果を生じる式。間隔式には、間隔、日時または Numeric
式である構成要素を組み込むことができます。
データ タイプの互換性
混合データ型の式を解決するための暗黙の変換の実行に関する Teradata Database
規則は、ANSI DateTime 値または Interval 値を使用する演算ではサポートされませ
ん。
ANSI DateTime 式または間隔式を変換するには、CAST 関数を使用します。明示的
なデータ型の変換における CAST を参照してください。
すべての日時および間隔スカラー演算で使われる値には、以下の制限事項が適用さ
れます。
条件
結果
2 つの日時値が同じ日時式にある
両方の値は同じ型を使用する必要があります。
DATE、TIME、および TIMESTAMP の値のタイプを混
合することはできません。
日時値と間隔値が同じ日時式に出現 間隔値には、日時値にも含まれている日時フィールド
する
だけが含まれていなければなりません。
2 つの間隔値が同じ間隔式に出現
する
両方の値は同じ型を使用する必要があります。
Year-Month と Day-Time 間隔を混合することはできま
せん。
ANSI の日時式
目的
DATE、TIME、または TIMESTAMP の値(または値式)で計算を実行し、同じタイプ
の単一の値を戻します。
日時式は、DATE、TIME、または TIMESTAMP 値の結果を戻す任意の式です。
SQL 関数、演算子、式および述部
745
第 15 章 日時および間隔の関数と式
ANSI の日時式
date_time_expression の構文
date_time_term
interval_expression
date_time_expression
date_time_term
+
±
interval_term
date_time_term の構文
date_time_primary
AT
LOCAL
expression
TIME ZONE
time_zone_string
構文要素
date_time_expression
DATE、TIME、または TIMESTAMP 値と評価される式。
式の形式は以下のうちの 1 つになります。
• 単一の date_time_term。
• interval_expression と date_time_term 式の合計。
• date_time_expression と interval_term の合計または差。
date_time_term
単一の date_time_primary、または AT LOCAL、AT [TIME ZONE] expression、また
は AT [TIME ZONE] time_zone_string のタイムゾーン指定子が指定された
date_time_primary。
interval_expression
以下のうちの 1 つです。
• 単一の interval_term。
• interval_term に対して加算または減算された interval_expression。
• start TO end 句に先行する date_time_expression と date_time_term (括弧で囲ま
れる)の差。
date_time_primary
以下の要素の 1 つ。どれも適切な DateTime 型を備えていなければなりません。
• 列参照
• 日時定数値
• 日時関数参照
たとえば、CASE 式または CAST 関数の結果や、または CURRENT_DATE や
CURRENT_TIME のような日時組み込み関数。
• スカラー関数参照
• 集約関数参照
• (table_expression)
スカラー subquery
746
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
ANSI の日時式
• (date_time_timestamp_expression)
AT LOCAL
現行セッションのタイムゾーンに基づくデフォルトのタイムゾーン変位を使用しま
す。現在のセッションのタイムゾーンは、タイムゾーン文字列として指定されるか、
ローカルのタイムゾーンのオフセットを定義する INTERVAL データ タイプとして表
わされるタイムゾーン変位として指定される。
AT [TIME ZONE] expression
式で定義されたタイムゾーンの変位を使用します。
expression のデータ タイプは INTERVAL HOUR(2) TO MINUTE か、暗黙的に
INTERVAL HOUR(2) TO MINUTE に変換できるデータ タイプでなければなりません。
AT [TIME ZONE] time_zone_string
time_zone_string は、タイムゾーン変位を決定します。
AT LOCAL および AT TIME ZONE タイムゾーン指定子
date_time_primary が TIME または TIMESTAMP 値と評価される場合、あるいはビ
ルトイン関数 CURRENT_DATE または DATE の場合に限り、date_time_primary 内
に AT LOCAL または AT [TIME ZONE]句を含めることができます。
効果は、date_time_term を指定されたタイムゾーン変位に合わせて調整することで
す。
AT [TIME ZONE]句でタイムゾーン変位を指定する expression は(必要なときに可能
であれば)、次に示す表で定義されたデータ型に応じて、タイムゾーン変位またはタ
イムゾーン文字列に暗黙的に変換されます。
expression のデータ タイプ
暗黙の変換
INTERVAL HOUR(n) TO MINUTE
(n が 2 でない場合)
CAST(expression AS INTERVAL HOUR(2) TO MINUTE)
INTERVAL HOUR
INTERVAL DAY
INTERVAL DAY TO HOUR
INTERVAL DAY TO MINUTE
INTERVAL DAY TO SECOND
INTERVAL HOUR
INTERVAL HOUR TO SECOND
INTERVAL MINUTE
INTERVAL MINUTE TO SECOND
INTERVAL SECOND
CAST(expression AS INTERVAL HOUR(2) TO MINUTE)
BYTEINT
SMALLINT
INTEGER
CAST(CAST(expression AS INTERVAL HOUR(2)) AS INTERVAL
HOUR(2) TO MINUTE)
SQL 関数、演算子、式および述部
747
第 15 章 日時および間隔の関数と式
ANSI の日時式
expression のデータ タイプ
暗黙の変換
BIGINT
DECIMAL/NUMERIC(小数部が 0 の
場合)
DECIMAL/NUMERIC (小数部が 0 以 CAST(CAST((expression)*60 AS INTERVAL MINUTE(4)) AS
上の場合)
INTERVAL HOUR(2) TO MINUTE)
CHARACTER SET UNICODE を使用 CAST(CAST(expression AS INTERVAL HOUR(2)) AS INTERVAL
する文字
HOUR(2) TO MINUTE)
上記の CAST 文でエラーが発生した場合、Teradata Database は次
の文を試行します。
CAST(expression AS INTERVAL HOUR(2) TO MINUTE)
この CAST 文でもエラーが発生した場合、Teradata Database は文
字の値をタイムゾーン文字列として処理します。
CHARACTER SET UNICODE ではな TRANSLATE(expression USING
い文字
source_repertoire_name_TO_Unicode)
source_repertoire_name は expression のサーバー文字セットで
す。コード変換された値は、上記の CHARACTER SET UNICODE を
使用した文字値に対する処理が実行されます。
その他
エラーが返されます。
注: 数値から INTERVAL 型への変換には全般的な制限があります。INTERVAL 型には
日時フィールドが 1 つだけ必要になります。ただし、この制限は、AT 句の expression
を暗黙的に変換する際には問題になりません。その理由は、この変換が 2 つの CAST
文を使用して実行されるためです。
INTERVAL HOUR(2) TO MINUTE への変換結果が、INTERVAL -'12:59' HOUR TO
MINUTE と、INTERVAL '14:00' HOUR TO MINUTE の間に収まらない値になると、
エラーが返されます。
AT [TIME ZONE] time_zone_string 句では、2 種類のタイムゾーン文字列を指定でき
ます。
• 独自の夏時間(DST)と、協定世界時(UTC 時間)からの標準タイムゾーン変位に対応
しない、タイムゾーン文字列。
• 独自の DST と、UTC 時間からの標準タイムゾーン変位に対応する、タイムゾーン
文字列。
サポートされているタイムゾーン文字列を次に示します。
独自の DST と標準タイムゾーン変位に対応しない文字列
748
• 'GMT'
• 'GMT+4'
• 'GMT-1'
• 'GMT+1'
• 'GMT+4:30'
• 'GMT-10'
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
ANSI の日時式
独自の DST と標準タイムゾーン変位に対応しない文字列
• 'GMT+10'
• 'GMT+5'
• 'GMT-11'
• 'GMT+11'
• 'GMT+5:30'
• 'GMT-2'
• 'GMT+11:30'
• 'GMT+5:45'
• 'GMT-3'
• 'GMT+12'
• 'GMT+6'
• 'GMT-4'
• 'GMT+13'
• 'GMT+6:30'
• 'GMT-5'
• 'GMT+14'
• 'GMT+7'
• 'GMT-6'
• 'GMT+2'
• 'GMT+8'
• 'GMT-6:30'
• 'GMT+3'
• 'GMT+8:45'
• 'GMT-7'
• 'GMT+3:30'
• 'GMT+9'
• 'GMT-8'
• 'GMT+9:30'
独自の DST と標準タイムゾーン変位に対応する文字列
• 'Africa Egypt'
• 'Asia Gaza'
• 'Australia Central'
• 'Africa Morocco'
• 'Asia Iran'
• 'Australia Eastern'
• 'Africa Namibia'
• 'Asia Iraq'
• 'Australia Western'
• 'America Alaska'
• 'Asia Irkutsk'
• 'Europe Central'
• 'America Aleutian'
• 'Asia Israel'
• 'Europe Eastern'
• 'America Argentina'
• 'Asia Jordan'
• 'Europe Kaliningrad'
• 'America Atlantic'
• 'Asia Kamchatka'
• 'Europe Moscow'
• 'America Brazil'
• 'Asia Krasnoyarsk'
• 'Europe Samara'
• 'America Central'
• 'Asia Lebanon'
• 'Europe Western'
• 'America Chile'
• 'Asia Magadan'
• 'Indian Mauritius'
• 'America Cuba'
• 'Asia Omsk'
• 'Mexico Central'
• 'America Eastern'
• 'Asia Syria'
• 'Mexico Northwest'
• 'America Mountain'
• 'Asia Vladivostok'
• 'Mexico Pacific'
• 'America Newfoundland'
• 'Asia West Bank'
• 'Pacific New Zealand'
• 'America Pacific'
• 'Asia Yakutsk'
• 'Pacific Samoa'
• 'America Paraguay'
• 'Asia Yekaterinburg'
• 'America Uruguay'
Teradata Database は、このタイムゾーン文字列を解決して、セッションまたは要求
された問合わせに対するタイムゾーン変位を計算します。
注: タイムゾーンの指定に、独自の DST と標準タイムゾーン変位に対応するタイム
ゾーン文字列を使用した場合にのみ、Teradata Database は夏時間の開始と終了を考
慮に入れて自動的にタイムゾーン変位を調整します。GMT 書式の文字列は、標準時
にのみに対応し、独自の夏時間が存在しないタイムゾーン文字列を表わします。た
とえば、インドではタイムゾーン文字列'GMT+5:30'が使用されているでしょう。こ
れは、年間を通して、5 時間 30 分の変位の間隔を適用するために使用できます。
SQL 関数、演算子、式および述部
749
第 15 章 日時および間隔の関数と式
ANSI の日時式
Teradata Database は、システム UDF(ユーザー定義関数)の
GetTimeZoneDisplacement に格納されたルールとタイムゾーン変位の情報に基づい
て、タイムゾーン文字列を解決します。
Teradata が提供するタイムゾーン文字列では要件を満たせないときには、新しいタ
イムゾーン文字列を追加するか、既存のタイムゾーン文字列に変更を加えてくださ
い。そのためには、GetTimeZoneDisplacement UDF に変更を加えるか、新しい規則
を追加することになります。
次に示す状況でも、AT 句を使用してタイムゾーンを明示的に指定できます。
• 以下のビルトイン関数を使用する場合。
• 「CURRENT_DATE」
• 「CURRENT_TIME」
• 「CURRENT_TIMESTAMP」
• 「DATE」
• 「TIME」
注: これらのビルトイン関数を AT LOCAL 句に指定すると、DBS 制御フラグ
TimeDateWZControl の設定に応じて返される値が変化します。
• CAST 関数または Teradata 変換構文を使用して、日時データ タイプを変換する場
合。変換元タイムゾーン、特定のタイムゾーン変位やタイムゾーン文字列、また
は現在のセッションのタイムゾーンとして、CAST や変換に使用するタイムゾー
ンを指定できます。
• フィールドの抽出前に、変換元の式のタイムゾーンを指定するために、EXTRACT
関数を使用する場合。
関連トピック
詳細は、以下を参照してください。
• セッション タイムゾーンの設定については、<SQL データ定義言語 - 構文規則お
よび例、B035-1144>の「SET TIME ZONE、CREATE USER、MODIFY USER」を
参照してください。
• システム タイムゾーン設定については、<ユーティリティ 、B035-1102>の
「System TimeZone Hour」および「System TimeZone Minute」を参照してくださ
い。
• DST を考慮に入れたシステム時間の自動調整については 、<ユーティリティ 、
B035-1102>の「SDF ファイル」および「Teradata Locale Definition ユーティリ
ティ(tdlocaledef)」を参照してください。
• 日時定数の詳細は、< SQL データ型とリテラル、B035-1143>を参照してください。
• 詳細は、「GetTimeZoneDisplacement」を参照してください。
• 詳細については、 「データ型の変換」を参照してください。
• タイムゾーンの詳細については、< SQL データ型とリテラル、B035-1143>の「日
付/時刻データ タイプと間隔データ タイプ」を参照してください。
750
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
ANSI の日時式
グレゴリオ暦の規則
日時式は、常にグレゴリオ暦の規則内で実行される。
そのような評価の結果、値がフィールドの許容範囲外になったり、DATE および TIME
の自然の規則に従って許容されない値になったりした場合は、エラーが戻される。
例えば、次の演算は、評価の結果の日付が有効でない('1996-09-31')ためエラーを
戻します。
SELECT DATE '1996-08-31' + INTERVAL '1' MONTH;
2 番目のオペランドを少し修正すれば、所定の結果が得られます。
SELECT DATE '1996-08-31' + INTERVAL '30' DAY;
この演算は、所定の結果の'1996-09-30'を戻します。エラーは戻されません。
評価のタイプ
日時値に関与する式は、結果が日時タイプになります。DATE は最下位タイプであ
り TIMESTAMP は最上位タイプです。
日時式に関与する値
結果
日付
日付。
時刻
時間。
タイムスタンプ
タイムスタンプ。
間隔値の加算と減算
日時値に間隔を加算することによって、または日時値から間隔を減算することによっ
て形成された日時値の式は、該当する構成要素フィールドの値の加算または減算を
行ない、該当するモジュロによって精度がより低いフィールドから桁あふれを持ち
越し、カレンダと時計に関する適切な演算を表わすことによって行なわれる。
interval_expression または interval_term には、それに対応する
date_time_expression または date_time_term に含まれている日時フィールドのみを
含めることができます。
TIME または TIMESTAMP 値に対して INTERVAL 値が加算または減算された場合、
結果に関連するタイムゾーン変位値は、TIME または TIMESTAMP 値に関連するタ
イムゾーン変位値と同じになります。
タイムゾーンの関係した計算
タイムゾーンを含んだ日時式で演算を行なう場合、結果は以下のように計算されます。
式 DV の日時値とタイムゾーン値構成要素(UTC に正規化される)を呼び出す。
SQL 関数、演算子、式および述部
751
第 15 章 日時および間隔の関数と式
ANSI の日時式
結果は DV - TZ として計算されます。
例
例: date_time_primary
この例では、date_time_primary はビルトイン時刻関数です。
SELECT CURRENT_TIME;
例: 整数値のタイムゾーン指定子が指定された date_time_term
この例では、 date_time_primary はビルトイン時刻関数であり、タイムゾーン変位
を太平洋標準時の負の整数値で指定しています。
SELECT CURRENT_TIME AT TIME ZONE -8;
例: 10 進数位取りのタイムゾーン指定子が指定された date_time_term
この例では、date_time_primary はビルトイン時刻関数であり、タイムゾーン変位を
ベネズエラのタイムゾーンの 10 進数位取り値で指定しています。
SELECT CURRENT_TIME AT TIME ZONE -4.5;
例: 'hh:mm'文字列のタイムゾーン指定子が指定された date_time_term
この例では、date_time_primary はビルトイン時刻関数であり、タイムゾーン変位を
ベネズエラのタイムゾーンの負の'hh:mm'文字列で指定しています。
SELECT CURRENT_TIME AT TIME ZONE -'4:30';
例: INTERVAL 列のタイムゾーン指定子が指定された date_time_term
この例では、date_time_term は f1 という名前の date_time_primary 列の値です。
TS.f1 はタイプ TIME または TIMESTAMP の値であり、intrvl.a はタイプ INTERVAL
HOUR(2) TO MINUTE の列間隔値です。
SELECT f1 AT TIME ZONE intrvl.a
FROM TS;
例: 間隔リテラルのタイムゾーン指定子が指定された date_time_term
この例では、date_time_term は f1 という名前の date_time_primary 列の値です。
指定された間隔は、タイプ INTERVAL HOUR TO MINUTE の間隔定数値です。
SELECT f1 AT TIME ZONE INTERVAL '01:00' HOUR TO MINUTE
FROM TS;
例: タイムゾーン文字列のタイムゾーン指定子が指定された date_time_term
この例では、date_time_term は f1 という名前の date_time_primary 列の値です。
752
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
ANSI の日時式
TS.f1 は、タイプ TIME または TIMESTAMP の値であり、タイムゾーン変位はタイ
ムゾーン文字列'America Pacific'に基づきます。
SELECT f1 AT TIME ZONE 'America Pacific'
FROM TS;
例: date_time_expression
この例では、date_time_expression は date_time_term に加算された
interval_expression です。これらの項は加算だけを行なえることに注意する必要が
あります。interval_expression から date_time_term を減算することはできません。
SELECT INTERVAL '20' YEAR + CURRENT_DATE;
例: 加算での date_time_expression
この例では、date_time_expression は、interval_term に加算された別の
date_time_expression から成ります。
列 subscribe_date および subscription_interval は、それぞれ DATE および
INTERVAL MONTH(4)にタイプ付けされます。
SUBSCRIBE_DATE + SUBSCRIPTION_INTERVAL
例: 減算での date_time_expression
date_time_expression から interval_term を減算することもできます。
この例では、interval_term が date_time_expression から減算されます。
列 expiration_date および subscription_interval は、それぞれ DATE および
INTERVAL MONTH(4)にタイプ付けされます。
EXPIRATION_DATE - SUBSCRIPTION_INTERVAL
タイムゾーンの整列順序
タイムゾーンは、同一タイムゾーンを使用して年代順に順序付けされます。
例
TIMESTAMP(0) WITH TIME ZONE 型の列が含まれるテーブルに対して、配列が指
定された SELECT 文を使用した次の例を考えてみてください。
これらの ORDER BY SELECT で示された同じ順番がすべてのタイムゾーン比較操作
に適用されます。
SELECT f1 TIMESTAMPFIELD
FROM timestwz
ORDER BY f1;
この文は、次の結果テーブルを戻します。
SQL 関数、演算子、式および述部
753
第 15 章 日時および間隔の関数と式
ANSI の日時式
TIMESTAMPFIELD
------------------------1997-10-07 15:43:00+08:00
1997-10-07 15:43:00-00:00
1997-10-07 15:47:52-08:00
値は、格納されたタイムゾーン情報と共に表示されますが、配列がすぐに明確にな
らないことに注意する必要があります。
ここで、CAST 関数によってタイムゾーンを標準化すると、年代順の配列が明示的に
示されます。
SELECT CAST(f1 AS TIMESTAMP(0)) TIMESTAMP_NORMALIZED
FROM timestwz
ORDER BY f1;
この文は、次の結果テーブルを戻します。
TIMESTAMP_NORMALIZED
------------------1997-10-06 23:43:00
1997-10-07 07:43:00
1997-10-07 15:45:52
並びは前の問合わせと同じですが、TIMESTAMP 値の表示はセッションに有効なタ
イムゾーン(すなわち '-08:00')に標準化されています。
タイムゾーンの処理を変える、すなわち地方時を反映させると、同じ年代順の並び
でも表示が異なります。
SELECT f1 AT LOCAL LOCALIZED
FROM timestwz
ORDER BY f1;
この文は、次の結果テーブルを戻します。
LOCALIZED
------------------------1997-10-06 23:43:00-08:00
1997-10-07 07:43:00-08:00
1997-10-07 15:45:52-08:00
関連トピック
詳細は、以下を参照してください。
• セッション タイムゾーンの設定については、<SQL データ定義言語 - 構文規則お
よび例、B035-1144>の「SET TIME ZONE、CREATE USER、MODIFY USER」を
参照してください。
• システム タイムゾーン設定については、<ユーティリティ 、B035-1102>の
「System TimeZone Hour」および「System TimeZone Minute」を参照してくださ
い。
754
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
ANSI の間隔式
• DST を考慮に入れたシステム時間の自動調整については 、<ユーティリティ 、
B035-1102>の「SDF ファイル」および「Teradata Locale Definition ユーティリ
ティ(tdlocaledef )」を参照してください。
• 日時定数の詳細は、< SQL データ型とリテラル、B035-1143>を参照してください。
• 詳細は、「GetTimeZoneDisplacement」を参照してください。
• 詳細については、 「データ型の変換」を参照してください。
• タイムゾーンの詳細については、< SQL データ型とリテラル、B035-1143>の「日
付/時刻データ タイプと間隔データ タイプ」を参照してください。
ANSI の間隔式
目的
間隔値(または値式)で計算を実行し、同じタイプの単一の値を戻します。
定義
間隔式は、間隔値の結果を戻す式です。
interval_expression の構文
interval_term
interval_expression
±
interval_term
date_time_expression
(
date_time_term
)
start
TO end
interval_term の構文
numeric_factor の構文
±
interval_primary
interval_term
*
numeric_factor
/
numeric_term
*
interval_factor
構文要素
interval_expression
以下のうちの 1 つです。
• 単一の interval_term。
• interval_term に対して加算または減算された interval_expression。
• start TO end 句に先行する date_time_expression と date_time_term (括弧で囲ま
れる)の差。
SQL 関数、演算子、式および述部
755
第 15 章 日時および間隔の関数と式
ANSI の間隔式
interval_term
以下の式のうちの 1 つです。
• 単一の interval_factor
• interval_term を numeric_factor によって乗算または除算したもの
• numeric_term と interval_factor の積
interval_factor
符号付きの interval_primary。
date_time_expression
DATE、TIME、または TIMESTAMP 値と評価される式。
式の形式は以下のうちの 1 つになります。
• 単一の date_time_term。
• interval_expression と date_time_term 式の合計。
• date_time_expression と interval_term の合計または差。
date_time_term
単一の date_time_primary、または AT LOCAL、AT [TIME ZONE] expression、また
は AT [TIME ZONE] time_zone_string のタイムゾーン指定子が指定された
date_time_primary。
start
次の構文を持つ、日付または時間間隔の開始を定義する日時値。
YEAR
MONTH
DAY
(precision
)
,fractional_seconds_precision
HOUR
MINUTE
SECOND
説明:
• precision は、許可される桁数(1~4)を指定します。デフォルトの桁数は 2 です。
• fractional_seconds_precision は、SECOND の値の小数点以下の桁数(0~6)を指定
します。デフォルトは 6 です。
MONTH および SECOND 値は、TO end を指定しない場合にのみ使用できます。
TO end
次の構文を持つ、日付または時間間隔の終了を定義する日時値。
MONTH
HOUR
(fractional_seconds_precision)
MINUTE
SECOND
756
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
ANSI の間隔式
fractional_seconds_precision は、SECOND の値の小数点以下の桁数(0~6)を指定し
ます。デフォルトは 6 です。
end の値は、start.の値よりも下位でなければなりません。
start が YEAR の値の場合、end は MONTH の値でなければなりません。
numeric_factor
符号付きの numeric_primary
numeric_term
numeric_factor または numeric_term を numeric_factor によって乗算または除算し
たもの。
numeric_primary
以下の要素のうちの 1 つ。どれも適切な数値型でなければなりません。
• 列参照
• 数値定数値
• スカラー関数参照
• 集約関数参照
• (table_expression)
スカラー subquery
• (numeric_expression)
interval_primary
以下の要素のうちの 1 つ。どれも適切な INTERVAL 型でなければなりません。
• 列参照
• 間隔定数値
間隔定数の詳細は、< SQL データ型とリテラル、B035-1143>を参照してください。
• スカラー関数参照
• 集約関数参照
• (table_expression)
スカラー subquery
• (interval_expression)
例
間隔式の構成要素と処理の例
この後の例では、間隔式の構成要素を示し、それらの構成要素が処理される方法に
ついて説明します。
interval_term の例
interval_term の定義は、以下の 4 つの形式で表わすことができます。
• interval_factor
SQL 関数、演算子、式および述部
757
第 15 章 日時および間隔の関数と式
ANSI の間隔式
• interval_term * numeric_factor
• interval_term / numeric_factor
• numeric_term * interval_factor
この例では、2 番目の定義を使用しています。
SELECT (INTERVAL '3-07' YEAR TO MONTH) * 4;
この演算の interval_term は、INTERVAL '3-07' YEAR TO MONTH です。
numeric_factor は 4 です。
処理の段階は、以下のようになります。
1 間隔は、INTEGER 値として 43 ヶ月に変換されます。
2 INTEGER 値が 4 倍され、172 ヶ月の結果を生成します。
3 結果は'14-4'に変換されます。
numeric_factor の例
この例では、INTERVAL YEAR TO MONTH に型付けされた値を持つ numeric_factor
を使用しています。
SELECT INTERVAL '10-02' YEAR TO MONTH * 12/5;
この演算での numeric_factor は、整数 12 です。
処理の段階は、以下のようになります。
1 間隔が 12 倍され、間隔の結果を生成します。
2 間隔の結果が 5 で除算され、'24-04'の結果を生成します。
括弧を使って評価の順番を変更すると、結果がまったく異なることに注意する必要
があります。例を示します。
SELECT INTERVAL '10-02' YEAR TO MONTH * (12/5);
この演算では、numeric_factor は(12/5)になります。
処理の段階は、以下のようになります。
1. numeric_factor が計算されて 2.4 の結果を生成します。値はデフォルトで整数な
ので、結果は切り捨てられて 2 になります。
2. 間隔が 2 で乗算され、'20-04'の結果を生成します。
interval_term/numeric_factor の例
次の例では、numeric_factor 値によって除算された interval_term 値を使用していま
す。
SELECT INTERVAL '10-03' YEAR TO MONTH / 3;
interval_term は INTERVAL '10-03' YEAR TO MONTH です。
758
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
ANSI の間隔式
numeric_factor は 3 です。
処理の段階は、以下のようになります。
1 間隔値は月の値に分解されます。
10 年と 3 ヶ月が評価されて 123 ヶ月になります。
2 間隔の合計が numeric_factor である 3 によって除算され、結果が'3-05'になり
ます。
次の例は、整数の算術で切り捨てが行なわれる方法を示している点を除いて、最初
の例と類似しています。
SELECT INTERVAL '10-02' YEAR TO MONTH / 3;
interval_term は INTERVAL '10-02' YEAR TO MONTH です。
numeric_factor は 3 です。
処理の段階は、以下のようになります。
1. 間隔値は月の値に分解されます。
10 年と 2 ヶ月が評価されて 122 ヶ月になります。
2. 間隔の合計が numeric_factor である 3 によって除算され、40.67 か月という結
果を生成します。値は整数なので、結果が切り捨てられて 40 になります。
3. 間隔の合計が適切な形式に変換し直され、INTERVAL '3-04'という結果を生成し
ます。
numeric_term * interval_primary の例
この形式では、numeric_term の値に乗算と除算のインスタンスを含めることがで
きます。
SELECT 12/5 * INTERVAL '10-02' YEAR TO MONTH;
numeric_term は 12/5 です。
interval_primary は INTERVAL '10-02' YEAR TO MONTH です。
処理の段階は、以下のようになります。
1 numeric_term 12/5 が評価されて 2.4 の結果を生成します。値はデフォルトで
整数なので、結果は切り捨てられて 2 になります。
2 interval_primary が 2 で乗算され、'20-04'の結果を生成します。
numeric_term * ± interval_primary の例
この例では、負の interval_primary を numeric_term 倍し、負の結果を
interval_term に加算します。
SELECT (RACE_DURATION + (2 * INTERVAL -'30' DAY));
この場合の numeric_term は、numeric_primary 2 です。
SQL 関数、演算子、式および述部
759
第 15 章 日時および間隔の関数と式
ANSI の間隔式
interval_primary は INTERVAL -'30' DAY です。
RACE_DURATION は interval_term であり、タイプは INTERVAL DAY TO SECOND で
す。
処理の段階は、以下のようになります。
1 interval_primary が正確な数値、すなわち 60 日に変換されます。
2 この算術に示された演算がオペランド(この時点では両方とも数値)上で行なわれ、
適切な位取りと精度を持つ正確な数値の結果を生成します。
この例では、60 日が RACE_DURATION から減算されます。RACE_DURATION
は、INTERVAL DAY TO SECOND の間隔タイプです。
3 数値の結果が、示された間隔タイプ、DAY TO SECOND に変換し直されます。
interval_expression の例
interval_expression の定義は、以下の 3 つの形式で表わすことができます。
• interval_term
• interval_expression + interval_term
• (date_time_expression - date_time_term) start TO end
この例では、2 番目の定義を使用しています。
SELECT (CAST(INTERVAL '125' MONTH AS INTERVAL YEAR(2) TO MONTH))
+ INTERVAL '12' YEAR;
interval_expression は INTERVAL '125' MONTH です。
interval_term は INTERVAL '12' YEAR です。
処理の段階は、以下のようになります。
1 CAST 関数が、125 か月の interval_expression の値を 10 年と 5 か月に変換しま
す。
2 12 年の interval_term の値が interval_expression の値に加算され、22 年と 5 か
月という結果を生成します。
3 結果が適切なデータ タイプである INTERVAL YEAR(2) TO MONTH に変換され、
'22-05'の結果を生成します。
この例では、interval_expression の 3 番目の定義を使用しています。
date_time_expression の値と date_time_term の値が比較可能であるようにしなけれ
ばなりません。
SELECT (TIME '23:59:59.99' - CURRENT_TIME(2)) HOUR(2) TO SECOND(2);
date_time_expression は TIME '23:59:59.99'です。
date_term は、date_time_primary - CURRENT_TIME(2)です。
処理の段階は、以下のようになります。
760
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
ANSI の間隔式
1. 現在のシステム時刻を 18:35:37.83 と仮定します。
2. HOUR(2) TO SECOND(2)の時間間隔 18:35:37.83 が TIME の値 23:59:59.99 か
ら減算され、'5:24:22.16'の結果を生成します。
ここでは interval_expression の 3 番目の定義を使用して、2 つの TIMESTAMP 値の
分単位での差分を確かめる別の例を示します。まずテーブルを定義します。
CREATE TABLE BillDateTime
(start_time TIMESTAMP(0)
,end_time TIMESTAMP(0));
次に、分単位の差を判別します。
SELECT (end_time - start_time) MINUTE(4)
FROM BillDateTime;
処理の段階は、以下のようになります。
1. start_time TIMESTAMP 値が end_time TIMESTAMP 値から減算されて間隔結果
を生じます。
2. MINUTE(4)は 4 桁の精度の分単位の間隔を指定します。この場合、最大 9999
分(約 1 週間)を指定できます。
規則
間隔式には以下の規則が適用されます。
• 間隔に関与する式は、オペランドを整数に変換し、結果の算術式を評価し、次に
結果を適切な間隔に変換し直すことによって評価される。
• interval_expression と interval_primary のデータ型はどちらも INTERVAL であ
る。
• interval_expression には、年-月の間隔構成要素か、日-時刻の間隔構成要素のど
ちらかが含まれていなければならない。間隔のタイプを混合することは許されな
い。
• 間隔に関連した式の場合、日時式や数値式がその中に入っていても、常に間隔と
評価されます。
interval_expression 内の構成要素
結果
間隔タイプのただ 1 つの構成要素
同じ間隔タイプです。
単一の日時値または start TO end 句
日時または start TO end 句の値に対して指定された
日時フィールドを含みます。
間隔タイプの複数の構成要素
構成要素フィールドの間隔タイプのすべての日時
フィールドを含んだ間隔タイプです。
SQL 関数、演算子、式および述部
761
第 15 章 日時および間隔の関数と式
算術演算子および ANSI の DateTime と間隔のデータ型
複数のフィールドをもつ間隔の正規化
解析プログラムが複数のフィールドの間隔値を正規化する方法のために 、間隔値に
定義された精度では正規化後の間隔値を入れるのに十分な大きさでないことがあり
ます。
たとえば INTERVAL YEAR(2) TO MONTH と定義された列に'99-12'という値を挿入
すると、その値は解析プログラムによって'100-00'に正規化されるために、桁あふ
れエラーを起こします。その値を 2 桁の YEAR フィールドを持つと定義された列に
挿入しようとした場合は、年が 3 桁であるために失敗します。
次の式は、タイプの許容範囲の値を超えているために桁あふれエラーを戻します。
まずテーブルを定義します。
CREATE TABLE BillDateTime
(column_1 INTERVAL YEAR
,column_2 INTERVAL YEAR(1) TO MONTH
,column_3 INTERVAL YEAR(2) TO MONTH
,column_4 INTERVAL YEAR(3) TO MONTH );
ここで、次の INSERT 文を使用して値 INTERVAL '999-12' YEAR TO MONTH を挿入
します。
INSERT BillDateTime (column_1, column_4)
VALUES ( INTERVAL '40' YEAR, INTERVAL '999-12' YEAR TO MONTH );
INTERVAL YEAR(3) TO MONTH の値の有効な範囲は-'999-11'から'999-11'までなの
で、結果は桁あふれエラーになります。
'999-12'の値ならば問題がないように見えるかも知れませんが、解析プログラムは
その値を'1000-00' YEAR TO MONTH に正規化するので、それも失敗します。年の
値は次に 4 桁になるので、桁あふれが発生して演算が失敗します。
算術演算子および ANSI の DateTime と間隔のデータ型
ANSI の日時値と間隔値の演算では、スカラー算術演算子+、-、*、および/を使用す
ることができます。ただし、特定の組み合わせの日時値と間隔値に対してのみ演算
子は有効になります。
算術演算子と結果タイプ
日時および間隔のデータ タイプでは、以下の算術演算を行なうことができます。
762
最初の値のタイプ
演算子
2 番目の値のタイプ
結果のタイプ
日時
-
日時
間隔
日時
+
間隔
日時
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
算術演算子および ANSI の DateTime と間隔のデータ型
最初の値のタイプ
演算子
2 番目の値のタイプ
結果のタイプ
日時
-
間隔
日時
間隔
+
日時
日時
間隔
+
間隔
間隔
間隔
-
間隔
間隔
間隔
*
数値
間隔
間隔
/
数値
間隔
数値
*
間隔
間隔
DATE に対する数の加算と減算
Teradata SQL では、ANSI DATE 値に対して日数を加算または減算できるように ANSI
SQL:2011 規格が拡張されています。
Teradata SQL ではそのような数を INTERVAL DAY 値として扱います。
2 つの日時値の差の計算
Teradata Database は、ANSI SQL 規格に従って 2 つの DATE、TIME、または
TIMESTAMP 値間の差分を計算します。結果の単位より小さな単位は、間隔値を計
算するときに無視されます。
たとえば、2 つの DATE 値の月差を計算する場合、2 つのオペランドのそれぞれの
日の値は無視されます。同様に、2 つの TIMESTAMP 値の差分(時間単位)を計算す
る場合、オペランドの分や秒の値は無視されます。
例
例: DATE 値間の日数の差の計算
次の問合わせは、2 つの DATE 値の日差を計算します。
SELECT (DATE '2007-05-10' - DATE '2007-04-28') DAY;
結果は、以下のようになります。
(2007-05-10 - 2007-04-28) DAY
----------------------------12
次の問合わせは、2 つの DATE 値の月差を計算します。
SELECT (DATE '2007-05-10' - DATE '2007-04-28') MONTH;
SQL 関数、演算子、式および述部
763
第 15 章 日時および間隔の関数と式
集約関数と ANSI の日時および間隔データ タイプ
結果は、以下のようになります。
(2007-05-10 - 2007-04-28) MONTH
------------------------------1
2 つの日付の間には 12 日の差がありますが、1 か月にはなりません。しかし、
Teradata Database は計算時に日の値を無視して月の値だけを考慮するため、結果は
4 月と 5 月の差分を示す 1 か月の間隔になります。
例: DATE への間隔の加算
以下の例では、日時値に間隔値が加算されます。
CREATE TABLE Subscription
(id CHARACTER(13)
,subscribe_date DATE
,subscribe_interval INTERVAL MONTH(4));
INSERT Subscription (subscribe_date, subscribe_interval)
VALUES (CURRENT_DATE, INTERVAL ’24’ MONTH);
SELECT subscribe_date + subscribe_interval FROM Subscription;
結果は日時値になります。
関連トピック
詳細については、「DATE 値と整数の算術演算」を参照してください。
集約関数と ANSI の日時および間隔データ タイプ
ANSI SQL:2011 の日時タイプには、以下の集約関数が有効です。
関数
結果
AVG(arg)
引数のタイプ。
MAX(arg)
日時タイプの比較規則に基づく引数のタイプ。「MAX」。
MIN(arg)
「MIN」。
COUNT(arg)
モードが Teradata であれば INTEGER。
詳細の参照先
「AVG」。
「COUNT」。
モードが ANSI であれば DECIMAL(n,0)。ただ
し、
• DBSControl 内の MaxDecimal の値が 0、
15、18 のいずれかである場合、n は 15 で
す。
764
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
スカラー演算と日時関数
関数
結果
詳細の参照先
• DBSControl 内の MaxDecimal の値が 38 で
ある場合、n は 38 です。
間隔データ タイプ
間隔タイプには、以下の集約関数が有効です。
関数
結果
詳細の参照先
AVG(arg)
引数のタイプ。
「AVG」。
COUNT(arg)
モードが Teradata であれば INTEGER。
「COUNT」。
モードが ANSI であれば DECIMAL(n,0)。ただ
し、
• DBSControl 内の MaxDecimal の値が 0、
15、18 のいずれかである場合、n は 15 で
す。
• DBSControl 内の MaxDecimal の値が 38 で
ある場合、n は 38 です。
MAX(arg)
日時タイプの比較規則に基づく引数のタイプ。「MAX」。
MIN(arg)
「MIN」。
SUM(arg)
引数のタイプ。
「SUM」。
スカラー演算と日時関数
日時関数は、日時値または間隔値で動作し、結果として日時値を戻す関数です。
サポートされる日時関数は以下のとおりです。
•
•
•
•
CURRENT_DATE
CURRENT_TIME
CURRENT_TIMESTAMP
EXTRACT
同期化の問題を避けるために、これらの関数での演算は DATE、TIME、または
TIMESTAMP について同一の定義を使用することが保証されており、以下の事柄が
常に当てはまります。
•
•
•
•
CURRENT_DATE = CURRENT_DATE
CURRENT_TIME = CURRENT_TIME
CURRENT_TIMESTAMP = CURRENT_TIMESTAMP
CURRENT_DATE と CURRENT_TIMESTAMP は常に同じ DATE を識別する
SQL 関数、演算子、式および述部
765
第 15 章 日時および間隔の関数と式
Teradata の日付および時刻の式
• CURRENT_TIME と CURRENT_TIMESTAMP は常に同じ TIME を識別する
これらの値は、要求が開始された時点の時間を反映し、要求の継続中に変化するこ
とはありません。
例: CURRENT_DATE DateTime 関数の使用
以下の例は CURRENT_DATE 日時関数を使用します。
SELECT INTERVAL '20' YEAR + CURRENT_DATE;
関連トピック
詳細は、以下を参照してください。
• CURRENT_DATE の詳細については、CURRENT_DATE を参照してください。
• CURRENT_TIME の詳細については、CURRENT_TIME を参照してください。
• CURRENT_TIMESTAMP の詳細については、CURRENT_TIMESTAMP を参照して
ください。
• EXTRACT の詳細については、EXTRACT を参照してください。
Teradata の日付および時刻の式
Teradata SQL では、DATE 値のためのデータ タイプが提供され、REAL タイプでエ
ンコードされた数として TIME 値が格納されます。これは、ANSI SQL:2011 規格の
Teradata 拡張部分であり、使用しないでください。
DATE 値および TIME 値は、どちらもエンコードされた値であり、単純な整数または
実際の数ではないので、これらの値の算術演算には制約があります。
ANSI DATE および TIME 値は、適切な日時タイプを使用して格納され、日時の割り
当てと式についての一連の独自の規則があります。詳細については、「ANSI の日時
および間隔データ型の割り当て規則」と「ANSI SQL:2011 の日時および間隔値での
スカラー演算」を参照してください。
DATE 値と整数の算術演算
以下の算術関数は、日付と整数を使用して実行することができます(INTEGER は日数
と解釈されます)。
• DATE + INTEGER
• INTEGER + DATE
• DATE - INTEGER
これらの式は、単純な加算または減算として処理されません。以下のように処理さ
れます。
1 エンコードされた日付値が、あるシステム定義の固定日からの日数を示す中間値
に変換されます。
766
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
Teradata DATE 値でのスカラー演算
2 次に整数値が加算または減算され、基本となる固定日からの日数としての別の
値が形成されます。
3 その結果が、グレゴリオ暦で有効な日付値に戻されます。
DATE 値と日付の算術演算
DATE - DATE の式は、単純な減算としては処理されません。以下のように処理され
ます。
1 エンコードされた日付値が、あるシステム定義の固定日からのそれぞれの日数
を示す中間値に変換されます。
2 この中間値の 2 番目の値が最初の値から減算され、2 つの日付の間の日数が求め
られます。
3 値自体が整数であっても、結果は、ANSI SQL:2011 書式の INTERVAL DAY で戻
されます。
日付値についてのその他の算術演算で結果は得られますが、その結果には意味があ
りません。
例: DATE/2 の整数値の結果
DATE/2 によって整数の結果が得られますが、その値には意味がありません。
時間値について意味のある単純な算術演算はありません。その理由は、時間値が次
のようにエンコードされた時間の実数だからです。
(HOUR*10000 + MINUTE*100 + SECOND)
ここで、SECOND には小数値を含めることができます。
Teradata DATE 値でのスカラー演算
加算と減算の演算は以下のように許可されます。ここで、整数値は日数を表わします。
引数 1
演算
引数 2
結果
DATE
+
INTEGER
DATE
DATE
-
INTEGER
DATE
INTEGER
+
DATE
DATE
DATE
-
DATE
INTEGER
たとえば、90 日を加算することは 3 か月を加算することと同じではありません。
それぞれの月の日数が異なるからです。
SQL 関数、演算子、式および述部
767
第 15 章 日時および間隔の関数と式
LAST_DAY
また、うるう年があるので、365 日の倍数を加算することは年を加算することと同
じではありません。
Teradata の DATE 式でのスカラー演算は、ANSI SQL:2011 のデータ型を使って実行
されます。そのため、date_expression - numeric_expression のタイプの式は、
numeric_expression の構成要素が INTERVAL DAY としてタイプ付けされたかのよう
に扱われます。
ANSI SQL:2011 の日付および間隔の値は、独自のスカラー演算の集合を持ち、ここ
で DATE として定義されたスカラー演算を除いて、混合されたデータ タイプの式を
解決するための暗黙的な変換をサポートしません。
ADD_MONTHS 関数
ADD_MONTHS 関数は、月または年の加算と減算をするためのものであり、関与す
るさまざまな日数を処理します。
EXTRACT 関数
EXTRACT 関数を使用して、日付から年、月、または日を入手します。結果は
INTEGER データ タイプを持ちます。
関連トピック
詳細は、以下を参照してください。
• 詳細については、「ADD_MONTHS」を参照してください。
• 詳細については、「EXTRACT」を参照してください。
LAST_DAY
目的
date_timestamp_value を含む月の最終の日付を返します。
構文
LAST
( period_expression )
( derived_period )
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
768
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
LAST_DAY
date_timestamp_value
日付またはタイムスタンプの引数。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
LAST_DAY は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡される式には、次のいずれかのデータ タイプが含まれている必要があ
ります。
• DATE
• TIMESTAMP
• TIMESTAMP WITH TIME ZONE
TIMESTAMP 値は、UTC 時間でデータベースに格納されるためタイムゾーンが欠け
ています。そのため、この関数内ではタイム スタンプ値の解釈にセッションのタイ
ムゾーンを使用します。TIMESTAMP WITH TIME ZONE 値の場合、この関数内では
タイム スタンプ値の解釈にタイムゾーン構成要素を使用します。
結果のタイプ
戻りデータ タイプは DATE です。
例
例 1: 月の最終日の DATE の問合わせ
以下の問合わせを実行します。
SELECT LAST_DAY(DATE '2009-12-20');
これは、結果として 09/12/31 を返します。
例 2: 月の最終日の TIMESTAMP の問合わせ
以下の問合わせを実行します。
SELECT LAST_DAY(TIMESTAMP '2009-08-25 10:14:59');
これは、結果として 09/08/31 を返します。
SQL 関数、演算子、式および述部
769
第 15 章 日時および間隔の関数と式
NEXT_DAY
例 3: 月の最終日の TIMESTAMP WITH TIME ZONE の問合わせ
以下の問合わせを実行します
SELECT LAST_DAY(TIMESTAMP '2009-06-15 10:14:59-8:00');
以下の問合わせを実行します
SELECT LAST_DAY(TIMESTAMP '2009-06-15 10:14:59-8:00');
これは、結果として 09/06/30 を返します。
関連トピック
詳細については、「明示的なデータ型変換における CAST」を参照してください。
NEXT_DAY
目的
day_value で指定した日付より後の、最初の曜日(date_timestamp_value)の日付を返
します。
構文
NEXT_DAY ( date_timestamp_value, day_value )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
date_timestamp_value
日付またはタイムスタンプの引数。
day_value
文字の引数。
day_value には、任意の曜日または曜日の 3 文字の略語を使用できます。
有効な値は、次のとおりです。
•
•
•
•
•
770
'SUNDAY'または'SUN'
'MONDAY'または'MON'
'TUESDAY'または'TUE'
'WEDNESDAY'または'WED'
'THURSDAY'または'THU'
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
NEXT_DAY
• 'FRIDAY'または'FRI'
• 'SATURDAY'または'SAT'
曜日は大文字と小文字が区別されません。有効な略語の後に続く文字は無視されます。
この構文要素が NULL の場合、NULL が返されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
NEXT_DAY は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡された式は、次のデータ タイプを持っている必要があります。
• date_timestamp_value = DATE または TIMESTAMP(0)
• day_value = VARCHAR
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
詳細については、<SQL 外部ルーチン プログラミング 、B035-1147>の「互換デー
タ型」を参照してください。
TIMESTAMP 値は、UTC 時間でデータベースに格納されるためタイムゾーンが欠け
ています。そのため、この関数内ではタイム スタンプ値の解釈にセッションのタイ
ムゾーンを使用します。TIMESTAMP WITH TIME ZONE 値の場合、この関数内では
タイム スタンプ値の解釈にタイムゾーン構成要素を使用します。
結果のタイプ
戻りデータ タイプは DATE です。
例
例 1: 指定した日以降の最初の火曜日の問合わせ
以下の問合わせを実行します。
SELECT NEXT_DAY(DATE '2009-12-20', 'TUESDAY');
SQL 関数、演算子、式および述部
771
第 15 章 日時および間隔の関数と式
MONTHS_BETWEEN
結果として 09/12/22 が返されます。これは、2009 年 12 月 20 日の日曜日の次に
あたる火曜日が 12/22 になるためです。
例 2: 指定した日以降の最初の金曜日の問合わせ
以下の問合わせを実行します。
SELECT NEXT_DAY(DATE '2009-12-20', 'FRIDAY');
結果として 09/12/25 が返されます。これは、2009 年 12 月 20 日の日曜日の次に
あたる金曜日が 12/25 になるためです。
例 3: 別に指定した日以降の最初の金曜日の問合わせ
以下の問合わせを実行します。
SELECT NEXT_DAY(DATE '2009-12-25', 'FRIDAY');
結果として 10/01/01 が返されます。これは、2009 年 12 月 25 日の金曜日の次に
あたる金曜日が 2010 年 1 月 1 日になるためです。
関連トピック
埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービス シ
ステム関数」を参照してください。
MONTHS_BETWEEN
目的
date_timestamp_value1 と date_timestamp_value2 の間にある月の数を返します。
構文
MONTHS_BETWEEN
( date_timestamp_value1, date_timestamp_value2 )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
date_timestamp_value1
日付またはタイムスタンプの引数。
date_timestamp_value2
日付またはタイムスタンプの引数。
data_timestamp_value2 が NULL の場合は NULL が返されます。
772
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
MONTHS_BETWEEN
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
MONTHS_BETWEEN は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡される式には、次のいずれかのデータ タイプが含まれている必要があ
ります。
DATE、TIMESTAMP、または TIMESTAMP WITH TIME ZONE
MONTHS_BETWEEN に渡す 2 つの引数は、上記の 3 つのデータ タイプのいずれで
もかまいませんが、この 2 つの引数を同じデータ タイプにする必要があります。例
えば、第 1 パラメータとして DATE、第 2 パラメータとして TIMESTAMP を渡すこ
とはできません。
TIMESTAMP 値は、UTC 時間でデータベースに格納されるためタイムゾーンが欠け
ています。そのため、この関数内ではタイム スタンプ値の解釈にセッションのタイ
ムゾーンを使用します。TIMESTAMP WITH TIME ZONE 値の場合、この関数内では
タイム スタンプ値の解釈にタイムゾーン構成要素を使用します。
date_timestamp_value2 が次の場合:
• date_timestamp_value1 以降では、結果は負になります。
• date_timestamp_value1 以前では、結果は正になります。
date_timestamp_value1 と date_timestamp_value2 が同じ日付の場合や、どちらも
が月の最終日の場合、結果は常に整数になります。それ以外の場合、
MONTHS_BETWEEN は、結果の小数部分を 1 か月を 31 日として計算し、
date_timestamp_value1 と date_timestamp_value2 の時間構成要素の差分を考えま
す。グレゴリオ暦がサポートされます。
タイムゾーンのないタイムスタンプは、ローカル タイムゾーンで比較されます。こ
のことは、2 つのタイムスタンプが同じ日にあるかどうか、または両方が月の最終
日であるかどうかを判断する場合にのみ重要になります。タイムゾーンのあるタイ
ムスタンプは、同じゾーンでの時刻になるように、比較の前に UTC に変換されます。
結果のタイプ
戻りデータ タイプは NUMBER です。
SQL 関数、演算子、式および述部
773
第 15 章 日時および間隔の関数と式
ADD_MONTHS
例
例: 2 つの日付の間の月数の問合わせ
以下の問合わせを実行します。
SELECT MONTHS_BETWEEN(DATE'1995-02-02', DATE'1995-01-01');
これは、結果として 1.03225806451612903225806451612903225806 を返しま
す。MONTHS_BETWEEN 関数は、結果の小数部分を 1 か月を 31 日として計算し、
date_timestamp_value1 と date_timestamp_value2 の時間構成要素の差分を考えま
す。
例: 1 つの日付の月数の問合わせ
以下の問合わせを実行します。
SELECT MONTHS_BETWEEN(DATE'2008-09-25', DATE'2008-09-25');
結果として 0.0 が返されます。これは、date_timestamp_value1 と
date_timestamp_value2 の両方が同じ日になるためです。
関連トピック
埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービス シ
ステム関数」を参照してください。
ADD_MONTHS
目的
整数の月数を DATE または TIMESTAMP 式に加算し、結果を正規化します。
日付の構文
ADD_MONTHS
( date_expression, integer_expression )
タイムスタンプの構文
ADD_MONTHS
(timestamp_expression, integer_expression )
構文要素
date_expression
月を追加する、次のいずれかの integer_expression:
• 単一引用符で囲まれた DATE の値
774
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
ADD_MONTHS
•
•
•
•
DATE 定数
現在のシステム日付値を指定する CURRENT_DATE キーワード
現在のシステム日付値を指定する DATE キーワード
UDT と文字または DATE タイプの間のキャストを行なう暗黙 CAST を持つ UDT
timestamp_expression
月を追加する、次のいずれかの integer_expression:
• TIMESTAMP 定数
• 現在のシステム TIMESTAMP 値を指定する CURRENT_TIMESTAMP キーワード
• UDT と文字または TIMESTAMP タイプの間のキャストを行なう暗黙 CAST を持
つ UDT
integer_expression
date_expression または timestamp_expression に追加される月の整数値。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
規則
ADD_MONTHS は以下の規則に従います。
• ADD_MONTHS のどちらかの引数が NULL の場合には、結果は NULL になります。
• 結果が‘0000-01-01’から‘9999-12-31’までの範囲にない場合は、エラーが報告さ
れます。
• ADD_MONTHS 関数の結果が有効な日付でない場合は、報告されるすべての日付
が有効になるように正規化されます。
UDT のサポート
UDT が与えられた
引数
UDT の暗黙 CAST を使って Teradata Database が暗黙のタイプ変換を
実行するために、UDT との間にキャストが必要な事前定義タイプ
date_expression
• 文字
timestamp_expressi
on
• DATE
integer_expression
数値
• Timestamp
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
ADD_MONTHS を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、
ANSI SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レ
コードの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。
SQL 関数、演算子、式および述部
775
第 15 章 日時および間隔の関数と式
ADD_MONTHS
月のスカラー算術の問題
ターゲット月の日数がソース日付の月よりも少ない場合の一貫した取り扱いは、月
の間隔に関するスカラー算術での重要な論題です。月の概念には固定的な定義がな
いからです。
日付に関するすべてのスカラー関数はグレゴリオ暦を使用します。グレゴリオ暦の
特殊性により、90 日(3 か月を表わす)を加算するとか、730 日(2 年を表わす)を加算
するといった算術演算によって一般的に期待通りの結果が得られるわけではありま
せん。詳細については、「グレゴリオ暦の規則」を参照してください。
ADD_MONTHS 関数が使用するアルゴリズムでは 、date_expression または
timestamp_expression に対して月数を加算または減算することができるので、一貫
して有効な結果を得ることができます。
Teradata SQL の ADD_MONTHS 関数または ANSI SQL:2011 の日時 間隔算術のどち
らを使うかを判断する際に、有効ではあるけれども望まない結果が戻されるか、そ
れとも結果が戻されずにエラー メッセージを受け取るかのどちらかの選択に迫られ
ます。
システム定義の関数に依存しない 3 番目の選択肢は、日付の算術に Teradata Database
定義のカレンダ ビューを使用することです。
ADD_MONTHS の正規化の動作
月の間隔の算術に対する標準的なアプローチは、適宜 MONTH および YEAR 値を増
分し、DAY のソース値を保存することです。この方法では、ターゲット月の日数が
ソース日付の DAY 値よりも小さい場合に問題になります。
例えば、'1999-01-31'というソース DATE 値に 1 MONTH を加算する場合、結果を
処理するためにどんなアプローチをとるべきでしょうか。標準的なアプローチを使
えば、結果は'1999-02-31'になりますが、2 月 31 日は有効な日付ではありません。
ADD_MONTHS の動作は、ANSI SQL:2011 準拠の演算である DATE ± INTERVAL 'n'
MONTH および TIMESTAMP ± INTERVAL 'n' MONTH の動作に相当しますが、1 つ
の重要な違いがあります。
これら 2 つのスカラー算術演算の相違点は、有効でない日付値が関数から戻される
場合のそれぞれの動作にあります。
• ANSI SQL:2011 の算術はエラーを戻します。
• ADD_MONTHS 算術は規定の調整を行ない、有効な日付を戻します。
正規化の定義
正規化プロセスについて、以下にさらに丁寧に説明します。
ソースの date_expression または timestamp_expression の DAY フィールドが、結果
のターゲット DAY フィールドよりも大きい場合、ADD_MONTHS は DD を、その月
776
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
ADD_MONTHS
の最後の日付+n に設定して、レポートされる日付またはタイムスタンプを正規化し
ます。
分かりやすくするため、date_expression を'YYYY-MM-DD'と定義します。
与えられた date_expression に対して、ADD_MONTHS の構文を次のように表現で
きます。
ADD_MONTHS('YYYY-MM-DD' , n)
n が負の数にもなりうることに留意してください。また、次に示すように、
date_expression に対して'YYYY-MM-DD'を代用して、ADD_MONTHS を ANSI SQL:
2011 の日付および間隔の形に再定義することができます。
ADD_MONTHS('YYYY-MM-DD', n) = 'YYYY-MM-DD' ± INTERVAL 'n' MONTH
この等式は 1999-09-31 のような有効でない日付でない限り真です。有効でない日
付の場合は、ANSI 式は有効でない日付例外をトラップしてエラーを戻します。
一方、ADD_MONTHS は、例外を処理して有効な日付を戻しますが、それは必ずし
も、期待された日付ではないかもしれません。ADD_MONTHS が使うアルゴリズム
は、その正規化された結果を生成し、次のような擬似コードとして表わします。
WHEN
DD > last_day_of_the_month(MM+n)
THEN SET
DD = last_day_of_the_month(MM+n)
この特性は、任意の timestamp_expression の日付部分にも当てはまります。
正規化により、うるう年に対しても有効な結果が生成されます。
ADD_MONTHS の直感的でない結果
ADD_MONTHS が行なう正規化のために、関数の結果の多くは直感的なものではな
く、逆の計算の結果は必ずしも元通りにはなりません。例えば、「例」の結果を
「例」の結果と比較してください。
これは、この関数が常に有効な日付を生成するものの、必ずしも期待通りの日付を
生成するわけではないためです。月の間隔の算術の正確さは、相対的にとらえるべ
き問題です。どんな定義も任意定義であって汎用化することはできないので、「期
待通り」と言う語は、ADD_MONTHS の動作の説明としてより良い表現であるに過
ぎません。
次の SELECT 文は、有効であり期待通りの日付を戻します。
SELECT ADD_MONTHS ('1999-08-15' , 1);
この文は 1999-09-15 を戻します。
SELECT ADD_MONTHS ('1999-09-30' , -1);
SQL 関数、演算子、式および述部
777
第 15 章 日時および間隔の関数と式
ADD_MONTHS
この文は 1999-08-30 を戻します。
次の SELECT 文は有効な日付を戻しますが、その「正確さ」は、どのように「1 か
月」を定義するかにより異なります。
SELECT ADD_MONTHS ('1999-08-31' , 1);
この文は 1999-09-30 を戻します。なぜなら、9 月には 30 日までしかなく、正規化
されていない 1999-09-31 という回答は有効な日付ではないからです。
ADD_MONTHS の要約
ADD_MONTHS は、新しい date_expression または timestamp_expression を、YEAR
および MONTH フィールドとともに戻し、正しい日付を提供するように調整します。
しかし、DAY フィールドの調整は単に有効な日付を保証するためのものであり、直
感的に期待する日付ではないかもしれません。
この動作がご使用のアプリケーションで受け入れられない場合は、ANSI SQL:2011
の日時間隔算術を代わりに使用してください。詳細については、「ANSI の間隔式」
を参照してください。
ADD_MONTHS が結果の DAY 値を変更するのは、そうしなければ有効でない
date_expression または timestamp_expression が報告されることになる場合のみに
限られます。
例
例 1: 直感的に理解できる例
これらの例は、ADD_MONTHS 関数の単純で直感的な例です。すべての結果は有効
で、期待通りのものです。
例 1: DATE 式に対して複数年の月数を問合わせる
次の文は現在の日付に 13 年を加算します。
SELECT ADD_MONTHS (CURRENT_DATE, 12*13);
例 2: 現在の日付から 6 か月後の日付を問合わせる
次の文は 6 ヶ月前の日付を戻します。
SELECT ADD_MONTHS (CURRENT_DATE, -6);
例 3: 現在の日付から 4 か月後の日付を問合わせる
次の文は現在のタイムスタンプに 4 か月を加算します。
SELECT ADD_MONTHS (CURRENT_TIMESTAMP, 4);
778
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
ADD_MONTHS
例 4: 現在の日付から 9 か月後の日付を問合わせる
次の文は 1999 年 1 月 1 日から 9 か月後のタイムスタンプを戻します。キーワード
TIMESTAMP を使用している定数形式に注意してください。
SELECT ADD_MONTHS (TIMESTAMP '1999-01-01 23:59:59', 9);
例 5: 現在の日付から 1 か月後の日付を問合わせる
次の文は 1999 年 1 月 30 日に 1 か月を加えます。
SELECT ADD_MONTHS ('1999-01-30', 1);
結果は 1999-02-28 になります。
例 2: 直感的には理解できない例
以下の例では、date_expression の DAY の値、または timestamp_expression の日付
要素が 29、30、または 31 の場合に、ADD_MONTHS 関数の結果が常に期待通りに
はならないことを例示しています。
単純にするために、すべての例で date_expression を使用しています。どのケース
でも、関数は設計どおりに動作しています。
例 1: 無効な日付を問合わせる
この例では、SELECT 文の結果は、1996 年 2 月の日付です。1996 年 2 月 31 日が
有効な日付だったとしたらそうなっていたはずですが、2 月 31 日は有効な日付で
はないので、ADD_MONTHS は答えを正規化します。
元の日付の DAY 値がターゲットの月の最後の DAY 値よりも大きかった場合には、
この結果は、ターゲットの月の最後の有効な DAY 値になります。
SELECT ADD_MONTHS ('1995-12-31', 2);
この例の結果は 1996-02-29 になります。
1996 年がうるう年だったことに注意する必要があります。間隔が 2 か月ではなく
14 か月である場合、結果は'1997-02-28'になります。
例 2: 現在の日付の前の月を問合わせる
この文は、「例」の ADD_MONTHS 関数の逆を実行します。
例の元の日付である'1999-01-30'に戻るはずと思われますが、そうはなりません。
SELECT ADD_MONTHS ('1999-02-28' , -1);
ADD_MONTHS は結果として 1999-01-28 を戻します。
関数は設計どおりに実行し、結果はエラーではありませんが、例から期待した結果
ではないでしょう。
例 3: 現在の日付から 1 か月後の日付で、28 日に終わる月を問合わせる
次の文は'1999-03-31'を戻すものと期待されますが、そうなりません。
SELECT ADD_MONTHS ('1999-02-28' , 1);
ADD_MONTHS は結果として 1999-03-28 を戻します。
SQL 関数、演算子、式および述部
779
第 15 章 日時および間隔の関数と式
OADD_MONTHS
例 4: 現在の日付から 1 か月後の日付で、30 日に終わる月を問合わせる
次の文は'1999-03-31'を戻すものと期待されますが、そうなりません。
SELECT ADD_MONTHS ('1999-04-30' , -1);
ADD_MONTHS は結果として 1999-03-30 を戻します。
例 5: 現在の日付から 1 か月後の日付で、30 日に終わる月を問合わせる
次の文から'1999-05-31'が返されるものと考えられますが、結果は異なります。
SELECT ADD_MONTHS ('1999-04-30' , 1);
ADD_MONTHS は結果として 1999-05-30 を戻します。
関連トピック
詳細は、以下を参照してください。
• この動作の例については、「例 2: 直感的には理解できない例」に示す一連の例を
参照してください。
• 詳細については、<データ ディクショナリ 、B035-1092>の「CALENDAR ビュー」
を参照してください。
• UDT の暗黙的な型の変換の詳細については、「暗黙的な型の変換」を参照してく
ださい。
• 詳細については、<ユーティリティ 、B035-1102>を参照してください。
OADD_MONTHS
目的
指定された date_timestamp_value を指定された num_months に追加し、結果の日
付を返します。
構文
OADD_MONTHS
( date_timestamp_value, num_months )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
date_timestamp_value
日付またはタイムスタンプの引数。
780
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
OADD_MONTHS
この構文要素が NULL の場合、NULL が返されます。
num_months
数値式。
この構文要素が NULL の場合、NULL が返されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
OADD_MONTHS は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡された式は、次のデータ タイプを持っている必要があります。
• date_timestamp_value = DATE、TIMESTAMP、または TIMESTAMP WITH TIME
ZONE
• num_months = INTEGER
num_months 引数では、UDF に適用される暗黙のデータ型変換規則を使用して
INTEGER に変換できるデータ型の値も渡すことができます。date_timestamp_value
引数については、暗黙の型変換はサポートされていません。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
詳細については、<SQL 外部ルーチン プログラミング 、B035-1147>の「互換デー
タ型」を参照してください。
TIMESTAMP 値は、UTC 時間でデータベースに格納されるためタイムゾーンが欠け
ています。そのため、この関数内ではタイム スタンプ値の解釈にセッションのタイ
ムゾーンを使用します。TIMESTAMP WITH TIME ZONE 値の場合、この関数内では
タイム スタンプ値の解釈にタイムゾーン構成要素を使用します。
date_timestamp_value の日付構成要素がその月の最終日の場合や、結果の月が
date_timestamp_value の日付構成要素よりも少ない日数になる場合、
OADD_MONTHS は結果としての月の最終日を返します。それ以外の場合、
OADD_MONTHS は date_timestamp_value として同じ日付構成要素を持つ値を返し
ます。
OADD_MONTHS と ADD_MONTHS の相違点は、OADD_MONTHS で月の最終日に月
を追加すると、この関数が常に月の最終日を返すことです。次の問合わせは、
ADD_MONTHS と OADD_MONTHS の相違点を説明するものです。
• 問合わせ
SQL 関数、演算子、式および述部
781
第 15 章 日時および間隔の関数と式
OADD_MONTHS
SELECT ADD_MONTHS ('2008-02-29', 1);
は'08/03/29'を返します。
• 問合わせ
SELECT OADD_MONTHS ('2008-02-29', 1);
は'08/03/31'を返します。
結果のタイプ
OADD_MONTHS は戻りデータ タイプが DATE のスカラー関数です。
例
例: 指定した日に 1 か月追加する
以下の問合わせを実行します。
SELECT OADD_MONTHS (DATE '2008-02-15', 1);
これは、結果として 08/03/15 を返します。
例: 指定した日に 2 か月追加する
以下の問合わせを実行します。
SELECT OADD_MONTHS (DATE '2008-02-20', 2);
これは、結果として 08/04/20 を返します。
例 3: 月が 29 日に終わる場合、指定した日に 1 か月追加する
以下の問合わせを実行します。
SELECT OADD_MONTHS (DATE '2008-02-29', 1);
これは、結果として 08/03/31 を返します。
29 日は 2 月の最終日になるため、3 月 31 日が返されます。これは、31 日が 3 月の
最終日になるためです。
関連トピック
埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービス シ
ステム関数」を参照してください。
782
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
TRUNC(Date)
TRUNC(Date)
目的
fmt で指定した単位になるように日付の時間部分を切り捨てた date_value を返しま
す。
構文
TRUNC
( date_value
TD_SYSFNLIB.
)
, fmt
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
date_value
数値またはタイムスタンプの引数。
fmt
文字式。
この構文要素が NULL の場合、NULL が返されます。
fmt が省略されると、date_value は最近接の日付になるように切り捨てられます。
日曜日が週の最初の曜日と見なされます。ISO 年の場合、月曜日が最初の曜日と見
なされます。
この構文要素が無効な場合、エラーが返されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
TRUNC(DATE)は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡される式には、次のいずれかのデータ タイプが含まれている必要があ
ります。
• date_value = DATE、TIMESTAMP、または TIMESTAMP WITH TIME ZONE
• fmt = VARCHAR CHARACTER SET LATIN
SQL 関数、演算子、式および述部
783
第 15 章 日時および間隔の関数と式
TRUNC(Date)
fmt 引数では、UDF に適用される暗黙のデータ型変換規則を使用して VARCHAR に
変換できるデータ型の値も渡すことができます。date_value 引数については、暗黙
の型変換はサポートされていません。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
TRUNC の日付書式
784
構成要素
説明
CC
SCC
4 桁表現の年の最初の 2 桁が 1 だけ大きくな
る年
SYYY
YYYY
YEAR
SYEAR
YYY
YY
Y
年(7 月 1 日で切り上げ)
IYYY
IYY
IY
I
ISO 年
MONTH
MON
MM
RM
月(16 日目で切り上げ)
Q
四半期(その四半期の 2 番目の月の 16 日目で
切り上げ)
WW
年の最初の日と同じ曜日
IW
ISO 年の最初の日と同じ曜日
W
月の最初の日と同じ曜日
DDD
DD
J
日
DAY
DY
D
最初の曜日
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
ROUND(Date)
構成要素
説明
HH
HH12
HH24
時間
MI
分
結果のタイプ
TRUNC は戻りデータ タイプが DATE のスカラー関数です。
例
例: 週の最初の曜日の日付値を返す
以下の問合わせを実行します。
SELECT TRUNC(CAST('2003/09/17' AS DATE), 'D') (FORMAT 'yyyy-mm-dd');
結果 2003-09-14 を戻します。日付がその週の最初の曜日になるように切り捨てら
れます。
例: 月の最初の日の日付値を返す
以下の問合わせを実行します。
SELECT TRUNC(CAST('2003/09/17' AS DATE), 'RM') (FORMAT 'yyyy-mm-dd');
結果 2003-09-01 を戻します。日付が月の最初になるように切り捨てられます。
関連トピック
詳細は、以下を参照してください。
• 詳細については、<SQL 外部ルーチン プログラミング、B035-1147>の「互換デー
タ型」を参照してください。
• 埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービ
ス システム関数 」を参照してください。
ROUND(Date)
目的
fmt で指定した単位になるように日付の時間部分を丸めた date_value を返します。
SQL 関数、演算子、式および述部
785
第 15 章 日時および間隔の関数と式
ROUND(Date)
構文
ROUND
( date_value
TD_SYSFNLIB.
)
, fmt
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
date_value
数値またはタイムスタンプの引数。
fmt
文字式。
この構文要素が NULL の場合、NULL が返されます。
fmt が省略されると、 date_value は最近接の日付になるように丸められます。日曜
日が週の最初の曜日と見なされます。ISO 年の場合、月曜日が最初の曜日と見なさ
れます。
この構文要素が無効な場合、エラーが返されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
ROUND(Date)は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡される式には、次のいずれかのデータ タイプが含まれている必要があ
ります。
• date_value = DATE、TIMESTAMP、または TIMESTAMP WITH TIME ZONE
• fmt = VARCHAR CHARACTER SET LATIN
fmt 引数では、UDF に適用される暗黙のデータ型変換規則を使用して VARCHAR に
変換できるデータ型の値も渡すことができます。date_value 引数については、暗黙
の型変換はサポートされていません。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
786
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
EXTRACT
結果のタイプ
ROUND は戻りデータ タイプが DATE のスカラー関数です。
例
例: 日付を週最初の曜日に丸める
以下の問合わせを実行します。
SELECT ROUND(CAST('2003/09/17' AS DATE), 'D') (FORMAT 'yyyy-mm-dd');
結果 2003-09-14 を戻します。日付がその週の最初の曜日になるように丸められます。
例: 日付を翌月最初の日に丸める
以下の問合わせを実行します。
SELECT ROUND(CAST('2003/09/17' AS DATE), 'RM') (FORMAT 'yyyy-mm-dd');
結果 2003-10-01 を戻します。日付が 16 以上になるため、この日付は次の月の最
初に丸められます。
関連トピック
詳細は、以下を参照してください。
• 詳細については、<SQL 外部ルーチン プログラミング、B035-1147>の「互換デー
タ型」を参照してください。
• ROUND(日付)の日付フォーマットについては、「TRUNC(日付)」を参照してくだ
さい。
• 埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービ
ス システム関数 」を参照してください。
EXTRACT
目的
日時または間隔値から指定のフル ANSI SQL:2011 フィールドを 1 つ抽出し、正確
な数値に変換します。
SQL 関数、演算子、式および述部
787
第 15 章 日時および間隔の関数と式
EXTRACT
構文
EXTRACT
(
YEAR
FROM
value )
MONTH
DAY
HOUR
MINUTE
SECOND
TIMEZONE_HOUR
TIMEZONE_MINUTE
構文要素
YEAR
YEAR の整数値は、value で示された日付から抽出されます。
MONTH
MONTH の整数値は、value で示された日付から抽出されます。
DAY
DAY の整数値は、value で示された日付から抽出されます。
HOUR
HOUR の整数値は、value で示された日付から抽出されます。
MINUTE
MINUTE の整数値は、value で示された日付から抽出されます。
TIMEZONE_HOUR
TIMEZONE_HOUR の整数値は、value で示された日付から抽出されます。
TIMEZONE_MINUTE
TIMEZONE_MINUTE の整数値は、value で示された日付から抽出されます。
SECOND
SECOND の整数値は、value で示された日付から抽出されます。返される値のデータ
型は、DECIMAL(8,2)です。
value
結果が DateTime、Interval、または UDT 値になる式。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠していますが、非 ANSI の Teradata Database 拡張
機能が含まれています。
788
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
EXTRACT
ANSI SQL:2011 EXTRACT では、日時または間隔の値に含まれるすべてのフィール
ドを抽出できます。ANSI SQL:2011 EXTRACT 関数に加えて、Teradata SQL では浮
動小数点値から抽出した HOUR、MINUTE、または SECOND もサポートしています。
引数
value が次の場合:
結果
日付を表わす文字列式
'YYYY-MM-DD' 形式に合致する列。
時間を表わす文字列式
'HH:MI:SS.SSSSSS' 形式に合致する列。
浮動小数点タイプ
value は HOUR * 10000 + MINUTE * 100 + SECOND というア
ルゴリズムでエンコードされた時間値でなければなりません。
浮動小数点値から抽出できるのは、HOUR、MINUTE、および
SECOND だけです。
外部的に作成された時間値は、適切にエンコードされ、REAL
列に格納されます。そしてその時間値は、エンコーディング
によって精度を低下させずに REAL で表現可能な値が作成さ
れていれば、希望する精度で格納されます。
時間値を REAL として新しいアプリケーションに格納しない
でください。その代わりに、より厳密に定義された ANSI SQL:
2011 日時データ タイプを使用してください。
UDT
UDT と以下のいずれかの事前定義タイプの間でキャストを行
なう暗黙 CAST が UDT になければなりません。
• 数値
• 文字
• 日時
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用
し、AS ASSIGNMENT 節を指定します。CREATE CAST の詳細
は、<SQL データ定義言語 - 構文規則および例、B035-1144>
を参照してください。
EXTRACT を含め、システム演算子および関数用の UDT の暗
黙の型変換は、ANSI SQL 規格の Teradata 拡張機能です。こ
の拡張を無効にするには、DBS 制御レコードの
DisableUDTImplCastForSysFuncOp フィールドを TRUE に設
定します。詳細は、<ユーティリティ 、B035-1102>を参照し
てください。
UDT の暗黙的な型の変換の詳細については、「暗黙的な型の
変換」を参照してください。
SQL 関数、演算子、式および述部
789
第 15 章 日時および間隔の関数と式
EXTRACT
value が次の場合:
結果
文字列式または浮動小数点 式は日時または間隔タイプに評価されなければなりません。
タイプまたは UDT ではない
場合
結果
EXTRACT は、ANSI SQL:2011 日時値の正確な数値を戻します。
引数のデータ タイプが TIME または TIMESTAMP の場合、EXTRACT は、適切なタ
イムゾーンに調整された値を返します。
引数にタイムゾーンが指定されない場合は、現在のセッションのタイムゾーンに基
づくタイムゾーン変位が使用されます。それ以外の場合は、引数の明示的なタイム
ゾーンが使用されます。AT 句を使用すると、タイムゾーンに引数を、明示的に指定
できます。詳細については、ANSI の日時式を参照してください。
SECOND を抽出する場合、value に含まれる秒の小数点以下桁数がゼロであると、結
果は INTEGER になります。value に含まれる秒の小数点以下桁数がゼロよりも大き
いと、結果は DECIMAL になり、その位取りはデータ記述の SECOND フィールドで
の指定に従います。
それ以外のものを抽出した場合、結果は精度が 32 ビットの INTEGER になります。
抽出の対象
結果
SECOND
value に含まれる秒の小数点以下桁数:
• ゼロである場合、結果は INTEGER になります。
• ゼロよりも大きい場合、結果は DECIMAL になり、その位取りはデー
タ記述の SECOND フィールドでの指定に従います。
その他
結果は、精度が 32 ビットの INTEGER。
value が NULL の場合、結果は NULL になります。
例
例 1: 現在の日付から年を返す
次の例は、現在の日付から年を整数として戻します。
SELECT EXTRACT (YEAR FROM CURRENT_DATE);
例 2: 購入日に 90 日を追加する
PurchaseDate が DATE フィールドであると想定すると、この例は、整数の
PurchaseDate に 90 日を加算することによって形成される 日付値の月を戻します。
SELECT EXTRACT (MONTH FROM PurchaseDate+90) FROM SalesTable;
790
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
GetTimeZoneDisplacement
例 3: 整数を返す
次の例は、整数の 12 を戻します。
SELECT EXTRACT (DAY FROM '1996-12-12');
例 4: 文字リテラルの結果が有効な日付にならない場合
この例では、文字定数が有効な日付に評価されないため、エラーが戻されます。
SELECT EXTRACT (DAY FROM '1996-02-30');
例 5: 文字列リテラルが ANSI SQL:2011 の日付形式に一致しない場合
以下の例では、文字列定数が ANSI SQL:2011 の日付形式に合致しないため、エラー
が戻されます。
SELECT EXTRACT (DAY FROM '96-02-15');
EXTRACT への引数が DATE タイプの値の場合、含まれる値は確実に有効な日付とな
り、EXTRACT はエラーを戻すことができません。
例 6: 非 ANSI DateTime の定義
次の例は、非 ANSI 日時定義に関連しています。引数が時間値として書式化された
文字定数の場合には、この引数は REAL に変換されて処理されます。この例では、
59 が戻されます。
SELECT EXTRACT (MINUTE FROM '23:59:17.3');
例 7: 現在の時刻から時間を返す
この例は、現在時刻から時間値を整数として戻します。
SELECT EXTRACT (HOUR FROM CURRENT_TIME);
現在時刻は、指示された精度でシステム値 TIME として検索されます。
例 8: 秒を DECIMAL として返す
次の例では、DECIMAL(8,2)の形で秒が戻されます。これは、CURRENT_TIME の秒
の小数点以下の桁数 2 に基づいています。
SELECT EXTRACT (SECOND FROM CURRENT_TIME (2));
GetTimeZoneDisplacement
目的
指定したタイムゾーン文字列の規則とタイムゾーン変位情報を返します。
構文
GetTimeZoneDisplacement
SQL 関数、演算子、式および述部
(time_zone_string)
791
第 15 章 日時および間隔の関数と式
GetTimeZoneDisplacement
構文要素
time_zone_string
VARBYTE データ型を使用して指定した、有効なタイムゾーン文字列。Teradata でサ
ポートされるタイムゾーン文字列のリストは、AT LOCAL および AT TIME ZONE タ
イムゾーン指定子を参照してください。
time_zone_string が有効でない、あるいはサポートされていない場合、
GetTimeZoneDisplacement は先頭バイトに値 1 を返して、タイムゾーン文字列が存
在しないことを示します。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果
GetTimeZoneDisplacement は、指定したタイムゾーン文字列の規則とタイムゾーン
変位情報を格納する BYTE の列を返します。結果のデータ タイプは BYTE です。返
される情報は、次のとおりです。
バイト
値
先頭バイト
• タイムゾーン文字列が見つからない場合は、1。これは、入力引数で指
定されたタイムゾーン文字列が有効でないか、サポートされていないこ
とを意味します。
• タイムゾーン文字列が見つかった場合は、0。
第 2 バイト
• タイムゾーン文字列に、独自の夏時間と、協定世界時(UTC 時間)からの
標準タイムゾーン変位情報が含まれている場合は、1。
この場合、後続の約 480 バイトには、有効な標準タイムゾーン変位、
夏時間のタイムゾーン変位、および夏時間の開始時期と終了時期を記述
する規則一式が格納されています。各タイムゾーン文字列に格納される
規則の数は、最大で 6 つです。
• タイムゾーン文字列に、独自の夏時間と、UTC 時間からの標準タイム
ゾーン変位情報が含まれていない場合は、0。
この場合、後続の 4 バイトには、タイムゾーン変位の時間および分の情
報が格納されています。
使用上の注意
GetTimeZoneDisplacement は、システム ユーザー定義関数(UDF)です。Teradata
Database は、この UDF を内部的に呼び出して、SQL 文やデータ形式指定(SDF)ファ
イルで指定されたタイムゾーン文字列を解決します。この関数を直接呼び出しては
いけません。ただし、新しいタイムゾーン文字列を追加する場合や、既存のタイム
792
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
GetTimeZoneDisplacement
ゾーン文字列の規則を追加または変更する場合には、この UDF に変更を加えてもか
まいません。
タイムゾーン文字列の使用に関する制限
Teradata Database システム標準のタイムゾーン文字列を使用する場合 、1986 年以
前の年には、夏時間(DST)へのシフトなどのタイムゾーンの規則が適用されません。
Teradata Database 標準タイムゾーン文字列の有効な年は、1987 年から 9999 年ま
でです。
Teradata Database 標準のタイムゾーン文字列では要件を満たせないときには、新た
にカスタマイズしたタイムゾーン文字列を追加するか 、既存の文字列に変更を加え
てください。そのためには、GetTimeZoneDisplacement に変更を加えるか、新しい
規則を追加することになります。
注: DST に準拠したロケールのタイムゾーン文字列を使用したものの、タイムゾー
ン オフセット値が時間値に含まれない場合、Teradata Database はあいまいな時間
内の時間値を DST として解釈して処理するべきか、または標準時間として解釈して
処理するべきかを判別できません。このような場合、DisplacementOnOverlap の
DBS 制御設定値によって、Teradata Database がこれらの時間を DST タイムゾーン
オフセットと見なすか、標準タイムゾーン オフセットと見なすかが決定されます。
この問題が発生するのは、DST ロケールにタイムゾーン文字列を使用するとき、時
間値にタイムゾーン オフセット値が含まれていないとき、および
TimeDateWZControl の DBS 制御設定が 3 に設定されているとき(タイムゾーン オフ
セット情報のない日付と時刻値は、システム ローカル タイムを使用して格納され
ます)に限られます。
DisplacementOnOverlap TimeDateWZControl の詳細については、<ユーティリティ、
B035-1102>の DBS 制御に関する章を参照してください。
タイムゾーン文字列の追加または修正
Teradata Database には、一般的に使用できるタイムゾーンを表現する、タイムゾー
ン文字列一式が用意されています。サポートされているタイムゾーン文字列のリス
トについては、「AT LOCAL および AT TIME ZONE タイムゾーン指定子」を参照し
てください。GetTimeZoneDisplacement UDF は、UTC とローカル タイムゾーン間
の変換を実行するために、上記のタイムゾーン文字列と、それらに関連する規則を
格納して保守します。
用意されているタイムゾーン文字列では要件が満たされない場合には、SYSLIB デー
タベースに格納されている GetTimeZoneDisplacement UDF に変更を加えて、タイ
ムゾーン文字列を追加または変更してください。UDF のソース コードは、DBS パッ
ケージの一部として入手できます。このソース コードは、/tdbms/etc/dem/src に
格納されています。
新しいタイムゾーン文字列を定義する場合や、既存のタイムゾーン文字列を追加ま
たは変更する場合には、次の手順を実行します。
SQL 関数、演算子、式および述部
793
第 15 章 日時および間隔の関数と式
GetTimeZoneDisplacement
1 既存の GetTimeZoneDisplacement UDF のバックアップ コピーを作成します。
#
#
#
#
cd /home
mkdir workdir
cd workdir
cp /tdbms/etc/dem/src/udfgettimezonedisplacement.c .
2 既存のタイムゾーン文字列を修正するには、次の手順を実行します。
注: tdlocaledef_tzrules.txt に提供されている既存のタイムゾーン設定のルール変
更については、Teradata カスタマー サポート サービスにお問合わせください。
# cd /opt/teradata/tdat/tdbms/xx.xx.xx.xx/etc
# vi tdlocaledef_tzrules.txt
TimeZoneString {"America Eastern"; "-5"; "0"; "2";
"4"; "4"; "1"; "0"; "0"; "02:00:00";
"3"; "10"; "0"; "0"; "-1"; "02:00:00";
"1987"; "2006"; "-5"; "0"; "-4"; "0";
"4"; "3"; "8"; "0"; "0"; "02:00:00";
"4"; "11"; "1"; "0"; "0"; "02:00:00";
"2007"; "9999"; "-5"; "0"; "-4"; "0"}
a GetTimeZoneDisplacement UDF の TZ_DST 構造体の中から、タイムゾーン文
字列のエントリを見つけます。例:
{"America Eastern", 2,
{{{4, 4, 1, 0, 0, "02:00:00"},
{3, 10, 0, 0, -1, "02:00:00"},
{1987, 2006, -5, 0, -4, 0}},
{{4, 3, 8, 0, 0, "02:00:00"},
{4, 11, 1, 0, 0, "02:00:00"},
{2007, 9999, -5, 0, -4, 0}},
{{0, 0, 0, 0, 0, "00:00:00"},
{0, 0, 0, 0, 0, "00:00:00"},
{0, 0, 0, 0, 0, 0}},
{{0, 0, 0, 0, 0, "00:00:00"},
{0, 0, 0, 0, 0, "00:00:00"},
{0, 0, 0, 0, 0, 0}},
{{0, 0, 0, 0, 0, "00:00:00"},
{0, 0, 0, 0, 0, "00:00:00"},
{0, 0, 0, 0, 0, 0}},
{{0, 0, 0, 0, 0, "00:00:00"},
{0, 0, 0, 0, 0, "00:00:00"},
{0, 0, 0, 0, 0, 0}}
},
794
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
GetTimeZoneDisplacement
-5, 0
},
注: tdlocaledef_tzrules.txt および udfgettimezonedisplacement.c のタイムゾー
ン文字列に基づくルールは、異なるフォーマットでリストされます。
tdlocaledef を実行してシステムにタイムゾーン文字列を設定するには 、
tdlocaledef_tzrules.txt のフォーマットが使用されます。
b このタイムゾーン文字列のエントリに関連付けられた規則と情報に変更を加
えるか、そのエントリに新しい規則を追加します。
3 新しいタイムゾーン文字列を追加するには、次の手順を実行します。
a 新しいタイムゾーン文字列とそれに関連する規則を追加するために、TZ_DST
構造体の中に新しいエントリを作成します。
注: tdlocaledef_tzrules.txt および udfgettimezonedisplacement.c のタイムゾー
ン文字列に基づくルールは、異なるフォーマットでリストされます。
tdlocaledef を実行してシステムにタイムゾーン文字列を設定するには 、
tdlocaledef_tzrules.txt のフォーマットが使用されます。
b 新しいタイムゾーン文字列のエントリを、TZ_DST 構造体内でのアルファベッ
ト順が保たれる位置に配置します。
c udfgettimezonedisplacement.c の MAX_DST_ENTRIES は、既存のタイムゾー
ン文字列に一致する必要があります。新しいタイムゾーン文字列を 1 つ追加
すると、1 つ増えます。
4 REPLACE FUNCTION 文を使用して、この UDF を再コンパイルします。詳細は、
<SQL データ定義言語 - 構文規則および例、B035-1144>の「CREATE
FUNCTION(外部形式)/REPLACE FUNCTION(外部形式)」を参照してください。
注: 必ず DBC としてログインし、他のユーザーにはログオンさせないでください。
例:
Database SYSLIB;
DROP FUNCTION GetTimeZoneDisplacement;
REPLACE FUNCTION GetTimeZoneDisplacement
(tzstringinfo VARBYTE(130))
RETURNS BYTE(340)
LANGUAGE C
NO SQL
PARAMETER STYLE SQL
EXTERNAL NAME 'CS!GetTimeZoneDisplacement!/home/workdir/
udfgettimezonedisplacement.c' ;
5 新しいタイムゾーン文字列をテストします。
.os date
.os date -u
SQL 関数、演算子、式および述部
795
第 15 章 日時および間隔の関数と式
GetTimeZoneDisplacement
SELECT CURRENT_TIMESTAMP AS SYSTEMTIME,
CURRENT_TIMESTAMP AT 'new_time_zone_string';
TZ_DST 構造体
TZ_DST 構造体は、TZwithDST 構成要素の配列です。これらの各構成要素では、タ
イムゾーン文字列とそれに関連する規則を記述します。TZwithDST 構造体の定義は、
次のとおりです。
typedef struct TZwithDST
{
CHARACTER_LATIN tzstring[TZSTRINGSIZE];
int
number_of_rules;
DSTRules
TZRules[TZRulesEntries];
SMALLINT
Standardtzdispl_hour;
SMALLINT
Standardtzdispl_minute;
} TZwithDST;
説明:
フィールド
説明
tzstring
タイムゾーン文字列の名前。たとえば、"America Pacific"。
タイムゾーン文字列の最大長は 130 バイトです。
number_of_rules
このタイムゾーン文字列に関連する規則の数。各タイムゾー
ン文字列には、最大 6 つの規則が許可されています。
TZRules
規則を記述する各 DSTRules 構成要素の配列です。これらの
規則は、タイムゾーン文字列のタイムゾーン変位を計算する
ために使用されます。
Standardtzdispl_hour
標準タイムゾーン変位の時間です。
Standardtzdispl_minute
標準タイムゾーン変位の分です。
TZRules 配列の各 DSTRules 構成要素では、タイムゾーン文字列の規則を記述しま
す。DSTRules 構造体の定義を示します。
typedef struct DSTRules
{
startendDSTInfo startDST;
startendDSTInfo endDST;
yearDisplInfo
validyrs;
} DSTRules;
説明:
796
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
GetTimeZoneDisplacement
フィールド
説明
startDST
夏時間(DST)を開始する日付と時間を指定します。
endDST
夏時間(DST)を終了する日付と時間を指定します。
validyrs
DST の開始日と終了日を適用する年を指定します。この年範囲に関連する
情報には、以下の項目があります。
• start_year - この DST 規則を開始する年。
• end_year - この DST 規則を終了する年。
• Standardtzdispl_hour - 標準タイムゾーン変位の時間。
• Standardtzdispl_minute - 標準タイムゾーン変位の分。
• DSTtzdispl_hour - 夏時間用のタイムゾーン変位の時間。
• DSTtzdispl_minute - 夏時間用のタイムゾーン変位の分。
startDST と endDST には、以下の項目を設定できます。該当しないフィールドに
は、0 を入力してください。
フィールド
rule_type
説明
DST の開始日と終了日の指定方法を示します。有効な値は次のとおりです。
• 0 - DST の開始または終了情報は指定されていない。標準タイムゾーン
変位が使用されます。
• 1 - DST は特定の固定日に開始または終了する。この日付は、month
および day_of_month フィールドで指定します。
• 2 - DST は、month、day_of_week および week_of_month フィールド
で示される、月の第 1 週、第 2 週または第 3 週に開始または終了する。
• 3 - DST は、month、day_of_week および week_of_month フィールド
で示される、月の最後の週日の 2 週前の週日、3 週前の週日、月の最
後の週日に開始または終了する。
• 4 - DST は、day_of_month フィールドで指定された日付の次の週日ま
たは直後の日に、開始または終了する。月と週日は month および
day_of_week フィールドで指定します。
たとえば、タイムゾーン文字列 が'America Pacific'の場合、開始日の
規則は 3 月 8 日より後の最初の日曜日になります。2010 年の場合な
らば、3 月 14 日になります。
month
DST を開始または終了する月。有効な値は 0~12 です。このフィールド
は、rule_type 1、2、3 および 4 で使用します。
たとえば、タイムゾーン文字列'America Pacific'の場合、開始日の規則は
3 月 8 日の後の最初の日曜日なので、startDST 構造体のこのフィールド
の値は、3 月を表現する 3 になります。
SQL 関数、演算子、式および述部
797
第 15 章 日時および間隔の関数と式
GetTimeZoneDisplacement
フィールド
説明
day_of_month
rule_type が 1 の場合、このフィールドには DST を開始または終了する月
の日付を指定します。例えば、DST が、ローカル タイムで 8 月 21 日の
午前 12:00 に終了する場合、endDST 構造体のこのフィールドには値 21
が格納されます。
rule_type が 4 の場合、このフィールドで指定した日付の次の週日または
直後の日に、DST を開始または終了します。たとえば、タイムゾーン文
字列'America Pacific'の場合、開始日の規則は 3 月 8 日の後の最初の日曜
日なので、startDST 構造体のこのフィールドには値 8 が格納されます。
rule_type が 0、2 または 3 の場合、このフィールドは使用されず、値は
0 になります。
day_of_week
有効な値は 0~7 です。それぞれで日曜日から土曜日を表わします。この
フィールドは、rule_type 2、3 および 4 で使用します。
たとえば、タイムゾーン文字列'America Pacific'の場合、開始日の規則は
3 月 8 日の後の最初の日曜日なので、startDST 構造体のこのフィールド
の値は、日曜日を表現する 0 になります。
week_of_month 有効な値は、1、2、3、4、5、-1 および-2 です。それぞれ、最初の週日、
2 番目の週日、3 番目の週日、4 番目の週日、5 番目の週日、最後の週
日、および最後から 2 つ前の週日を表現しています。このフィールドは、
rule_type 2 および 3 で使用します。
たとえば、タイムゾーン文字列'Europe Azores'の場合、開始日の規則は、
3 月の最終日曜日になるので、startDST 構造体のこのフィールドの値は、
月の最後の週を表現する-1 になります。
loctime
DST を開始または終了するローカル タイムです。
たとえば、"02:00:00"は、ローカル タイムの午前 2:00 に DST を開始ま
たは終了すること示します。
例: 新しいタイムゾーン文字列の追加
たとえば、1 つの規則と以下のタイムゾーン変位情報を含む、新しいタイムゾーン
文字列'Europe Azores'を追加すると仮定します。
•
•
•
•
•
•
3 月の最終日曜日、ローカル タイムの午前 12:00 に DTS を開始する。
10 月の最終日曜日、ローカル タイムの午前 1:00 に DTS を開始する。
標準タイムゾーンの UTC からのオフセットは、-1 時間。
夏時間の UTC からのオフセットは、0 時間。
この規則の開始年は、2009 年。
この規則の終了年は、2010 年。
この情報を基にすると、新しいタイムゾーン文字列'Europe Azores'のエントリは、
次のようになります。
798
SQL 関数、演算子、式および述部
第 15 章 日時および間隔の関数と式
GetTimeZoneDisplacement
{"Europe Azores", 1,
'Europe Azores'
{{{3, 3, 0, 0, -1, "00:00:00"},
startDST information
{3, 10, 0, 0, -1, "01:00:00"},
{2009, 2010, -1, 0, 0, 0}},
{{0, 0, 0, 0, 0, "00:00:00"},
{0, 0, 0, 0, 0, "00:00:00"},
{0, 0, 0, 0, 0, 0}},
{{0, 0, 0, 0, 0, "00:00:00"},
{0, 0, 0, 0, 0, "00:00:00"},
{0, 0, 0, 0, 0, 0}},
{{0, 0, 0, 0, 0, "00:00:00"},
{0, 0, 0, 0, 0, "00:00:00"},
{0, 0, 0, 0, 0, 0}},
{{0, 0, 0, 0, 0, "00:00:00"},
{0, 0, 0, 0, 0, "00:00:00"},
{0, 0, 0, 0, 0, 0}},
{{0, 0, 0, 0, 0, "00:00:00"},
{0, 0, 0, 0, 0, "00:00:00"},
{0, 0, 0, 0, 0, 0}}
},
-1, 0
displacement
},
<= 1 rule defined for
<= Start of rule 1,
<= endDST information
<= validyrs information
<= Start of rule 2
<= Start of rule 3
<= Start of rule 4
<= Start of rule 5
<= Start of rule 6
<= Standard time zone
タイムゾーン文字列のエントリには、6 つ分の規則のスペースがありますが、この
例では、開始年の 2009 年と終了年の 2010 年用に 1 つの規則を使用しているだけ
です。
新しい'Europe Azores'タイムゾーン文字列は、構造体のアルファベット順が保たれ
るように、TZ_DST 構造体内の'Australia Western'と'Europe Central'タイムゾーン文
字列の間に配置する必要があります。
関連トピック
詳細情報
参照先
セッションのタイムゾーンの設定につ
いて
<SQL データ定義言語 - 構文規則および例、
B035-1144>の「SET TIME ZONE」、「CREATE
USER」、「MODIFY USER」。
システムのタイムゾーンの設定につ
いて
<ユーティリティ>の「System TimeZone Hour」お
よび「System TimeZone Minute」。
SQL 関数、演算子、式および述部
799
第 15 章 日時および間隔の関数と式
GetTimeZoneDisplacement
詳細情報
参照先
夏時間を考慮に入れたシステム時間の <ユーティリティ >の「SDF ファイル」および
自動調整
「Teradata Locale Definition ユーティリティ
(tdlocaledef)」。
800
SQL 関数、演算子、式および述部
第 16 章
エクスポート幅プロシージャ
概要
この章では、次の用途に使用するストアド プロシージャについて説明します。
• 新しいユーザー定義のエクスポート幅定義の作成
• 既存のユーザー定義のエクスポート幅定義の変更
• ユーザー定義のエクスポート幅定義の削除
エクスポート幅について
エクスポート幅を適切に設定していないと、Teradata Database がエクスポートする
文字数やバイト数が、それを受信するクライアント アプリケーションが期待する文
字数やバイト数を超過することや、期待する文字数やバイト数に満たないことがあ
ります。エクスポート幅は、システムが Teradata クライアントに返す結果セット行
の各文字フィールドに、どれだけ領域を予約するかを定義します。
DBS 制御フィールドのエクスポート幅テーブル ID を設定すると、クライアントに
結果セットを返す際にシステムが使用する 、デフォルトのエスポート幅を定義でき
ます。詳細は、<ユーティリティ 、B035-1102>の「DBS 制御(dbscontrol)」を参照
してください。
CREATE USER 文または MODIFY USER 文で EXPORTWIDTH オプションを使用し
て、システムレベルのエクスポート幅を上書きできます 。EXPORTWIDTH オプショ
ンは、次の値を受け入れます。
エクスポート定義名
説明
'Expected'
文字データ タイプとクライアント使用形式に対して妥当なデフォ
ルトの幅を提供します。
'Compatibility'
Latin または KANJI1 のデータを処理するために記述されるアプ
リケーションによる処理を行なうために、Unicode データを有効
にします。
'Maximum'
文字データ タイプとクライアント使用形式に対して最大のデフォ
ルト幅を提供します。
'user-defined name '
文字データ タイプとクライアント使用形式に対して、ユーザー
定義のデフォルトの幅を提供します。
SQL 関数、演算子、式および述部
801
第 16 章 エクスポート幅プロシージャ
エクスポート幅について
エクスポート定義名
説明
DEFAULT
DBS 制御フィールド「エクスポート幅テーブル ID」の設定を使
用します。
次の用途に ReplaceExportDefinition ストアド プロシージャを使用できます。
• 新しいユーザー定義のエクスポート定義名と、それに関連付けられたエクスポー
ト幅ルールの作成。
• 既存のユーザー定義のエクスポート定義名に関連付けられた、エクスポート幅
ルールの更新。
RemoveExportDefinition ストアド プロシージャを使用すると、ユーザー定義のエク
スポート定義名と、それに関連付けられたエクスポート幅ルールを削除できます。
関連情報
参照先
エクスポート幅と、ユーザー定義のエクス
ポート幅定義の作成
<国際文字セットのサポート、B035-1125>。
ユーザー レベルのエクスポート幅設定の指定 <SQL データ定義言語 - 構文規則および例、
B035-1144>の「CREATE USER」または
「MODIFY USER」。
エクスポート幅のシステム デフォルトの設定 <ユーティリティ、B035-1102>の「DBS 制御
(dbscontrol)」。
エクスポート幅について
エクスポート幅を適切に設定していないと、Teradata Database がエクスポートする
文字数やバイト数が、それを受信するクライアント アプリケーションが期待する文
字数やバイト数を超過することや、期待する文字数やバイト数に満たないことがあ
ります。エクスポート幅は、システムが Teradata クライアントに返す結果セット行
の各文字フィールドに、どれだけ領域を予約するかを定義します。
DBS 制御フィールドのエクスポート幅テーブル ID を設定すると、クライアントに結
果セットを返す際にシステムが使用する 、デフォルトのエスポート幅を定義できま
す。詳細は、<ユーティリティ 、B035-1102>の「DBS 制御(dbscontrol)」を参照して
ください。
CREATE USER 文または MODIFY USER 文で EXPORTWIDTH オプションを使用して、
システムレベルのエクスポート幅を上書きできます 。EXPORTWIDTH オプション
は、次の値を受け入れます。
802
エクスポート定義名
説明
'Expected'
文字データ タイプとクライアント使用形式に対して妥当なデフォ
ルトの幅を提供します。
SQL 関数、演算子、式および述部
第 16 章 エクスポート幅プロシージャ
ReplaceExportDefinition
エクスポート定義名
説明
'Compatibility'
Latin または KANJI1 のデータを処理するために記述されるアプ
リケーションによる処理を行なうために、Unicode データを有効
にします。
'Maximum'
文字データ タイプとクライアント使用形式に対して最大のデフォ
ルト幅を提供します。
'user-defined name'
文字データ タイプとクライアント使用形式に対して、ユーザー
定義のデフォルトの幅を提供します。
DEFAULT
DBS 制御フィールド「エクスポート幅テーブル ID」の設定を使
用します。
次の用途に ReplaceExportDefinition ストアド プロシージャを使用できます。
• 新しいユーザー定義のエクスポート定義名と、それに関連付けられたエクスポー
ト幅ルールの作成。
• 既存のユーザー定義のエクスポート定義名に関連付けられた、エクスポート幅
ルールの更新。
RemoveExportDefinition ストアド プロシージャを使用すると、ユーザー定義のエク
スポート定義名と、それに関連付けられたエクスポート幅ルールを削除できます。
関連情報
参照先
エクスポート幅と、ユーザー定義のエクス
ポート幅定義の作成
<国際文字セットのサポート、B035-1125>。
ユーザー レベルのエクスポート幅設定の指定 <SQL データ定義言語 - 構文規則および例、
B035-1144>の「CREATE USER」または
「MODIFY USER」。
エクスポート幅のシステム デフォルトの設定 <ユーティリティ、B035-1102>の「DBS 制御
(dbscontrol)」。
ReplaceExportDefinition
目的
ユーザー定義のエクスポート幅定義の作成または変更
構文
CALL
ReplaceExportDefinition
A
( 'export_definition_name ',
SYSLIB.
A
'export_width_rule_set ' , result_message )
;
SQL 関数、演算子、式および述部
803
第 16 章 エクスポート幅プロシージャ
ReplaceExportDefinition
構文要素
SYSLIB
関数が格納されているデータベースの名前。
export_definition_name
ユーザー定義のエクスポート定義名。
'Expected'、'Compatibility'、または'Maximum'を指定することはできません。
export_width_rule_set
40 個の 16 進数数字を含む、ユーザー定義の BYTE 文字列。export_definition_name.
に付随するエクスポート幅ルールの定義に使用します。
result_message
ストアド プロシージャの出力メッセージ。
許可
このストアド プロシージャまたは SYSLIB データベースに対する EXECUTE 権限が必
要です。
引数のタイプ
このプロシージャに渡された式は、次のデータ タイプを持っている必要があります。
• export_definition_name = VARCHAR(n) CHARACTER SET LATIN (n の最大値は 30)
• export_width_rule_set = BYTE(20)
• result_message = VARCHAR(310) CHARACTER SET UNICODE
Teradata Database の暗黙のデータ型変換規則を使用して、上記の型に変換できる
データ型の引数も渡すことができます。
使用上の注意
新しいユーザー定義のエクスポート幅定義を作成するには、次の引数を指定して
ReplaceExportDefinition ストアド プロシージャを呼び出します。
• export_definition_name は、新しいエクスポート幅定義の名前を指定するための
Latin 文字列です。
• export_width_rule_set は、40 個の 16 進数数字を含む BYTE 文字列です。これに
より、エクスポート幅ルールを、新しいエクスポート幅定義用にエンコードしま
す。エクスポート幅ルールの詳細については、「エクスポート幅ルール」を参照
してください。
• result_message は、このストアド プロシージャの出力メッセージを格納する出力
パラメータです。
804
SQL 関数、演算子、式および述部
第 16 章 エクスポート幅プロシージャ
ReplaceExportDefinition
ReplaceExportDefinition は、指定されたルールで新しいエクスポート幅定義を作成
し、DBC.ExportWidth テーブルを更新します。
既存のユーザー定義のエクスポート幅定義のエクスポート幅ルールを変更するには、
次の引数を指定して、ReplaceExportDefinition ストアド プロシージャを呼び出しま
す。
• export_definition_name は、変更する既存のユーザー定義のエクスポート幅定義
の名前を指定する、Latin 文字列です。
• export_width_rule_set は、40 個の 16 進数数字を含む BYTE 文字列です。これ
により、export_definition_name の新しいエクスポート幅ルールを定義します。
エクスポート幅ルールの詳細については、「エクスポート幅ルール」を参照して
ください。
• result_message は、このストアド プロシージャの出力メッセージを格納する出
力パラメータです。
ReplaceExportDefinition は、指定されたエクスポート幅定義を新しいルールで変更
して、DBC.ExportWidth テーブルを更新します。改定されたエクスポート幅定義
は、影響を受けるユーザーごとに次回のトランザクション時に有効になります。実
行中のトランザクションは、既存のエクスポート幅定義で継続されます。
注: 'Expected'、'Compatibility'、または'Maximum'を export_definition_name に対し
て指定することはできません。
エクスポート幅ルール
export_width_rule_set は、40 個の 16 進数数字が含まれる BYTE 文字列であり、
フォーマットは次のようになります。
•
•
•
•
最初の 10 個の数字では、LATIN 文字列のエクスポート幅を定義します。
2 番目の 10 個の数字では、UNICODE 文字列のエクスポート幅を定義します。
3 番目の 10 個の数字では、KANJISJIS 文字列のエクスポート幅を定義します。
4 番目の 10 個の数字では、GRAPHIC 文字列のエクスポート幅を定義します。
例えば、export_width_rule_set が
'1112211111222232222211121111112222322222'XB の場合は、次のように
なります。
• 最初の 10 個の数字(1112211111)は、LATIN 文字列のエクスポート幅を定義し
ます。
• 2 番目の 10 個の数字(2222322222)は、UNICODE 文字列のエクスポート幅を定
義します。
• 3 番目の 10 個の数字(1112111111)は、KANJISJIS 文字列のエクスポート幅を定
義します。
• 4 番目の 10 個の数字(2222322222)は、GRAPHIC 文字列のエクスポート幅を定
義します。
10 個の数字のセットの各位置では、次のようにセッション文字セットのエクスポー
ト幅変換乗数を指定します。
SQL 関数、演算子、式および述部
805
第 16 章 エクスポート幅プロシージャ
ReplaceExportDefinition
10 個の数字セットの中の 変換乗数
位置
1 番目
• 文字列'_0I'で終了する任意のセッション文字セット。
• セッション文字セット'KATAKANAEBCDIC'。
2 番目
文字列'_0U'で終了する任意のセッション文字セット。
3 番目
文字列'_0S'で終了する任意のセッション文字セット。
4 番目
セッション文字セット'UTF16'。
5 番目
セッション文字セット'UTF8'。
6 番目
STATEMACHINE EUC1211 によるサイト定義セッション文
字セット。
7 番目
STATEMACHINE EUC1223 によるサイト定義セッション文
字セット。
8 番目
STATEMACHINE S80 によるサイト定義セッション文字セッ
ト。
9 番目
STATEMACHINE S80A1E0 によるサイト定義セッション文
字セット。
10 番目
STATEMACHINE SOSI0E0F によるサイト定義セッション文
字セット。
各位置の値は 1、2、3 または 4 になります。ただし、各 10 個の文字セット(UTF16)
内の 4 番目の位置の値は、2 または 4 のどちらかにする必要があります。
例えば、export_width_rule_set が
'1112211111222232222211121111112222322222'XB の場合は、次のようにな
ります。
• LATIN サーバー文字セット(10 個の数字の最初のセットが 1112211111)からエ
クスポートするときに、UTF8 セッション文字セット(10 個の数字の最初のセット
内で 5 番目の位置)については、エクスポート幅が 2 になります。
• UNICODE サーバー文字セット(10 個の数字の 2 番目のセットが 2222322222)か
らエクスポートするときに、UTF8 セッション文字セット(10 個の数字の 2 番目
のセット内で 5 番目の位置)については、エクスポート幅が 3 になります。
• KANJISJIS サーバー文字セット(10 個の数字の 3 番目のセットが 1112111111)か
らエクスポートするときに、UTF16 セッション文字セット(10 個の数字の 3 番目
のセット内で 4 番目の位置)については、エクスポート幅が 2 になります。
例
この例では、MyExportWidth が存在しない場合、ReplaceExportDefinition は
MyExportWidth という名前の新しいエクスポート幅定義を、それに関連付けるエク
スポート幅ルール セットの
806
SQL 関数、演算子、式および述部
第 16 章 エクスポート幅プロシージャ
RemoveExportDefinition
'1422323221332232322321123111122322323221'XB で作成します。
MyExportWidth が既に存在する場合、ReplaceExportDefinition は現在のエクスポー
ト幅ルール セットの MyExportWidth を、新しいエクスポート幅ルール セットの
'1422323221332232322321123111122322323221'XB で置換します。
CALL SYSLIB.ReplaceExportDefinition
('MyExportWidth','1422323221332232322321123111122322323221'xb,msg);
RemoveExportDefinition
目的
ユーザー定義のエクスポート幅定義を削除します。
構文
RemoveExportDefinition
CALL
A
( 'export_definition_name ',
SYSLIB.
A
result_message )
;
構文要素
SYSLIB
関数が格納されているデータベースの名前。
export_definition_name
ユーザー定義のエクスポート定義名。
'Expected'、'Compatibility'、または'Maximum'を指定することはできません。
result_message
ストアド プロシージャの出力メッセージ。
許可
このストアド プロシージャまたは SYSLIB データベースに対する EXECUTE 権限が
必要です。
引数のタイプ
このプロシージャに渡された式は、次のデータ タイプを持っている必要があります。
SQL 関数、演算子、式および述部
807
第 16 章 エクスポート幅プロシージャ
RemoveExportDefinition
• export_definition_name = VARCHAR(n) CHARACTER SET LATIN (n の最大値は 30)
• result_message = VARCHAR(100) CHARACTER SET UNICODE
Teradata Database の暗黙のデータ型変換規則を使用して、上記の型に変換できる
データ型の引数も渡すことができます。
使用上の注意
既存のユーザー定義のエクスポート幅定義を削除するには、次の引数を指定して
RemoveExportDefinition ストアド プロシージャを呼び出します。
• export_definition_name は、削除する既存のエクスポート幅定義の名前を指定す
るための Latin 文字列です。
• result_message は、このストアド プロシージャの出力メッセージを格納する出力
パラメータです。
RemoveExportDefinition は、指定されたエクスポート幅定義を DBC.ExportWidth
テーブルから削除します。
注: 'Expected'、'Compatibility'、または'Maximum'を export_definition_name に対し
て指定することはできません。また、ユーザーに割り当てられているエクスポート
幅定義を、削除することはできません。
例
次の文は、MyExportWidth という名前のユーザー定義のエクスポート幅定義を削除
します。
CALL SYSLIB.RemoveExportDefinition('MyExportWidth',msg);
808
SQL 関数、演算子、式および述部
第 17 章
ハッシュ関連の関数
概要
ハッシュ関連の関数は、以下に関する情報を戻します。
•
•
•
•
•
•
特定のハッシュ バケット番号に対応する基本またはフォールバックの AMP
特定の行ハッシュ値に対応するハッシュ バケット番号
行の基本索引の行ハッシュ値
最高の AMP 番号
最高のハッシュ バケット番号
符号なしの整数に対するハッシュ関数の適用によって生成できる最大値
ハッシュ関連関数は、現行基本索引または副次索引の統計プロパティを識別する場
合や、その他の列の統計プロパティを評価して今後の基本索引または副次索引とし
ての適性を判別する場合に使用します。この統計は、ハッシュ シノニムを最小化し
て、データ分布の均一性を高めるのに役立ちます。
HASHAMP
目的
指定されたハッシュ バケット番号に対応する基本 AMP の ID 番号を返します。ハッ
シュ バケット番号を指定しないと、システム上の AMP の最大数よりも 1 つ少ない
番号が HASHAMP から戻されます。
構文
HASHAMP
( expression )
構文要素
expression
有効ハッシュ バケット番号と評価される式。
SQL 関数、演算子、式および述部
809
第 17 章 ハッシュ関連の関数
HASHAMP
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプと値
expression 引数は、値の有効範囲がハッシュ バケット サイズのシステム設定によっ
て異なる場合は、INTEGER データ型と評価されなければなりません。
ハッシュ バケット サイズ
expression の値の範囲
16 ビット
0~65535
20 ビット
0~1048575
ハッシュ バケット サイズのシステム設定の指定方法については 、<ユーティリティ 、
B035-1102>の「DBS Control(DBS 制御)ユーティリティ」を参照してください。
expression が INTEGER に暗黙変換できない場合は、エラーが戻されます。
expression の結果が UDT になる場合に、UDT と以下のいずれかの事前定義タイプの
間でキャストする暗黙 CAST を UDT が持っていると、Teradata Database はその UDT
に対して暗黙タイプ変換を実行します。
• 数値
• 文字
• DATE
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
HASHAMP を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、ANSI
SQL 標準の Teradata 拡張機能です。
結果
expression
結果
有効なハッシュ バケッ HASHAMP は、ハッシュ バケットに対応する基本 AMP を判別して、
ト番号に評価される その AMP ID 番号を戻します。
結果は、ゼロ以上かつ構成内の AMP の最大数より小さい INTEGER
値になります。
引数リストに表示され HASHAMP は、システム内の AMP の最大数より 1 少ない INTEGER
ない
値を戻します。
NULL と評価される
810
HASHAMP は NULL を戻します。
SQL 関数、演算子、式および述部
第 17 章 ハッシュ関連の関数
HASHAMP
ハッシュ バケットと基本 AMP の関係を定義するハッシュ マップの詳細について
は、<サポート ユーティリティ 、B035-1180>の「Reconfiguration(再構成)ユーティ
リティ」を参照してください。
例
以下の例では、テーブル T に column_1、column_2、および INTEGER 列 B があり、
それらの列にゼロからシステム上の最大ハッシュ バケット数までの整数の番号が取
り込まれていると想定します。
CREATE TABLE T
(column_1 INTEGER
,column_2 INTEGER
,B INTEGER)
UNIQUE PRIMARY INDEX (column_1, column_2);
例: HASHAMP を引数なしで呼び出す
HASHAMP を引数なしで呼び出した場合には、システム上の AMP の最大数よりも
1 つ少ない番号が戻されます。
SELECT HASHAMP();
例: HASHAMP を NULL の引数とともに呼び出す
HASHAMP を NULL の引数とともに呼び出した場合には、NULL が戻されます。
SELECT HASHAMP(NULL);
例: ハッシュ バケットの分布の問合わせ
次の問合わせは、それぞれの基本 AMP におけるハッシュ バケットの分布を戻します。
SELECT B, HASHAMP (B)
FROM T
ORDER BY 1;
例: 各基本 AMP 上の行数の問合わせ
以下の問合わせは、テーブル T の基本索引が column_1 と column_2 となる各基本
AMP の行の数を戻します。
SELECT HASHAMP (HASHBUCKET (HASHROW (column_1,column_2))), COUNT (*)
FROM T
GROUP BY 1
ORDER BY 1;
SQL 関数、演算子、式および述部
811
第 17 章 ハッシュ関連の関数
HASHBAKAMP
関連トピック
詳細は、以下を参照してください。
• 詳細については、ユーティリティ 、B035-1102 を参照してください。
• 暗黙の型変換の詳細については、「データ型の変換」を参照してください。
• ハッシュ バケットとフォールバック AMP の関係を定義するハッシュ マップの詳
細については、<サポート ユーティリティ 、B035-1180>の「Reconfiguration(再
構成)ユーティリティ」を参照してください。
HASHBAKAMP
目的
指定されたハッシュ バケットに対応するフォールバック AMP の ID 番号を戻しま
す。ハッシュ バケットを指定しないと、システム上の AMP の最大数よりも 1 つ少
ない番号が HASHBAKAMP から戻されます。
構文
HASHBAKAMP
( expression )
構文要素
expression
有効ハッシュ バケット番号と評価される式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
引数のタイプと値
expression 引数は、値の有効範囲がハッシュ バケット サイズのシステム設定によっ
て異なる場合は、INTEGER データ型と評価されなければなりません。
ハッシュ バケット サイズ
expression の値の範囲
16 ビット
0~65535
20 ビット
0~1048575
ハッシュ バケット サイズのシステム設定の指定方法については 、<ユーティリティ 、
B035-1102>の「DBS Control(DBS 制御)ユーティリティ」を参照してください。
expression が INTEGER に暗黙変換できない場合は、エラーが戻されます。
812
SQL 関数、演算子、式および述部
第 17 章 ハッシュ関連の関数
HASHBAKAMP
expression の結果が UDT になる場合に、UDT と以下のいずれかの事前定義タイプ
の間でキャストする暗黙 CAST を UDT が持っていると、Teradata Database はその
UDT に対して暗黙タイプ変換を実行します。
• 数値
• 文字
• DATE
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
HASHBAKAMP を含め、システム演算子および関数用の UDT の暗黙の型変換は、
ANSI SQL 標準の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レ
コードの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。
結果
expression
結果
引数リストに表示されない
HASHBAKAMP は、システム内の AMP の最大数より 1
少ない INTEGER 値を戻します。
NULL と評価される
HASHBAKAMP は NULL を戻します。
有効なハッシュ バケット番号に評 HASHBAKAMP は、ハッシュ バケットに対応する
価される
フォールバック AMP を判別して、その AMP の ID 番
号を戻します。
結果は、ゼロ以上かつ構成内の AMP の最大数より小
さい INTEGER 値になります。
ハッシュ バケットとフォールバック AMP の関係を定義するハッシュ マップの詳細
については、<サポート ユーティリティ 、B035-1180>の「Reconfiguration(再構成)
ユーティリティ」を参照してください。
例
例
以下の例では、テーブル T に 1 つの INTEGER 列 B があり、その列には、ゼロから
システム上の最大ハッシュ バケット数までの整数の番号が取り込まれていると想定
します。
例
HASHBAKAMP を引数なしで呼び出した場合には、システム上の AMP の最大数よ
りも 1 つ少ない番号が戻されます。
SELECT HASHBAKAMP();
SQL 関数、演算子、式および述部
813
第 17 章 ハッシュ関連の関数
HASHBUCKET
例
HASHBAKAMP 関数を NULL の引数とともに呼び出した場合には、関数は NULL を
戻します。
SELECT HASHBAKAMP(NULL);
例
次の問合わせは、それぞれのフォールバック AMP 内におけるハッシュ バケットの
分布を戻します。
SELECT B, HASHBAKAMP (B)
FROM T
ORDER BY 1;
関連トピック
詳細については、<ユーティリティ 、B035-1102>を参照してください。
HASHBUCKET
目的
指定された行のハッシュ値に対応するハッシュ バケット番号を戻します。行ハッシュ
値を指定しないと、ハッシュ バケットの最大番号が HASHBUCKET から戻されます。
構文
HASHBUCKET
( expression )
構文要素
expression
有効な BYTE(4)行ハッシュ値と評価される任意選択の式。
expression の結果が UDT になる場合に、事前定義されたバイト型への暗黙 CAST を
UDT が持っていると、Teradata Database はその UDT に対して暗黙型変換を実行し
ます。
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および
例、B035-1144>を参照してください。
HASHBUCKET を含め、システム演算子および関数用の UDT の暗黙の型変換は、ANSI
SQL 標準の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レコード
の DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。
814
SQL 関数、演算子、式および述部
第 17 章 ハッシュ関連の関数
HASHBUCKET
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果
HASHBUCKET は INTEGER データ タイプを戻します。
expression
結果
引数リストに表示され
ない
HASHBUCKET は、最高のハッシュ バケット番号である INTEGER
値を戻します。
NULL と評価される
HASHBUCKET は NULL を戻します。
有効な BYTE(4)行ハッ
シュ値と評価される
HASHBUCKET は、行ハッシュ値に対応するハッシュ バケット番
号を戻します。
ハッシュ バケット番号の値の範囲は、ハッシュ バケット サイズ
のシステム設定によって異なります 。
• ハッシュ バケット サイズが 16 ビットである場合、ハッシュ
バケット番号の値は 0~65535 になります。
• ハッシュ バケット サイズが 20 ビットである場合、ハッシュ
バケット番号の値は 0~1048575 になります。
HASHBUCKET を使用した BYTE タイプから INTEGER タイプへの変換
バイト データ タイプが CAST 構文または Teradata 変換構文を使用した変換のソー
ス タイプである場合は、ターゲット データ タイプもバイト タイプである必要があ
ります。
BYTE(1)または BYTE(2)データ タイプを INTEGER に変換するには、HASHBUCKET
関数を使用します。
次のテーブル定義を考えます。
CREATE TABLE ByteData(b1 BYTE(1), b2 BYTE(2));
ハッシュ バケット サイズのシステム設定に関係なく列 b1 を INTEGER に変換する
には、以下を使用します。
SELECT HASHBUCKET('00'XB || b1 (BYTE(4))) / ((HASHBUCKET()+1)/65536)
FROM ByteData;
ハッシュ バケット サイズのシステム設定に関係なく列 b2 を INTEGER に変換する
には、以下を使用します。
SELECT HASHBUCKET(b2 (BYTE(4))) / ((HASHBUCKET()+1)/65536)
FROM ByteData;
SQL 関数、演算子、式および述部
815
第 17 章 ハッシュ関連の関数
HASHBUCKET
例
以下の例では、テーブル T には、列 C1 および C2 と、さらに別の列もある可能性が
あると想定しています。
例
引数なしで HASHBUCKET を呼び出すと、最大のハッシュ バケットが戻されます。
SELECT HASHBUCKET();
例
HASHBUCKET 関数を NULL の引数とともに呼び出した場合には、関数は NULL を戻
します。
SELECT HASHBUCKET(NULL);
例
前の例を使用して、HASHROW 呼出しを HASHBUCKET 呼出しの入れ子にすること
ができます。
HASHBUCKET (HASHROW (NULL))の呼出しは、0 のハッシュ バケットを戻します。
SELECT HASHBUCKET(HASHROW(NULL));
例
以下の例は、C1 と C2 が T の基本索引となる各ハッシュ バケット内の行の数を戻し
ます。
SELECT HASHBUCKET (HASHROW (C1,C2)), COUNT (*)
FROM T
GROUP BY 1
ORDER BY 1;
例
以下の例の結果では、1 つ以上の行とそれに対応する基本 AMP をもつ各ハッシュ バ
ケットが一覧で示されます。
SELECT HASHAMP (HASHBUCKET (HASHROW (C1, C2))),
HASHBUCKET (HASHROW (C1,C2))
FROM T
GROUP BY 1,2
ORDER BY 1,2 ;
816
SQL 関数、演算子、式および述部
第 17 章 ハッシュ関連の関数
HASHROW
HASHROW
目的
式または一連の式の行ハッシュ値を 16 進数で戻します。 式が何も指定されていな
い場合は、HASHROW は最大のハッシュ コード値を戻します。
構文
HASHROW
(
,
)
expression
構文要素
expression
SELECT 文の SELECT 句の式リストに表示できるオプションの式またはカンマで区
切られた式リスト。通常は、(候補の)索引を構成する列名をカンマで区切ったリスト。
HASHROW は、結果が UDT データ タイプになる式をサポートしません。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果
結果の行ハッシュ値はタイプ BYTE(4)です。
引数リスト
HASHROW の動作
空
最大のハッシュ コード値を戻します。
NULL と評価される式
'00000000'XB を戻します。
すべての式が NULL と評価される場合の式のリスト
0、''、' '、または同様の値と評価される式
SELECT 文の選択リストに表示できる、NULL 以外の expression または expression のリス
有効な式
トを評価して、その結果に対してハッ
シュ関数を適用します。HASHROW は
いくつかの式が NULL と評価される場合、SELECT
その結果の行ハッシュ値を戻します。
文の選択リストに表示できる式のリスト
使用上の注意
HASHROW は、現行基本索引の統計特性を識別する場合、または他の列に対するこ
れらの特性を評価して、将来の基本索引としての適性を判別する場合に特に役立ち
SQL 関数、演算子、式および述部
817
第 17 章 ハッシュ関連の関数
HASHROW
ます。また、これらの統計を使用すれば、ハッシュ シノニムを最小にして 、データ
分布の均一性を高めるためにも役立ちます。
システムで使用可能なハッシュ コードは最大で 4,294,967,295 個あり、その範囲
は '00000000'XB~'FFFFFFFF'XB です。
HASHBUCKET 呼出しの中に HASHROW 呼出しを埋め込むことができます。
例
例
HASHROW を引数なしで呼び出した場合には、'FFFFFFFF'XB が戻されます。これ
は、システム内の最大ハッシュ コードです。
SELECT HASHROW();
例
以下の例では、date_field 列と time_field 列が eventlog テーブルの基本索引となる、
行ハッシュあたりの行の平均数を戻します。
SELECT COUNT(*) / COUNT(DISTINCT HASHROW (date_field,time_field))
FROM eventlog;
date_field 列と time_field 列が固有索引となる条件を満たしている場合、この例は、
ハッシュ シノニムが同じ行の平均数を戻します。
例
次の例は、数値フィールドの decimal 書式の変更によってシノニムをなくす効果を
評価します。
column_1 と column_2 が DECIMAL(2,2)として宣言されていることを前提としてい
ます。
次の 2 つの問合わせを実行依頼することによって、ハッシュの衝突時に列を
DECIMAL(8,6)および DECIMAL(8,4)に書式設定し直すことの効果を判別することが
できます。
SELECT COUNT (DISTINCT column_1(DECIMAL(8,6)) ||
column_2(DECIMAL(8,4))
FROM T;
SELECT COUNT (DISTINCT HASHROW (column_1(DECIMAL(8,6)),
column_2 (DECIMAL(8,4)))
FROM T;
2 番目の問合わせの結果が最初の問合わせの結果よりはるかに小さい場合、かなり
の数のハッシュ衝突があります。つまり、2 番目の結果が最初の値に近ければ近い
ほど、削減されるハッシュ シノニムは多くなることを示します。
818
SQL 関数、演算子、式および述部
第 17 章 ハッシュ関連の関数
HASHROW
関連トピック
詳細は、以下を参照してください。
• HASHBUCKET の詳細については、「HASHBUCKET」を参照してください。
SQL 関数、演算子、式および述部
819
第 17 章 ハッシュ関連の関数
HASHROW
820
SQL 関数、演算子、式および述部
第 18 章
ファイル システム情報マクロ
概要
これらの関数を使用して、さまざまな Ferret SHOW コマンドによって、Teradata
Database ファイル システムの、データ ブロック サイズ、データ ブロックごとの行
数に関する統計および、指定されているテーブルまたはテーブル グループのデー
タ ブロックの圧縮状態に関する情報を表示できるようになります。
情報は、Ferret ユーティリティの SHOWBLOCKS コマンドによって表示される情報
に類似しています。これらの関数からの情報は通常のデータベース テーブルで作成
されるため、情報の共有と処理をより簡単に行なうことができます。この情報を作
成し表示するためのアクセス権は、標準の SQL GRANT および REVOKE 権限文を使
用してより簡単に管理することもできます。
関連トピック
Ferret についての詳細は、<ユーティリティ 、B035-1102>を参照してください。
CreateFsysInfoTable
CreateFsysInfoTable_ANSI
目的
PopulateFsysInfoTable マクロによって生成されたファイル システム情報を保持す
るためのデータベース テーブルを作成します。
注: ANSI セッション モードを使用する場合は、マクロの_ANSI 形式を使用します。
PopulateFsysInfoTable または PopulateFsysInfoTable_ANSI マクロがデータベース
とテーブル名に文字列が入力されない状態で呼び出された場合、テーブルの作成は
不要です。出力が画面にリダイレクトされます。
SQL 関数、演算子、式および述部
821
第 18 章 ファイル システム情報マクロ
CreateFsysInfoTable
CreateFsysInfoTable_ANSI
構文
構文要素
target_database_name
テーブルが作成されるデータベース。
注: ターゲット データベースでテーブルを作成するための適切な権限を所有している
必要があります。
target_table_name
ファイル システム情報を保持するために作成されるテーブルの名前 。
注: ターゲット データベースでテーブルを作成するための適切な権限を所有している
必要があります。
storage_type
テーブルが永久テーブル、グローバル一時テーブル、または揮発テーブルかどうか
を指定します。
storage_type の有効な値は、次のとおりです。
• PERM
• GLOBALTEMP
• VOLATILE
fallback
データベースがテーブルのフォールバック コピーを維持するかどうかを指定します。
fallback の有効な値は、次のとおりです。
• Y (Yes: テーブルにフォールバックがある)
• N (No: テーブルにフォールバックがない)
command
この出力が同じように表示される Ferret SHOW コマンド。
利用可能なオプションには、SHOWBLOCKS または SHOWWHERE があります。
display_opt
テーブルに格納可能なファイル システム詳細のレベル。
display_opt の有効な値は、次のとおりです。
• S は、最小量のファイル システム情報詳細を提供します
• M は、中量のファイル システム情報を提供します
822
SQL 関数、演算子、式および述部
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
• L は、最大量のファイル システム情報を提供します
表示される特定の情報については、「PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI」を参照してください。
注: CreateFsysInfoTable に選択される表示オプションは、PopulateFsysInfoTable マ
クロの対応する実行に使用される表示オプションに一致している必要があります。
出力が画面にダイレクトされた場合(たとえば、データベースおよびテーブル名に空
の文字列を指定)、PopulateFsysInfoTable または PopulateFsysInfoTable_ANSI マク
ロの呼び出しを使用したテーブルの作成は不要です。あらゆる表示オプションの指
定が可能です。
許可
このマクロを実行するには、上記の権限だけでなく、CreateFsysInfoTable マクロ、
またはこのマクロを含むデータベースに対し EXECUTE 権限がなければなりません。
マクロ名と引数は大文字と小文字を区別します。
例
例: SHOWBLOCKS の短形式のファイル システム情報テーブルの作成
この文は、ディスク ブロック情報の最小表示を保持するための揮発の非フォール
バック テーブルを作成します。
exec dbc.createfsysinfotable
('visuser','datablockinfo','volatile','n','showblocks','s');
例: SHOWWHERE の短形式のファイル システム情報テーブルの作成
この文は、SHOWWHERE の短形式出力を保持するための永続的な非フォールバッ
ク ターゲット テーブル'showw_s'を作成します。
exec dbc.createfsysinfotable
('visuser','showw_s','perm','n','showwhere','s');
オプションを'M'または'L'に変更して、中形式または長形式の出力を表示します。
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
目的
CreateFsysInfoTable マクロによって作成されるテーブルにファイル システム デー
タを生成します。
注: ANSI セッション モードを使用する場合は、マクロの_ANSI 形式を使用します。
SQL 関数、演算子、式および述部
823
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
構文
構文要素
input_database_name
ファイル システム データ ブロック ヒストグラム情報が生成されるテーブルを含む
データベース。
注: 入力データベースのテーブルからデータを選択するための適切な権限を所有して
いる必要があります。
データベース DBC を指定すると、input_class 引数を使用して、情報が生成される
テーブルのクラスを選択することができます。
input_table_name
ファイル システム情報が生成されるテーブルの名前 。
注: 入力データベースのテーブルからデータを選択するための適切な権限を所有して
いる必要があります。
input_class
ファイル システム情報が生成されるテーブルのクラス 。
input_class は、input_database_name が DBC の場合にのみ指定できます。
input_class の有効な値は、次のとおりです。
• CLASSPERM
• CLASSJRNL
• CLASSREDRIVE
• CLASSGLOBALTEMP
• CLASSSPOOL
• CLASSWAL
• CLASSALL (上記の表のクラスをすべて表示)
注: input_class は、SHOWWHERE に対してのみサポートされます。input_class オプ
ションは、マクロを使用して SHOWBLOCKS 情報を生成する場合は、リソース使用
率が高いため使用できません。
command
この出力が同じように表示される Ferret SHOW コマンド。
利用可能なオプションには、SHOWBLOCKS または SHOWWHERE があります。
824
SQL 関数、演算子、式および述部
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
display_opt
生成され、ターゲット テーブルに入力されるファイル システム詳細のレベル。
display_opt に有効な値は、S、M および L です。
• S には指定されているテーブルの基本データ サブテーブルに関する以下の情報が
含まれます。
ブロック サイズのヒストグラム
サブテーブルごとの最小、平均、最大ブロック サイズ
ブロック圧縮情報(状態、予想圧縮率、予想される非圧縮)
• M には S と同じ情報が含まれていますが、指定されているテーブルのすべてのサ
ブテーブルの統計を表示します。
• L には指定されているテーブルのサブテーブルごとの各ブロック サイズ カテゴ
リに関する以下の情報が含まれています。
• ブロック数
• データ ブロック サイズごとの行数の最小数、平均数、最大数
• ブロック圧縮情報(状態、予想圧縮率、予想非圧縮率)
注: PopulateFsysInfoTable に選択されている表示オプションは、CreateFsysInfoTable
マクロの対応する実行に使用された表示オプションと一致している必要があります。
target_database_name
CreateFsysInfoTable マクロによってターゲット テーブルが作成されたデータベース。
この引数と target_table_name が空の文字列である場合、出力はコンピュータ画面
にダイレクトされます。
注: 作成する、またはターゲット データベースのテーブルに挿入するための適切な
権限を所有している必要があります。
データベースとテーブル名に空の文字列を指定してマクロを呼び出した場合 、
CreateFsysInfoTable CreateFsysInfoTable_ANSI の呼び出しは不要です。
target_table_name
ファイル システム情報を保持するための 、ターゲット データベース内で
CreateFsysInfoTable マクロによって作成されたテーブルの名前。
この引数と target_database_name が空の文字列である場合、出力はコンピュータ
画面にダイレクトされます。
注: ターゲット データベースの target_table_name に挿入するための適切な権限を
所有している必要があります。ターゲット データベースで target_table_name を作
成した場合、ターゲット テーブルに対し暗黙的な INSERT 権限を所有していること
になります。
データベースとテーブル名に空の文字列を指定してマクロを呼び出した場合 、
CreateFsysInfoTable CreateFsysInfoTable_ANSI の呼び出しは不要です。
SQL 関数、演算子、式および述部
825
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
許可
このマクロを実行するには、上記の権限だけでなく、PopulateFsysInfoTable マク
ロ、またはこのマクロを含むデータベースに対し EXECUTE 権限を所有している必
要があります。
マクロ名と引数は大文字と小文字を区別します。
例
例: SHOWBLOCK 出力のファイル システム情報テーブルの挿入 (オプション'S')
最初のステップとして、ファイル システム情報行を格納するためのターゲット テー
ブルを作成することができます。
手動、または CreateFsysInfoTable マクロを使用して、ターゲット テーブルを作成
します。
exec
createfsysinfotable('visuserdata','showbtrgttableshort','perm','y','sho
wblocks','s');
SHOWBLOCKS に関するファイル システム情報を格納するためのターゲット テーブ
ルを作成するときの S 表示オプションに対するターゲット テーブルの定義を以下に
示します。
show table visuserdata.showbtrgttable;
CREATE SET TABLE visuserdata.showbtrgttableshort,FALLBACK ,
NO BEFORE JOURNAL,
NO AFTER JOURNAL,
CHECKSUM = DEFAULT,
DEFAULT MERGEBLOCKRATIO
(
TheDate DATE FORMAT 'YY/MM/DD',
TheTime TIME(6),
DataBaseName VARCHAR(128) CHARACTER SET UNICODE NOT
CASESPECIFIC
NOT NULL,
TableName VARCHAR(128) CHARACTER SET UNICODE NOT CASESPECIFIC
NOT
NULL,
TableID BYTE(6),
TableIDTAI INTEGER,
CompressionMethod CHAR(8) CHARACTER SET LATIN NOT CASESPECIFIC,
CompressionState VARCHAR(2) CHARACTER SET LATIN NOT CASESPECIFIC,
EstCompRatio DECIMAL(5,2),
EstPctOfUncompDBs DECIMAL(5,2),
PctDBsIn1to8 BYTEINT,
PctDBsIn9to24 BYTEINT,
826
SQL 関数、演算子、式および述部
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
PctDBsIn25to64 BYTEINT,
PctDBsIn65to120 BYTEINT,
PctDBsIn121to168 BYTEINT,
PctDBsIn169to216 BYTEINT,
PctDBsIn217to256 BYTEINT,
PctDBsIn257to360 BYTEINT,
PctDBsIn361to456 BYTEINT,
PctDBsIn457to512 BYTEINT,
PctDBsIn513to760 BYTEINT,
PctDBsIn761to1024 BYTEINT,
PctDBsIn1025to1034 BYTEINT,
PctDBsIn1035to1632 BYTEINT,
PctDBsIn1633to2048 BYTEINT,
MinDBSize INTEGER,
AvgDBSize INTEGER,
MaxDBSize INTEGER,
TotalNumDBs BIGINT,
LrgCyls BIGINT,
SmlCyls BIGINT)
PRIMARY INDEX ( TheDate ,TheTime ,TableID ,CompressionState );
次の例に、S 表示オプションの PopulateFsysInfoTable マクロ実行からの BTEQ 出力
と、出力を強制的に画面に表示する target_database_name および
target_table_name の空の文字列を示します。
出力の列タイトル名は、ターゲット テーブルを使用して出力を格納せずに画面にリ
ダイレクトされるときに変わります。例えば、列名がターゲット テーブルで
"PctDBsIn1to8"とすると、出力が画面にリダイレクトされた場合、対応する列は"%
Of DBs In 1 to 8"となります。
PopulateFsysInfoTable マクロの後に戻される警告は、出力が画面に表示されるとき
に想定されている動作です。
注: BTEQ .foldline コマンドと.sidetitles コマンドは、戻されたデータ セットの列タ
イトルが横に表示され、これらの列の対応する値が列タイトルの横に表示されるよ
うにするために使用されています。
注: 次の PopulateFsysInfoTable()呼び出しの例では、出力/結果を画面にリダイレク
トします(データベースとテーブル名に空の文字列を指定)。特定のテーブルに出力/
結果を挿入する場合、テーブルが CreateFsysInfoTable()マクロで作成され、同じ/
display_opt が PopulateFsysInfoTable および CreateFsysInfoTable の両方のマクロ
の呼び出しに指定されていることを確認します。
exec
***
***
***
populatefsysinfotable('visuser','test3','showblocks','s','','');
Procedure has been executed.
Warning: 3212 The stored procedure returned one or more result sets.
Total elapsed time was 34 seconds.
SQL 関数、演算子、式および述部
827
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
*** ResultSet# 1 : 1 rows returned by "SYSLIB.POPULATEFSYSINFOTABLESP".
Date 13/12/22
Time 21:45:29
DB//Name visuser
Tbl//Name test3
TID
0000E90A0000
TID//TAI
1024
Comp//Method MANUAL
Comp//State U
Est Comp//Ratio(%)
Est Uncomp//DBs(%)
% Of DBs In//1 to 8//Sects
% Of DBs In//9 to 24//Sects
% Of DBs In//25 to 64//Sects
% Of DBs In//65 to 120//Sects 50
% Of DBs In//121 to 168//Sects
% Of DBs In//169 to 216//Sects
% Of DBs In//217 to 256//Sects 50
% Of DBs In//257 to 360//Sects
% Of DBs In//361 to 456//Sects
% Of DBs In//457 to 512//Sects
% Of DBs In//513 to 760//Sects
% Of DBs In//761 to 1024//Sects
% Of DBs In//1025 to 1304//Sects
% Of DBs In//1305 to 1632//Sects
% Of DBs In//1633 to 2048//Sects
Min DB Size
96
Avg DB Size
176
Max DB Size
254
Total DBs
8
Lrg Cyls
4
Sml Cyls
例: SHOWBLOCK 出力のファイル システム情報テーブルの挿入 (オプション'M')
最初のステップとして、ファイル システム情報行を格納するためのターゲット テー
ブルを作成することができます。
手動、または CreateFsysInfoTable マクロを使用して、ターゲット テーブルを作成
します。
exec
createfsysinfotable('visuserdata','showbtrgttablemedium','perm','y',
'showblocks','m');
828
SQL 関数、演算子、式および述部
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
SHOWBLOCKS に関するファイル システム情報を格納するためのターゲット テーブ
ルを作成するときの M 表示オプションに対するターゲット テーブルの定義を以下
に示します。
show table visuserdata.showbtrgttablemedium;
CREATE SET TABLE visuserdata.showbtrgttablemedium ,FALLBACK ,
NO BEFORE JOURNAL,
NO AFTER JOURNAL,
CHECKSUM = DEFAULT,
DEFAULT MERGEBLOCKRATIO
(
TheDate DATE FORMAT 'YY/MM/DD',
TheTime TIME(6),
DataBaseName VARCHAR(128) CHARACTER SET UNICODE NOT
CASESPECIFIC
NOT NULL,
TableName VARCHAR(128) CHARACTER SET UNICODE NOT CASESPECIFIC
NOT
NULL,
TableID BYTE(6),
TableIDTAI INTEGER,
CompressionMethod CHAR(8) CHARACTER SET LATIN NOT CASESPECIFIC,
CompressionState VARCHAR(2) CHARACTER SET LATIN NOT CASESPECIFIC,
EstCompRatio DECIMAL(5,2),
EstPctOfUncompDBs DECIMAL(5,2),
PctDBsIn1to8 BYTEINT,
PctDBsIn9to24 BYTEINT,
PctDBsIn25to64 BYTEINT,
PctDBsIn65to120 BYTEINT,
PctDBsIn121to168 BYTEINT,
PctDBsIn169to216 BYTEINT,
PctDBsIn217to256 BYTEINT,
PctDBsIn257to360 BYTEINT,
PctDBsIn361to456 BYTEINT,
PctDBsIn457to512 BYTEINT,
PctDBsIn513to760 BYTEINT,
PctDBsIn761to1024 BYTEINT,
PctDBsIn1025to1034 BYTEINT,
PctDBsIn1035to1632 BYTEINT,
PctDBsIn1633to2048 BYTEINT,
MinDBSize INTEGER,
AvgDBSize INTEGER,
MaxDBSize INTEGER,
TotalNumDBs BIGINT,
LrgCyls BIGINT,
SmlCyls BIGINT)
SQL 関数、演算子、式および述部
829
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
PRIMARY INDEX (TheDate, TheTime, TableID ,TableIDTAI ,CompressionState);
BTEQ -- Enter your SQL request or BTEQ command:
次の例に、M 表示オプションの PopulateFsysInfoTable マクロ実行からの BTEQ 出力
と、出力を強制的に画面に表示する target_database_name および target_table_name
の空の文字列を示します。
出力の列タイトル名は、ターゲット テーブルを使用して出力を格納せずに画面にリ
ダイレクトされるときに変わります。例えば、列名がターゲット テーブルで
"PctDBsIn1to8"とすると、出力が画面にリダイレクトされた場合、対応する列は"%
Of DBs In 1 to 8"となります。
PopulateFsysInfoTable マクロの後に戻される警告は、出力が画面に表示されるとき
に想定されている動作です。
注: BTEQ .foldline コマンドと.sidetitles コマンドは、戻されたデータ セットの列タ
イトルが横に表示され、これらの列の対応する値が列タイトルの横に表示されるよ
うにするために使用されています。この例では、2 つの出力行を示します。各行の
最初の列は DATE 列です。
注: 次の PopulateFsysInfoTable()呼び出しの例では、出力/結果を画面にリダイレク
トします(データベースとテーブル名に空の文字列を指定)。特定のテーブルに出力/
結果を挿入する場合、テーブルが CreateFsysInfoTable()マクロで作成され、同じ/
display_opt が PopulateFsysInfoTable および CreateFsysInfoTable の両方のマクロの
呼び出しに指定されていることを確認します。
exec
***
***
***
populatefsysinfotable('visuser','test3','showblocks','m','','');
Procedure has been executed.
Warning: 3212 The stored procedure returned one or more result sets.
Total elapsed time was 32 seconds.
*** ResultSet# 1 : 2 rows returned by "SYSLIB.POPULATEFSYSINFOTABLESP".
Date 13/12/22
Time 21:46:12
DB//Name visuser
Tbl//Name test3
TID
0000E90A0000
TID//TAI
0
Comp//Method MANUAL
Comp//State N
Est Comp//Ratio(%)
Est Uncomp//DBS(%)
% Of DBs In//1 to 8//Sects 100
% Of DBs In//9 to 24//Sects
% Of DBs In//25 to 64//Sects
% Of DBs In//65 to 120//Sects
% Of DBs In//121 to 168//Sects
% Of DBs In//169 to 216//Sects
830
SQL 関数、演算子、式および述部
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
% Of DBs In//217 to 256//Sects
% Of DBs In//257 to 360//Sects
% Of DBs In//361 to 456//Sects
% Of DBs In// 457 to 512//Sects
% Of DBs In//513 to 760//Sects
% Of DBs In//761 to 1024//Sects
% Of DBs In//1025 to 1304//Sects
% Of DBs In//1305 to 1632//Sects
% Of DBs In//1633 to 2048//Sects
Min DB Size
2
Avg DB Size
2
Max DB Size
2
Total DBs
4
Lrg Cyls
4
Sml Cyls
Date 13/12/22
Time 21:46:12
DB//Name visuser
Tbl//Name test3
TID
0000E90A0000
TID//TAI
1024
Comp//Method MANUAL
Comp//State U
Est Comp//Ratio(%)
Est Uncomp//DBS(%)
% Of DBs In//1 to 8//Sects
% Of DBs In//9 to 24//Sects
% Of DBs In//25 to 64//Sects
% Of DBs In//65 to 120//Sects 50
% Of DBs In//121 to 168//Sects
% Of DBs In//169 to 216//Sects
% OfDBs In//217 to 256//Sects 50
% Of DBs In//257 to 360//Sects
% Of DBs In//361 to 456//Sects
% Of DBs In// 457 to 512//Sects
% Of DBs In//513 to 760//Sects
% Of DBs In//761 to 1024//Sects
% Of DBs In//1025 to 1304//Sects
% Of DBs In//1305 to 1632//Sects
% Of DBs In//1633 to 2048//Sects
Min DB Size
96
Avg DB Size
176
Max DB Size
254
Total DBs
8
SQL 関数、演算子、式および述部
831
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
Lrg Cyls
Sml Cyls
4
例: SHOWBLOCK 出力のファイル システム情報テーブルの挿入 (オプション'L')
最初のステップとして、ファイル システム情報行を格納するためのターゲット テー
ブルを作成することができます。
手動、または CreateFsysInfoTable マクロを使用して、ターゲット テーブルを作成
します。
exec
createfsysinfotable('visuserdata','showbtrgttablelong','perm','y','show
blocks','l');
SHOWBLOCKS に関するファイル システム情報を格納するためのターゲット テーブ
ルを作成するときの L 表示オプションに対するターゲット テーブルの定義を以下に
示します。
show table visuserdata.showbtrgttablelong;
CREATE SET TABLE visuserdata.showbtrgttablelong ,FALLBACK ,
NO BEFORE JOURNAL,
NO AFTER JOURNAL,
CHECKSUM = DEFAULT,
DEFAULT MERGEBLOCKRATIO
(
TheDate DATE FORMAT 'YY/MM/DD',
TheTime TIME(6),
DataBaseName VARCHAR(128) CHARACTER SET UNICODE NOT CASESPECIFIC
NOTNULL,
TableName VARCHAR(128) CHARACTER SET UNICODE NOT CASESPECIFIC NOT
NULL,
TableID BYTE(6),
TableIDTAI INTEGER,
CompressionMethod CHAR(8) CHARACTER SET LATIN NOT CASESPECIFIC,
CompressionState VARCHAR(2) CHARACTER SET LATIN NOT CASESPECIFIC,
EstCompRatio DECIMAL(5,2),
EstPctOfUncompDBs DECIMAL(5,2),
DBSize INTEGER,
DBsPerSize BIGINT,
PctOfDBsInSubtable DECIMAL(5,2),
MinNumRowsPerDB INTEGER,
AvgNumRowsPerDB INTEGER,
MaxNumRowsPerDB INTEGER,
LrgCyls BIGINT,
SmlCyls BIGINT)
PRIMARY INDEX ( TheDate ,TheTime ,TableID ,TableIDTAI ,DBSize ,
832
SQL 関数、演算子、式および述部
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
PctOfDBsInSubtable );
BTEQ -- Enter your SQL request or BTEQ command:
次の例に、L 表示オプションの PopulateFsysInfoTable マクロ実行からの BTEQ 出力
と、出力を強制的に画面に表示する target_database_name および
target_table_name の空の文字列を示します。
出力の列タイトル名は、ターゲット テーブルを使用して出力を格納せずに画面にリ
ダイレクトされるときに変わります。例えば、列名がターゲット テーブルで
"PctDBsIn1to8"とすると、出力が画面にリダイレクトされた場合、対応する列は"%
Of DBs In 1 to 8"となります。
PopulateFsysInfoTable マクロの後に戻される警告は、出力が画面に表示されるとき
に想定されている動作です。
注: BTEQ .foldline コマンドと.sidetitles コマンドは、戻されたデータ セットの列タ
イトルが横に表示され、これらの列の対応する値が列タイトルの横に表示されるよ
うにするために使用されています。この例では、7 つの出力行を示します。各行の
最初の列は DATE 列です。
exec
***
***
***
populatefsysinfotable('visuser','test3','showblocks','l','','');
Procedure has been executed.
Warning: 3212 The stored procedure returned one or more result sets.
Total elapsed time was 27 seconds.
*** ResultSet# 1 : 7 rows returned by "SYSLIB.POPULATEFSYSINFOTABLESP".
Date 13/12/22
Time 21:46:49
DB//Name visuser
Tbl//Name test3
TID
0000E90A0000
TID//TAI
0
Comp//Method MANUAL
Comp//State N
Est Comp//Ratio(%)
Est Uncomp//DBS(%)
DBSize
2
DBs Per//Size
4
% Of DBs In//SubTable 100.00
Min Rows//Per DB
1
Avg Rows//Per DB
1
Max Rows//Per DB
1
Lrg Cyls
4
Sml Cyls
Date 13/12/22
Time 21:46:49
DB//Name visuser
SQL 関数、演算子、式および述部
833
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
Tbl//Name
TID
TID//TAI
Comp//Method
Comp//State
Est Comp//Ratio(%)
Est Uncomp//DBS(%)
DBSize
DBs Per//Size
% Of DBs In//SubTable
Min Rows//Per DB
Avg Rows//Per DB
Max Rows//Per DB
Lrg Cyls
Sml Cyls
Date
Time
DB//Name
Tbl//Name
TID
TID//TAI
Comp//Method
Comp//State
Est Comp//Ratio(%)
Est Uncomp//DBS(%)
DBSize
DBs Per//Size
% Of DBs In//SubTable
Min Rows//Per DB
Avg Rows//Per DB
Max Rows//Per DB
Lrg Cyls
Sml Cyls
Date
Time
DB//Name
Tbl//Name
TID
TID//TAI
Comp//Method
Comp//State
Est Comp//Ratio(%)
Est Uncomp//DBS(%)
DBSize
DBs Per//Size
834
test3
0000E90A0000
1024
MANUAL
0
4
13/12/22
21:46:49
visuser
test3
0000E90A0000
1024
MANUAL
U
96
1
12.50
2221
2221
2221
13/12/22
21:46:49
visuser
test3
0000E90A0000
1024
MANUAL
U
98
1
SQL 関数、演算子、式および述部
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
% Of DBs
Min
Avg
Max
In//SubTable
Rows//Per DB
Rows//Per DB
Rows//Per DB
Lrg Cyls
Sml Cyls
Date
Time
DB//Name
Tbl//Name
TID
TID//TAI
Comp//Method
Comp//State
Est Comp//Ratio(%)
Est Uncomp//DBS(%)
DBSize
DBs Per//Size
% Of DBs In//SubTable
Min Rows//Per DB
Avg Rows//Per DB
Max Rows//Per DB
Lrg Cyls
Sml Cyls
Date
Time
DB//Name
Tbl//Name
TID
TID//TAI
Comp//Method
Comp//State
Est Comp//Ratio(%)
Est Uncomp//DBS(%)
DBSize
DBs Per//Size
% Of DBs In//SubTable
Min Rows//Per DB
Avg Rows//Per DB
Max Rows//Per DB
Lrg Cyls
Sml Cyls
Date
Time
DB//Name
SQL 関数、演算子、式および述部
12.50
2263
2263
2263
13/12/22
21:46:49
visuser
test3
0000E90A0000
1024
MANUAL
U
99
1
12.50
2297
2297
2297
13/12/22
21:46:49
visuser
test3
0000E90A0000
1024
MANUAL
U
102
1
12.50
2359
2359
2359
13/12/22
21:46:49
visuser
835
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
Tbl//Name test3
TID
0000E90A0000
TID//TAI
1024
Comp//Method MANUAL
Comp//State U
Est Comp//Ratio(%)
Est Uncomp//DBS(%)
DBSize
254
DBs Per//Size
4
% Of DBs In//SubTable
50.00
Min Rows//Per DB
5907
Avg Rows//Per DB
5907
Max Rows//Per DB
5907
Lrg Cyls
Sml Cyls
例: SHOWWHERE 出力のファイル システム情報テーブルの挿入 (オプション'S')
データを短形式出力のターゲット テーブルに挿入する場合:
exec dbc.populatefsysinfotable('dataload','t','showwhere','s','dataload','showw_s');
sel * from dataload.showw_s;
TheDate 15/01/28
TheTime 01:00:57.780000
DataBaseName dataload
TableName t
TableID 0000130B0000
TableIDTAI
0
Vproc -1
Drive -1
LrgCyls
10
SmlCyls
0
TableType PERM
Grade
GradePct
.00
VHCyls
0
HotCyls
0
WarmCyls
0
ColdCyls
10
CylsinSSD
0
TemperaturesMature Y
データを短形式の画面に挿入する場合:
exec dbc.populatefsysinfotable('dataload','t','showwhere','s','','');
*** Warning: 3212 The stored procedure returned one or more result sets.
*** Total elapsed time was 6 seconds
836
SQL 関数、演算子、式および述部
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
*** ResultSet# 1 : 1 rows returned by "SYSLIB.POPULATEFSYSINFOTABLESP".
Date
15/01/28
Time 09:01:46
DB Name dataload
Tbl Name t
TID
0000130B0000
TID_TAI
0
Vproc
-1
Drive
-1
Lrg Cyls
10
Sml Cyls
TableType PERM
Grade
Grade(%)
VH Cyls
Hot Cyls
Warm Cyls
Cold Cyls
10
Cyls in SSD
Temperatures Mature Y
例: SHOWWHERE 出力のファイル システム情報テーブルの挿入 (オプション'M')
データを中形式出力のターゲット テーブルに挿入する場合:
exec dbc.populatefsysinfotable('dataload','t','showwhere','m','dataload','showw_m');
sel * from dataload.showw_m;
TheDate 15/01/28
TheTime 01:03:12.160000
DataBaseName dataload
TableName t
TableID 0000130B0000
TableIDTAI
0
Vproc
0
Drive -1
LrgCyls
2
SmlCyls
0
TableType PERM
Grade
GradePct
.00
VHCyls
0
HotCyls
0
WarmCyls
0
ColdCyls
2
CylsinSSD
0
TemperaturesMature Y
TheDate 15/01/28
TheTime 01:03:12.160000
SQL 関数、演算子、式および述部
837
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
DataBaseName
dataload
TableName t
TableID 0000130B0000
TableIDTAI
0
Vproc
2
Drive -1
LrgCyls
3
SmlCyls
0
TableType PERM
Grade
GradePct
.00
VHCyls
0
HotCyls
0
WarmCyls
0
ColdCyls
3
CylsinSSD
0
TemperaturesMature Y
TheDate 15/01/28
TheTime 01:03:12.160000
DataBaseName dataload
TableName t
TableID 0000130B0000
TableIDTAI
0
Vproc
1
Drive -1
LrgCyls
2
SmlCyls
0
TableType PERM
Grade
GradePct
.00
VHCyls
0
HotCyls
0
WarmCyls
0
ColdCyls
2
CylsinSSD
0
TemperaturesMature Y
TheDate 15/01/28
TheTime 01:03:12.160000
DataBaseName dataload
TableName t
TableID 0000130B0000
TableIDTAI
0
Vproc
3
Drive -1
LrgCyls
3
SmlCyls
0
TableType PERM
Grade
GradePct
.00
VHCyls
0
HotCyls
0
838
SQL 関数、演算子、式および述部
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
WarmCyls
ColdCyls
CylsinSSD
TemperaturesMature
0
3
0
Y
データを中形式の画面に挿入する場合:
exec dbc.populatefsysinfotable('dataload','t','showwhere','m','','');
*** Warning: 3212 The stored procedure returned one or more result sets.
Date 15/01/28
Time 09:04:14
DB Name dataload
Tbl Name
t
TID
TID_TAI
Vproc
Drive
Lrg Cyls
Sml Cyls
TableType
Grade
Grade(%)
VH Cyls
Hot Cyls
Warm Cyls
Cold Cyls
Cyls in SSD
Temperatures Mature
0000130B0000
0
0
-1
2
PERM
2
Y
Date
15/01/28
Time
09:04:14
DB Name
dataload
Tbl Name
TID
t
0000130B0000
TID_TAI
0
Vproc
1
Drive
-1
Lrg Cyls
2
Sml Cyls
TableType
PERM
Grade
Grade(%)
VH Cyls
Hot Cyls
Warm Cyls
Cold Cyls
2
Cyls in SSD
Temperatures Mature
Date
Time
DB Name
SQL 関数、演算子、式および述部
Y
15/01/28
09:04:14
dataload
839
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
Tbl Name
TID
TID_TAI
Vproc
Drive
Lrg Cyls
Sml Cyls
TableType
Grade
Grade(%)
VH Cyls
Hot Cyls
Warm Cyls
Cold Cyls
Cyls in SSD
Temperatures Mature
Date
Time
DB Name
Tbl Name
TID
t
0000130B0000
0
2
-1
3
PERM
3
Y
15/01/28
09:04:14
dataload
t
0000130B0000
TID_TAI
0
Vproc
3
Drive
-1
Lrg Cyls
3
Sml Cyls
TableType
PERM
Grade
Grade(%)
VH Cyls
Hot Cyls
Warm Cyls
Cold Cyls
3
Cyls in SSD
Temperatures Mature
Y
例: SHOWWHERE 出力のファイル システム情報テーブルの挿入 (オプション'L')
データを長形式出力のターゲット テーブルに挿入する場合:
exec dbc.populatefsysinfotable('dataload','t','showwhere','l','dataload','showw_l');
sel * from dataload.showw_l;
TheDate
TheTime
DataBaseName
TableName
TableID
TableIDTAI
840
15/01/28
01:06:52.710000
dataload
t
0000130B0000
0
Vproc 2
Drive 2
SQL 関数、演算子、式および述部
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
LrgCyls
SmlCyls
TableType
3
0
PERM
Grade
GradePct .00
VHCyls
0
HotCyls
0
WarmCyls
0
ColdCyls
3
CylsinSSD
0
TemperaturesMature Y
TheDate 15/01/28
TheTime 01:06:52.710000
DataBaseName dataload
TableName t
TableID 0000130B0000
TableIDTAI
0
Vproc 1
Drive 1
LrgCyls
2
SmlCyls
0
TableType PERM
Grade
GradePct
.00
VHCyls
0
HotCyls
0
WarmCyls
0
ColdCyls
2
CylsinSSD
0
TemperaturesMature Y
TheDate 15/01/28
TheTime 01:06:52.710000
DataBaseName dataload
TableName t
TableID 0000130B0000
TableIDTAI
0
Vproc
0
Drive
0
LrgCyls
2
SmlCyls
0
TableType PERM
Grade
GradePct
.00
VHCyls
0
HotCyls
0
WarmCyls
0
ColdCyls
2
CylsinSSD
0
TemperaturesMature Y
TheDate 15/01/28
TheTime 01:06:52.710000
SQL 関数、演算子、式および述部
841
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
DataBaseName
TableName
TableID
TableIDTAI
dataload
t
0000130B0000
0
Vproc 3
Drive 3
LrgCyls
3
SmlCyls
0
TableType PERM
Grade
GradePct
.00
VHCyls
0
HotCyls
0
WarmCyls
0
ColdCyls
3
CylsinSSD
0
TemperaturesMature Y
データを長形式の画面に挿入する場合:
exec dbc.populatefsysinfotable('dataload','t','showwhere','l','','');
*** Warning: 3212 The stored procedure returned one or more result sets.
Date
15/01/28
Time 09:07:54
DB Name dataload
Tbl Name t
TID 0000130B0000
TID_TAI
0
Vproc
0
Drive
0
Lrg Cyls
2
Sml Cyls
TableType PERM
Grade
Grade(%)
VH Cyls
Hot Cyls
Warm Cyls
Cold Cyls
2
Cyls in SSD
Temperatures Mature
Y
Date
15/01/28
Time
09:07:54
DB Name
dataload
Tbl Name
TID
t
0000130B0000
TID_TAI
842
0
Vproc
1
Drive
1
SQL 関数、演算子、式および述部
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
Lrg Cyls
2
Sml Cyls
TableType PERM
Grade
Grade(%)
VH Cyls
Hot Cyls
Warm Cyls
Cold Cyls
2
Cyls in SSD
Temperatures Mature Y
Date 15/01/28
Time 09:07:54
DB Name dataload
Tbl Name t
TID 0000130B0000
TID_TAI
0
Vproc
2
Drive
2
Lrg Cyls
3
Sml Cyls
TableType
PERM
Grade
Grade(%)
VH Cyls
Hot Cyls
Warm Cyls
Cold Cyls
3
Cyls in SSD
Temperatures Mature
Y
Date
15/01/28
Time
09:07:54
DB Name
dataload
Tbl Name
t
TID
0000130B0000
TID_TAI
0
Vproc
3
Drive
Lrg Cyls
3
3
Sml Cyls
TableType
PERM
Grade
Grade(%)
VH Cyls
Hot Cyls
Warm Cyls
Cold Cyls
3
Cyls in SSD
Temperatures Mature Y
SQL 関数、演算子、式および述部
843
第 18 章 ファイル システム情報マクロ
PopulateFsysInfoTable
PopulateFsysInfoTable_ANSI
844
SQL 関数、演算子、式および述部
第 19 章
LOB 関数
概要
この章では、BLOB (バイナリ ラージ オブジェクト)データ タイプおよび CLOB (キャ
ラクタ ラージ オブジェクト)データ タイプで使用する関数について説明します。
EMPTY_BLOB
目的
空(つまり内容が 0 バイト)の BLOB (バイナリ ラージ オブジェクト)を返します。
構文
EMPTY_BLOB (
)
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
EMPTY_BLOB は埋め込みサービス システム関数です 。
引数のタイプ
EMPTY_BLOB は、入力引数を受け取りません。
SQL 関数、演算子、式および述部
845
第 19 章 LOB 関数
EMPTY_CLOB
結果のタイプ
EMPTY_BLOB は、戻り値のデータ タイプが BLOB AS LOCATOR のスカラー関数です。
例
以下の問合わせを実行します。
UPDATE employee SET picture = EMPTY_BLOB();
picture 列を空の BLOB で更新します。
関連トピック
埋め込みサービス関数のアクティブ化と呼び出しの詳細については、「埋め込みサー
ビス システムの関数 」を参照してください。
EMPTY_CLOB
目的
空(つまり内容が 0 バイト)の CLOB (キャラクタ ラージ オブジェクト)を返します。
構文
EMPTY_CLOB (
)
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
EMPTY_CLOB は埋め込みサービス システム関数です 。
846
SQL 関数、演算子、式および述部
第 19 章 LOB 関数
EMPTY_CLOB
引数のタイプ
EMPTY_CLOB は、入力引数を受け取りません。
結果のタイプ
EMPTY_CLOB は、戻り値のデータ タイプが LATIN 文字セットの CLOB AS LOCATOR
のスカラー関数です。
例
以下の問合わせを実行します。
UPDATE student SET essay = EMPTY_CLOB();
essay 列を空の CLOB で更新します。
関連トピック
埋め込みサービス関数のアクティブ化と呼び出しの詳細については、「埋め込みサー
ビス システムの関数 」を参照してください。
SQL 関数、演算子、式および述部
847
第 19 章 LOB 関数
EMPTY_CLOB
848
SQL 関数、演算子、式および述部
第 20 章
論理述部
概要
この章では、SQL 論理述部について説明します。
論理述部は、比較演算子および条件式とも呼ばれます。ANSI SQL 規格では、論理述
部を検索条件と呼びます。
関連トピック
比較演算子の全般情報については、「比較演算子と関数の概要」を参照してください。
論理述部について
論理述部は、オペランドを、1 つ以上の別のオペランドに照らしてテストし、論理
(ブール値の TRUE、FALSE、または UNKNOWN)結果を評価します。
テストされたオペランドは、以下のうちの 1 つです。
•
•
•
•
•
•
列名
リテラル
算術式
派生 PERIOD などの期間式
DEFAULT 関数
システム変数に評価される 、CURRENT_DATE または USER などの組み込み関数
論理述部を使用する場所
論理述部は、主として WHERE、ON、HAVING のいずれかの句で使用し、 SELECT
文の中でテーブル式を評価するときに、行が条件にかなっているかどうかを示します。
論理述部は検索形式の CASE 式の中の WHEN 句検索条件で使用することができます。
実行するテストのタイプは、述部の機能です。
SQL 関数、演算子、式および述部
849
第 20 章 論理述部
論理述部について
論理プリミティブの集合としての条件式
条件式は、論理述部プリミティブの集合とみなすことができます。その評価の順序
は、論理演算子 AND、OR、NOT と、括弧の配置によって制御されます。
表面的には同じように見える条件式でも、個々のプリミティブをどのようにグルー
プ化するかによって、まったく違った結果を生成することがあります。したがって、
条件式のロジックを計画するときには、注意が必要です。
SQL がサポートしている論理述部プリミティブを以下の表にまとめます。Match 条
件と Unique 条件がサポートされていない点に留意してください。
論理述部プリミ
ティブ条件
SQL 論理述部
関数
比較
SQL 比較演算子の完全なリ 2 つのデータ値が等しいかどうかや、大き
ストについては、「サポー さの違いをテストします。
トされる比較演算子」を参
照してください。
範囲
BETWEEN/NOT BETWEEN
データ値が、列データ値の指定の範囲に
入っているかどうかをテストします。
類似
LIKE
指定の文字列と列データ値のパターン照合
をテストします。
入力
IN/NOT IN
データ値が、指定の列値セットのメンバー
であるかどうかをテストします。
IN は、= ANY と等価です。
NOT IN は、<> ALL と等価です。
すべて
ALL
データ値が、指定のセット内のすべての列
値との比較において TRUE であるかどうか
をテストします。
いずれか
ANY
SOME
データ値が、指定のセット内のいずれかの
列値との比較において TRUE であるかどう
かをテストします。
存在有無
EXISTS/NOT EXISTS
指定のテーブルに少なくとも 1 つの行が
あるかどうかをテストします。
期間述部
期間述部演算子の完全なリ
ストについては、「期間関
数および演算子」を参照し
てください。
操作対象:
• 2 つの期間式
• 2 つの派生 PERIOD
• 1 つの期間式と 1 つの派生 PERIOD
• 1 つの期間式と 1 つの日時式
TRUE、FALSE、または UNKNOWN に評
価されます。
850
SQL 関数、演算子、式および述部
第 20 章 論理述部
論理述部について
論理述部プリミ
ティブ条件
SQL 論理述部
関数
OVERLAPS
2 つの期間(派生 PERIOD など)が重なって
いるかどうかをテストします。
IS UNTIL_CHANGED/IS
NOT UNTIL_CHANGED
期間式(派生 PERIOD など)の終了境界が
UNTIL_CHANGED か(または、でないか)を
テストします。
述部に関与するデータ タイプに対する制限事項
以下の表の制限事項が、述部に関与する演算と、CLOB、BLOB、および UDT タイプ
に対して適用されます。
データ タ 制約事項
イプ
BLOB
述部は BLOB または CLOB データ型をサポートしていません。
CLOB
BLOB を BYTE および VARBYTE タイプに、CLOB を CHARACTER および
VARCHAR タイプに明示的にキャストし、結果を述部の中で使用することがで
きます。
UDT
LIKE および OVERLAPS 論理述部は、UDT をサポートしません。
EXISTS および NOT EXISTS の場合:述部オペランドとして複数の UDT が関与す
る場合、それらは、同一タイプでなければなりません。これは、Teradata
Database が述部オペランドとして関与する UDT に対して暗黙タイプ変換を行
なわないためです。
この制限事項に対する対処策としては、CREATE CAST を使用して、UDT どうし
の間でキャストを行なう CAST を定義してから、述部が関与する演算内で明示
的に CAST 関数を呼び出します。
CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、
B035-1144>を参照してください。
BETWEEN/NOT BETWEEN および IN/NOT の場合:
• 述部オペランドとして複数の UDT が関与する場合、それらは、同一タイプ
でなければなりません。これは、Teradata Database が述部オペランドとし
て関与する UDT に対して暗黙タイプ変換を行なわないためです。
この制限事項に対する対処策としては、CREATE CAST を使用して、UDT ど
うしの間でキャストを行なう CAST を定義してから、述部が関与する演算内
で明示的に CAST 関数を呼び出します。
• 述部オペランドとして関与する UDT では、順序付けが定義されていなけれ
ばなりません。
SQL 関数、演算子、式および述部
851
第 20 章 論理述部
論理演算子と検索条件
データ タ 制約事項
イプ
Teradata Database は、ソース タイプが LOB でない DISTINCT 型 UDT の順
序付け機能を生成します。STRUCTURED 型 UDT またはソース タイプが LOB
である DISTINCT 型 UDT の順序付け定義を作成するときや、システム生成
の順序付け機能を置き換えるときは、CREATE ORDERING を使用します。
CREATE CAST と CREATE ORDERING の詳細は、<SQL データ定義言語 - 構文規
則および例、B035-1144>を参照してください。
述部に関与する DEFAULT 関数の制限事項
DEFAULT 関数は、列のデフォルト値を返します。これには、 列名を指定する形式
と、列名を省略する形式があります。述部は、両方の形式の DEFAULT 関数をサポー
トしていますが、DEFAULT 関数が列名を省略した場合は、次の条件が TRUE になり
ます。
• 述部が比較演算子を使用している。
• 比較には、単一の列参照のみを含めることができる。
• DEFAUL 関数が式の一部ではない。
たとえば、次の文は DEFAULT 関数を使用して Dept_No 列の値と Dept_No 列のデ
フォルト値を比較しています。比較操作には、単一の列参照が含まれるため、列名
が省略されていても、Teradata Database は DEFAULT 関数の列の文脈を派生できま
す。
SELECT * FROM Employee WHERE Dept_No < DEFAULT;
DEFAULT 関数が NULL と評価されると、述部は不明になり、WHERE 条件は FALSE
になります。
論理演算子と検索条件
検索条件または条件式は、以下の 1 つ以上の論理述部と接続している 1 つ以上の条
件項目からなっています。
•
•
•
•
•
•
•
•
852
比較演算子
BETWEEN/NOT BETWEEN
LIKE
IN/NOT IN
ALL または ANY/SOME
EXISTS/NOT EXISTS
OVERLAPS
IS NULL/IS NOT NULL
SQL 関数、演算子、式および述部
第 20 章 論理述部
論理演算子と検索条件
論理演算子
検索条件の結果を判別するために述部の結果に適用する演算子。
論理演算子には、以下のものがあります。
• AND
• NOT
• OR
以下に例を示します。
expression_1
OR
expression_2
OR
expression_3
NOT は、式などを否定するために使用します。
expression_1
AND NOT
expression_2
検索条件を使用する場所
検索条件は、WHERE、ON、QUALIFY、RESET WHEN または HAVING 句など、さ
まざまな SQL 句で使用できます。
HAVING 句で使用する場合は、集合演算子と一緒に論理式を使用できます。
たとえば次の問合わせは、HAVING 句の検索条件を使用して、部門番号が 100、
300、500、600 のいずれかであり、35,000 ドル≦給与の平均≦55,000 ドルであ
る部門を Employee テーブルから選択します。
SELECT AVG(Salary)
FROM Employee
WHERE DeptNo IN (100,300,500,600)
GROUP BY DeptNo
HAVING AVG(Salary) BETWEEN 35000 AND 55000 ;
評価の順序の規則
条件式の評価順序には、次の規則が適用されます。
• 式が同じ演算子を複数個含んでいる場合、その評価の順序は左から右です。
• 式に論理演算子の組み合わせが含まれている場合、評価の順序は以下のようにな
ります。
NOT
AND
OR
• 括弧を使用して、希望する評価の順序にすることができます。
• 条件式内の論理式は、常に左から右へと評価されるとは限りません。
SQL 関数、演算子、式および述部
853
第 20 章 論理述部
論理演算子と検索条件
論理式が評価される順序に条件式の正確性が左右される場合は、その条件式は避
けなければなりません。
たとえば、次の 2 つの式を比較します。
F2/(NULLIF(F1,0)) > 500
F1 <> 0 AND F2/F1 > 500
最初の式では、ゼロによる除算になることはありません。
2 番目の式では、その評価の順序によりゼロによる除算もあるため、エラーとな
ることがあります。
評価の結果
条件式内の各論理式は、以下の 3 つの結果のいずれかに評価されます。
• TRUE
• FALSE
• UNKNOWN
AND 真偽テーブル
以下の表は、検索条件の評価で使用される AND 論理を示したものです。
x FALSE
x UNKNOWN
x TRUE
y FALSE
FALSE
FALSE
FALSE
y UNKNOWN
FALSE
UNKNOWN
UNKNOWN
y TRUE
FALSE
UNKNOWN
TRUE
OR 真偽テーブル
以下の表は、検索条件の評価で使用される OR 論理を示したものです。
x FALSE
x UNKNOWN
x TRUE
y FALSE
FALSE
UNKNOWN
TRUE
y UNKNOWN
UNKNOWN
UNKNOWN
TRUE
y TRUE
TRUE
true
TRUE
NOT 真偽テーブル
以下の表は、検索条件の評価で使用される NOT 論理を示したものです。
結果
854
SQL 関数、演算子、式および述部
第 20 章 論理述部
論理演算子と検索条件
x FALSE
TRUE
x UNKNOWN
UNKNOWN
x TRUE
FALSE
SUBQUERY に関する制限
Subquery での検索条件の述部で SELECT AND CONSUME 文を指定できません。
検索条件における論理演算子の例
以下の例は、検索条件における論理演算子の使用法を示したものです。
次の例は、検索条件を使用して、高校を卒業していて少なくとも 12 年の学歴があ
るか、2 年を超える職務経験がある者の名前を Profile というユーザー テーブルか
ら選択します。
SELECT Name
FROM Profile
WHERE YrsExp > 2
OR (EdLev >= 12 AND Grad = 'Y') ;
次の文は、管理者番号が 10007 または 10012 のすべての社員のリストを要求しま
す。管理者情報は Department (部門)テーブルに含まれ、従業員情報は Employee
テーブルに含まれています。この要求は、2 つのテーブルの共通の列である DeptNo
でテーブルを結合させることによって処理します。
参照における曖昧さを避けるために、DeptNo を完全に修飾しなければなりません。
さらに、OR のある IN 条件をまとめるために、追加の括弧が必要なことにも注意す
る必要があります。それがないと、結果は直積(デカルト積)となります。
SELECT EmpNo,Name,JobTitle,Employee.DeptNo,Loc
FROM Employee,Department
WHERE (Employee.DeptNo=Department.DeptNo)
AND ((Employee.DeptNo IN
(SELECT Department.DeptNo
FROM Department
WHERE MgrNo=10007))
OR (Employee.DeptNo IN
(SELECT Department.DeptNo
FROM Department
WHERE MgrNo=10012))) ;
Department テーブルが次の行を含んでいると想定します。
SQL 関数、演算子、式および述部
855
第 20 章 論理述部
ANY/ALL/SOME 数量詞
DeptNo
Department
Loc
MgrNo
100
Administration
NYC
10005
600
Manufacturing
CHI
10007
500
Engineering
ATL
10012
300
Exec Office
NYC
10018
700
Marketing
NYC
10021
結合文は、次の結果を返します。
EmpNo
Name
JobTitle
DeptNo
Loc
10012
Watson L
Vice Pres
500
ATL
10004
Smith T
Engineer
500
ATL
10014
Inglis C
Tech Writer
500
ATL
10009
Marston A
Secretary
500
ATL
10006
Kemper R
Assembler
600
CHI
10015
Omura H
Programmer
500
ATL
10007
Aguilar J
Manager
600
CHI
10010
Reed C
Technician
500
ATL
10013
Regan R
Purchaser
600
CHI
10016
Carter J
Engineer
500
ATL
10019
Newman P
Test Tech
600
CHI
ANY/ALL/SOME 数量詞
目的
比較演算または IN/NOT IN 述部での数量化を可能にします。
856
SQL 関数、演算子、式および述部
第 20 章 論理述部
ANY/ALL/SOME 数量詞
構文
,
expression
comparison_operator
IN
NOT
expression
comparison_operator
IN
NOT
OR
literal
ALL
ANY
SOME
(
ALL
ANY
SOME
( subquery )
)
Literals
syntax
Subquery
syntax
,
(
expression
)
comparison_operator
IN
NOT
ALL
ANY
SOME
( subquery )
構文要素
expression
値を指定する式。
comparison_operator
式または式のリストとリスト(リテラル構文)内のリテラルまたは副問合わせ(副問合
わせ構文)を比較して、TRUE、FALSE、または UNKNOWN の結果を生成する比較演
算子。
[NOT] IN
式、リテラル(リテラル構文)のリスト内の式のリスト、または副問合わせ(副問合わ
せ構文)が存在するかどうかをテストして、TRUE、FALSE、または UNKNOWN の結
果を生成する述部。
literal
定数値。
subquery
式または式のリストで指定された数と同じ数の式を選択する副問合わせ。
Subquery で SELECT AND CONSUME 文を指定することはできません。
ANSI への準拠
ANY、SOME、および ALL は、ANSI SQL:2011 準拠の数量詞です。
SQL 関数、演算子、式および述部
857
第 20 章 論理述部
ANY/ALL/SOME 数量詞
ANY/ALL/SOME 数量詞とリテラル構文
リテラルのリストが数量詞と比較演算または IN/NOT IN 述部と共に使用される場
合、結果は以下のように決定されます。
述部
指定
結果が真になる場合
比較演算
ALL
expression とリスト内のすべてのリテラルとの比
較の結果が真になる場合
ANY
expression とリスト内のいずれかのリテラルとの
比較の結果が真になる場合
SOME
IN
ALL
expression はリスト内のすべてのリテラルに等し
くなります。
ANY
expression はリスト内いずれのリテラルとも等し
くなります。
SOME
NOT IN
ALL
expression はリスト内のいずれのリテラルにも等
しくなりません。
ANY
expression はリスト内いずれのリテラルとも等し
くなりません。
SOME
比較演算では、暗黙の変換の規則は比較演算子の規則と同じです。
expression が NULL に評価されると、結果は不明とみなされます。
ANY/ALL/SOME 数量詞と SUBQUERY 構文
Subquery が数量詞と比較演算または IN/NOT IN 述部と共に使用される場合、結果
は以下のように決定されます。
指定する数量詞 述部
結果
条件
ALL
比較演算
TRUE
expression によって戻された値セットに含ま
れるすべての値と subquery との比較の結果が
真になる場合。
IN
TRUE
expression は、subquery によって戻される値
のセット内のすべての値に等しくなります。
NOT IN
TRUE
expression は、subquery によって戻される値
のセット内のどの値にも等しくなりません。
比較演算
TRUE
subquery が値を返さない場合。
ALL
IN
858
SQL 関数、演算子、式および述部
第 20 章 論理述部
ANY/ALL/SOME 数量詞
指定する数量詞 述部
結果
条件
比較演算
TRUE
expression によって戻された値セットに含ま
れる少なくとも 1 つの値と subquery との比
較が真になる場合。
IN
TRUE
expression は、subquery によって戻される値
のセット内の 1 つ以上の値に等しくなります。
NOT IN
TRUE
expression は、subquery によって返される値
のセット内の 1 つ以上の値に等しくなりませ
ん。
比較演算
FALSE
subquery が値を返さない場合。
NOT IN
ANY
SOME
IN
NOT IN
ANY/ALL/SOME と比較演算子の使用に相当するもの
次の表に、ANY/ALL/SOME 数量詞に相当するものを示します。ここで op は比較演
算子を表わします。
式
等価である式
x op ALL (:a, :b, :c)
(x op :a) AND (x op :b) AND (x op :c)
x op ANY (:a, :b, :c)
(x op :a) OR (x op :b) OR (x op :c)
x op SOME (:a, :b, :c)
以下に例を示します。
式
等価である式
x < ALL (:a, :b, :c)
(x < :a) AND (x < :b) AND (x < :c)
x > ANY (:a, :b, :c)
(x > :a) OR (x > :b) OR (x > :c)
x > SOME (:a, :b, :c)
ANY/ALL/SOME と IN/NOT IN の使用に相当するもの
次の表に、ANY/ALL/SOME 数量詞に相当するものを示します。ここで op は IN ま
たは NOT IN を表わします。
式
等価である式
NOT (x op ALL (:a, :b, :c))
x NOT op ANY (:a, :b, :c)
SQL 関数、演算子、式および述部
859
第 20 章 論理述部
ANY/ALL/SOME 数量詞
式
等価である式
x NOT op SOME (:a, :b, :c)
NOT (x op ANY (:a, :b, :c))
x NOT op ALL (:a, :b, :c)
NOT (x op SOME (:a, :b, :c))
op が NOT IN の場合は、NOT op は IN であり、NOT NOT IN ではありません。
以下に例を示します。
式
等価である式
NOT (x IN ANY (:a, :b, :c))
x NOT IN ALL (:a, :b, :c)
NOT (x IN ALL (:a, :b, :c))
x NOT IN ANY (:a, :b, :c)
NOT (x NOT IN ANY (:a, :b, :c))
x IN ALL (:a, :b, :c)
NOT (x NOT IN ALL (:a, :b, :c))
x IN ANY (:a, :b, :c)
例
例
以下の文は、比較演算子と ANY 数量詞を使って、部門 100、300、500 に所属して
いる社員の社員番号、名前、部門番号を選び出します。
式
等価である式
SELECT EmpNo, Name, DeptNo
FROM Employee
WHERE DeptNo = ANY (100,300,500) ;
SELECT EmpNo, Name, DeptNo
FROM Employee
WHERE (DeptNo = 100)
OR (DeptNo = 300)
OR (DeptNo = 500) ;
且つ
SELECT EmpNo, Name, DeptNo
FROM Employee
WHERE DeptNo IN (100,300,500) ;
例
ALL 数量詞を指定する比較操作で subquery を使用する例を次に示します。
SELECT EmpNo, Name, JobTitle, Salary, YrsExp
FROM Employee
WHERE (Salary, YrsExp) >= ALL
(SELECT Salary, YrsExp FROM Employee) ;
860
SQL 関数、演算子、式および述部
第 20 章 論理述部
BETWEEN/NOT BETWEEN
例
この例は、ANY/ALL/SOME の動作を示したものです。
テーブルの定義と内容は、次のものを想定します。
CREATE
INSERT
INSERT
INSERT
INSERT
INSERT
TABLE t (x INTEGER);
t (1);
t (2);
t (3);
t (4);
t (5);
問合わせ
結果
SELECT * FROM t WHERE x IN ANY (1,2)
1, 2
SELECT * FROM t WHERE x = SOME (1,2)
1, 2
SELECT * FROM t WHERE x NOT IN ALL (1,2)
3, 4, 5
SELECT * FROM t WHERE NOT (x IN ANY (1,2))
3, 4, 5
SELECT * FROM t WHERE NOT (x = SOME (1,2))
3, 4, 5
SELECT * FROM t WHERE x NOT IN SOME (1, 2)
1, 2, 3, 4, 5
SELECT * FROM t WHERE x NOT = ANY (1, 2)
1, 2, 3, 4, 5
SELECT * FROM t WHERE x IN ALL (1,2)
行なし
SELECT * FROM t WHERE NOT (x NOT IN SOME (1,2))
行なし
SELECT * FROM t WHERE x = ALL (1,2)
行なし
SELECT * FROM t WHERE NOT (x NOT = ANY (1,2))
行なし
BETWEEN/NOT BETWEEN
目的
式の値が、2 つの別の式値の間にあるかどうかをテストします。
構文
expr1
BETWEEN
expr2
AND
expr3
NOT
SQL 関数、演算子、式および述部
861
第 20 章 論理述部
EXISTS/NOT EXISTS
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
使用上の注意
BETWEEN テストは、以下の条件が真の場合に、合格となります。
expression_2 <= expression_1 <= expression_3
BETWEEN テストが失敗すると、行は返されません。
BETWEEN テストは、2 つの別個の論理比較として処理されます。
expression_1 >= expression_2 AND expression_1 <= expression_3.
式
等価である式
x BETWEEN y AND z
((x >= y) AND (x <=z))
expression_1 は実際には 2 回評価されるため、RANDOM のような非確定的な関数
を使用した場合、予期しない結果が生じることがあることに注意してください。
例
次の例は、HAVING 句の検索条件を使用して、部門番号が 100、300、500、600
のいずれかであり、35,000 ドル≦給与の平均≦55,000 ドルである部門を Employee
テーブルから選択します。
SELECT AVG(Salary)
FROM Employee
WHERE DeptNo IN (100,300,500,600)
GROUP BY DeptNo
HAVING AVG(Salary) BETWEEN 35000 AND 55000 ;
EXISTS/NOT EXISTS
目的
指定のテーブル(普通は派生テーブル)をテストして、少なくとも 1 つの行があるかど
うかを調べます(つまり、そのテーブルが空でないかどうかをテストします)。
EXISTS は、WHERE 句内の検索条件の述部としてサポートされています。
構文
EXISTS
subquery
NOT
862
SQL 関数、演算子、式および述部
第 20 章 論理述部
EXISTS/NOT EXISTS
構文要素
subquery
式または式のリストで指定された数と同じ数の式を選択する副問合わせ。
Subquery で SELECT AND CONSUME 文を指定することはできません。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
使用上の注意
EXISTS 述部の機能は、subquery の結果をテストすることです。
Subquery の実行によって応答行が返された場合は、WHERE 条件が満たされている
とみなされます。
EXISTS 述部に NOT 修飾子を使用すると、テストの意味が逆になります。Subquery
の実行が実際に応答行を返していません。むしろ、要求された場合に応答が返され
たかどうかを示すブール値が返されます。
SUBQUERY に関する制限
Subquery で SELECT AND CONSUME 文を指定することはできません。
EXISTS/NOT EXISTS と IN/NOT IN の関係
EXISTS 述部は、subquery の指定の行があるかどうかをテストします。一般に、
EXISTS は、比較を IN と置き換えるため、NOT EXISTS は比較を NOT IN と置き換
えるために使用できますが、その逆は当てはまりません。EXISTS 述部や NOT EXISTS
述部、あるいはその両方を使用しないと解決できない問題もあります。例えば、
「For ALL」を参照してください。
例
t1 において、x1 列の値が t2 の x2 列の値と等しい行を選び出すには、以下のいず
れかの問合わせを使用します。
SELECT *
FROM t1
WHERE x1 IN
(SELECT x2
FROM t2);
SELECT *
SQL 関数、演算子、式および述部
863
第 20 章 論理述部
EXISTS/NOT EXISTS
FROM t1
WHERE EXISTS
(SELECT *
FROM t2
WHERE t1.x1=t2.x2);
t1 において、x1 列の値が t2 の x2 列のいずれの値とも等しくない行を選び出すに
は、以下のいずれかの問合わせを使用します。
SELECT *
FROM t1
WHERE x1 NOT IN
(SELECT x2
FROM t2);
SELECT *
FROM t1
WHERE NOT EXISTS
(SELECT *
FROM t2
WHERE t1.x1=t2.x2);
SELECT 'T1 is not empty'
WHERE EXISTS
(SELECT *
FROM t1);
SELECT 'T1 is empty'
WHERE NOT EXISTS
(SELECT *
FROM t1);
EXISTS 述部と NOT IN +NULL の比較
以下の条件が真の場合は、NOT IN の代わりに NOT EXISTS 述部を使用してください。
• NOT IN 条件のいずれかの列が null 可能として定義されている。
• 主問合わせから、NOT IN 条件のいずれかの列に null が入っているいずれかの行
が常に返される必要がある。
• Subquery の選択リストで返される null によって、主問合わせが行を返すのが妨
げられてはならない。
たとえば、以下の問合わせについてこれまでのすべての条件が真になる場合は、NOT
IN ではなく NOT EXISTS を使用してください。
SELECT dept, DeptName
FROM Department
864
SQL 関数、演算子、式および述部
第 20 章 論理述部
EXISTS/NOT EXISTS
WHERE Dept NOT IN
(SELECT Dept
FROM Course);
NOT EXISTS を使用したバージョンは次のようになります。
SELECT dept, DeptName
FROM Department
WHERE NOT EXISTS
(SELECT Dept
FROM Course
WHERE Course.Dept=Department.Dept);
つまり、Course.Dept と Department.Dept のいずれかが null 可能であり、
Department から Dept の null の行が返される必要があり、Course.Dept の null が、
Department から行が返されるのを妨げてはならないということです。
ALL の場合
ネストした 2 つの NOT EXISTS を使って、「列内のどの(論理∀)値にも、(論理∃)が
存在する…」という概念を具体化した SELECT 文を記述することができます。
例えば、図書館にすべての出版社の本が少なくとも 1 冊存在する場合に「TRUE」
値を選択する問合わせは、以下のように記述できます。
SELECT 'TRUE'
WHERE NOT EXISTS
(SELECT *
FROM publisher pb
WHERE NOT EXISTS
(SELECT *
FROM book bk
WHERE pb.PubNum=bk.PubNum);
NOT EXISTS 句とストアド プロシージャ
ストアド プロシージャの条件式がローカル変数、パラメータ、またはカーソルの別
名も参照する場合、その条件式に NOT EXISTS 句を指定することはできません。
NOT EXISTS と再帰的問合わせ
NOT EXISTS は、再帰的問合わせの再帰文では使用できません。ただし、再帰的問
合わせの中の非再帰シード文で NOT EXISTS 述部を指定することができます。
SQL 関数、演算子、式および述部
865
第 20 章 論理述部
EXISTS/NOT EXISTS
例
例: EXISTS と相関 SUBQUERY
いずれかの部門が提供するクラスの少なくとも 1 つに登録しているすべての生徒の
名前を選び出してみましょう。
SELECT SName, SNo
FROM student s
WHERE EXISTS
(SELECT *
FROM department d
WHERE EXISTS
(SELECT *
FROM course c, registration r, class cl
WHERE c.Dept=d.Dept
AND c.CNo=r.CNo
AND s.SNo=r.SNo
AND r.CNo=cl.CNo
AND r.Sec=cl.Sec));
生徒テーブルの内容は、以下のようになります。
Sname
SNo
Helen Chu
1
Alice Clark
2
Kathy Kim
3
Tom Brown
4
部門テーブルの内容は、以下のようになります。
Dept
DeptName
100
Computer Science
200
Physic
300
Math
400
Science
コース テーブルの内容は、以下のようになります。
866
CNo
Dept
10
100
11
100
SQL 関数、演算子、式および述部
第 20 章 論理述部
EXISTS/NOT EXISTS
CNo
Dept
12
200
13
200
14
300
クラス テーブルの内容は、以下のようになります。
CNo
Sec
10
1
11
1
12
1
13
1
14
1
登録テーブルの内容は、以下のようになります。
CNo
SNo
Sec
10
1
1
10
2
1
11
3
1
12
1
1
13
2
1
14
1
1
以下の行が返されます。
SName
----------Helen Chu1
Alice Clark
Kathy Kim
SNo
--*
2
3
例: NOT EXISTS と相関 SUBQUERY
コースを提供している各部門が提供するクラスの少なくとも 1 つに登録しているす
べての生徒の名前を選び出してみましょう。
SELECT SName, SNo
FROM student s
WHERE NOT EXISTS
(SELECT *
SQL 関数、演算子、式および述部
867
第 20 章 論理述部
IN/NOT IN
FROM department d
WHERE d.Dept IN
(SELECT Dept
FROM course) AND NOT EXISTS
(SELECT *
FROM course c, registration r, class cl
WHERE c.Dept=d.Dept
AND c.CNo=r.CNo
AND s.SNo=r.SNo
AND r.CNo=cl.CNo
AND r.Sec=cl.Sec)));
「例: EXISTS と相関 SUBQUERY」のテーブルの内容にあるように、以下の行が返され
ます。
SName
----Helen Chu
SNo
--1
関連トピック
詳細は、以下を参照してください。
• 相関 subquery についての詳細な説明は、< SQL データ操作言語、B035-1146>の
「相関 SUBQUERY」を参照してください。
IN/NOT IN
目的
比較可能な集合の中に式または式のリストの値が存在するかどうかを次のいずれか
の方法でテストします。
• 式の値を、明示したリテラルのリスト内の値と比較します。
• 式のリスト内の値を、subquery 内の対応する式の集合内の値と比較します。
構文
expression_1
IN
expression_2
,
NOT
OR
(
literal
signed_literal_1
)
TO
signed_literal_2
datetime_literal
868
SQL 関数、演算子、式および述部
第 20 章 論理述部
IN/NOT IN
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
リテラルのリストでの TO の使用は、ANSI 標準の Teradata 拡張機能です。
expression IN および NOT IN expression またはリテラル
構文要素
expression_1
expression_2 内で、またはリテラル、signed_literal TO signed_literal、または
datetime_literal のいずれかで指定されたリテラルの明示リスト内で存在がテストさ
れる式の値。
IN
含まれているものをテストするのか、含まれていないものをテストするのかを指定
します。
代用可能
• IN ANY
• IN SOME
• = ANY
• = SOME
IN(ただしリテラルのリストが指定されていてそこに signed_literal_1 TO
signed_literal_2 が含まれる場合を除く)
代用可能
• <> ALL
• NOT IN ALL
expression_2
expression_1 の存在がテストされる値。
literal
• リテラル
• マクロ パラメータ
• TIME や DATE などの組み込み値
signed_literal_1 TO signed_literal_2
リテラルの範囲。
datetime_literal
ANSI DateTime リテラル。
SQL 関数、演算子、式および述部
869
第 20 章 論理述部
IN/NOT IN
結果
IN がリテラルのリストともに使用された場合、expression_1 の値が次のときに結果
が真になります。
• リスト内のいずれかのリテラルに等しい。
• signed_literal_1 と signed_literal_2 の間(これらの値を含む)にある
(signed_literal_1 が signed_literal_2 より小さいか等しい場合)。
• signed_literal_2 と signed_literal_1 の間(これらの値を含む)にある
(signed_literal_2 が signed_literal_1 より小さい場合)
expression_1 の値が NULL の場合、結果は不明となります。
expression_1 の値が非 NULL の場合は、結果が真意なるためのいずれの条件も満た
されないので、結果は偽になります。
この形式を使用すると、式がリテラル リスト内のいずれかと等しい場合、IN 検索条
件が満たされます。式がリテラルのリスト内のどの値とも等しくない場合は、NOT
IN 条件が満たされます。
条件が真になる形式
条件
expression_1 IN expression_2
expression_1 = expression_2
expression_1 NOT IN expression_2
expression_1 <> expression_2
expression_1 IN (const_1, const_2)
(expression_1 = const_1) OR (expression_1 =
const_2)
expression_1 NOT IN (const_1,
const_2)
(expression_1 <> const_1) AND (expression_1 <>
const_2)
expression_1 IN (signed_const_1 TO (signed_const_1 <= expression_1) AND
signed_const_2)
(expression_1 <= signed_const_2)
signed_const_1 <= signed_const_2
expression_1 IN (signed_const_1 TO (signed_const_2 <= expression_1) AND
signed_const_2)
(expression_1 <= signed_const_1)
signed_const_2 < signed_const_1
expression_1 NOT IN
(expression_1 < signed_const_1) OR (expression_1 >
(signed_const_1 TO signed_const_2) signed_const_2)
signed_const_1 <= signed_const_2
expression_1 NOT IN
(expression_1 < signed_const_2) OR (expression_1 >
(signed_const_1 TO signed_const_2) signed_const_1)
signed_const_2 < signed_const_1
以下に例を示します。
870
SQL 関数、演算子、式および述部
第 20 章 論理述部
IN/NOT IN
文
等価である文
SELECT DeptNo
FROM Department
WHERE DeptNo IN (500, 600);
SELECT DeptNo
FROM Department
WHERE (DeptNo = 500)
OR (DeptNo = 600);
UPDATE Employee
SET Salary=Salary + 200
WHERE DeptNo NOT IN (100, 700);
UPDATE Employee
SET Salary=Salary + 200
WHERE (DeptNo ^= 100)
AND (DeptNo ^= 700);
使用上の注意
IN が単一語の演算子と共に使用される場合、その演算子は、リテラル、または式と
することができます。複数語の演算子が使用される場合には、その演算子はリテラ
ルから構成されなければなりません。式を使用することはできません。
expression_1 データ型とリテラル値は互換性がなければなりません。暗黙の変換の
規則は、比較演算子のそれと同じです。
IN/NOT IN と EXISTS/NOT EXISTS の関係
一般に、EXISTS は、比較を IN と置き換えるため、NOT EXISTS は比較を NOT IN
と置き換えるために使用できますが、その逆は当てはまりません。問題によっては、
EXISTS 述部または NOT EXISTS 述部を使って解決しなければならないものもありま
す。EXISTS および NOT EXISTS については、「EXISTS / NOT EXISTS」を参照して
ください。
IN/NOT IN、NOT、および ANY/ALL/SOME の使用に相当するもの
次の表に、ANY/ALL/SOME 数量詞に相当するものを示します。ここで op は IN ま
たは NOT IN を表わします。
使用法
等価である式
NOT (x op ALL (:a, :b, :c))
x NOT op ANY (:a, :b, :c)
x NOT op SOME (:a, :b, :c)
NOT (x op ANY (:a, :b, :c))
x NOT op ALL (:a, :b, :c)
NOT (x op SOME (:a, :b, :c))
NOT (x op (:a, :b, :c))
x NOT op (:a, :b, :c)
相当するものとして示しているものの中で、op が NOT IN の場合は、NOT op は IN
であり、NOT NOT IN ではありません。
以下に例を示します。
SQL 関数、演算子、式および述部
871
第 20 章 論理述部
IN/NOT IN
式
等価である式
NOT (x IN ANY (:a, :b, :c))
x NOT IN ALL (:a, :b, :c)
NOT (x IN ALL (:a, :b, :c))
x NOT IN ANY (:a, :b, :c)
NOT (x NOT IN ANY (:a, :b, :c))
x IN ALL (:a, :b, :c)
NOT (x NOT IN ALL (:a, :b, :c))
x IN ANY (:a, :b, :c)
NOT (x IN (:a, :b, :c))
x NOT IN (:a, :b, :c)
NOT (x NOT IN (:a, :b, :c))
x IN (:a, :b, :c)
構文 2: expression IN および NOT IN subquery
この IN および NOT IN の構文は、次のいずれかの形式です。
expression
IN
(
)
subquery
NOT
,
(
expression
IN
)
(
subquery
)
NOT
構文要素
expression
subquery 内で存在がテストされる式の値。
subquery
示された検索基準を満たす値を返す SELECT 文。
subquery は、次のようにする必要があります。
• 括弧で囲まなければなりません。
• セミコロンで終了してはなりません。
• 式のリストで定義された数と同じ数の式を選択しなければなりません。
• SELECT AND CONSUME 文を指定できません。
IN での Null の動作
Subquery に IN が使用されている場合には、文の結果に null の列値は含まれません。
NOT IN での Null の動作
次の表は、各種の形式の問合わせにおける NOT IN での null の動作をまとめたもの
です。
872
SQL 関数、演算子、式および述部
第 20 章 論理述部
IN/NOT IN
問合わせの形式
条件
SELECT ... FROM T1
WHERE x NOT IN
(SELECT y FROM T2);
y の値の 1 つが null の 問合わせ全体を通じて T1
場合
の行は返されません。
SELECT ...FROM T1
WHERE expression_list_1 NOT IN
(SELECT expression_list_2
FROM T2);
Subquery によって行 x に null を含む T1 の行
が返される場合、およ は返されません。
び x に null が含まれ
る場合
expression_list_2 の最 どの行も T1 から返され
初のフィールドが null ません。
の場合
expression_list_2 の最 行が返されます。
初のフィールド以外の
フィールドに null があ
る場合
Subquery が行を返す
場合、および
expression_list_1 の最
初のフィールドに null
がある場合
SELECT ... FROM T1
WHERE expression_list_1 NOT IN
(SELECT expression_list_2
FROM T2
WHERE search_condition);
結果
expression_list_1 の最初
のフィールドに null を含
む T1 の行は、返されま
せん。
expression_list_1 の最初
search_condition が行 のフィールドに NULL が
を返さない場合
あるものも含めて、T1 の
すべての行が返されます。
T2 に対する
NOT IN 句とストアド プロシージャ
ストアド プロシージャの条件式がローカル変数、パラメータ、またはカーソルの別
名も参照する場合、その条件式に NOT IN 句を指定することはできません。
NOT IN と再帰的問合わせ
NOT IN は、再帰的問合わせの再帰文では使用できません。ただし、再帰的問合わ
せの中の非再帰シード文で NOT IN 述部を指定することができます。
問合わせに大きな NOT IN 句を使用すると失敗することがある
IN または NOT IN 句に多数の引数を含む問合わせは、失敗することがあります。
たとえば、IN 句に 16000 の引数を使った次の問合わせを実行して、失敗したとし
ます。
SQL 関数、演算子、式および述部
873
第 20 章 論理述部
IN/NOT IN
SELECT MAX(emp_num)
FROM employee
WHERE emp_num IN(1,2,7,8,...,121347);
この問題が起きたときの回避策は、IN 句の中の引数を含めた一時テーブルまたは揮
発性テーブルを使用して問合わせを書き直すことです。
以下の文を使用すると同じ選択を行なうことができますが、失敗は起こりません。
CREATE VOLATILE TABLE temp_IN_values (
in_value INTEGER) ON COMMIT PRESERVE ROWS;
INSERT INTO temp_IN_values
SELECT emp_num
FROM table_with_emp_num_values;
新しい問合わせは、次のようになります。
SELECT MAX(emp_num)
FROM employee AS e JOIN temp_IN_values AS en
ON (e.emp_num = en.in_value);
例
例: Atlanta の従業員の検索
次の文は、Atlanta で働くすべての社員の名前を検索します。
SELECT Name
FROM Employee
WHERE DeptNo IN
(SELECT DeptNo
FROM Department
WHERE Loc = 'ATL');
例: DeptNo に 2 つの列がある場合の検索
似た例ですが、DeptNo が 2 つの列に分けられていると想定すると、次の文を使用す
ることができます。
SELECT Name
FROM Employee
WHERE (DeptNoA, DeptNoB) IN
(SELECT DeptNoA, DeptNoB
FROM Department
WHERE Loc = 'LAX') ;
874
SQL 関数、演算子、式および述部
第 20 章 論理述部
IS NULL/IS NOT NULL
例: IN/NOT IN およびリテラルのリストの使用
この例は、リテラル リストを使用した IN/NOT IN の動作を示しています。
テーブルの定義と内容は、次のものを想定します。
CREATE
INSERT
INSERT
INSERT
INSERT
INSERT
TABLE t (x INTEGER);
t (1);
t (2);
t (3);
t (4);
t (5);
問合わせ
結果
SELECT * FROM t WHERE x IN (1,2)
1, 2
SELECT * FROM t WHERE x IN ANY (1,2)
1, 2
SELECT * FROM t WHERE NOT (x NOT IN (1,2))
1, 2
SELECT * FROM t WHERE x NOT IN (1,2)
3, 4, 5
SELECT * FROM t WHERE x NOT IN ALL (1,2)
3, 4, 5
SELECT * FROM t WHERE NOT (x IN (1, 2))
3, 4, 5
SELECT * FROM t WHERE NOT (x IN ANY (1,2))
3, 4, 5
SELECT * FROM t WHERE x IN (3 TO 5)
3, 4, 5
SELECT * FROM t WHERE x NOT IN SOME (1, 2)
1, 2, 3, 4, 5
SELECT * FROM t WHERE x IN (1, 2 TO 4, 5)
1, 2, 3, 4, 5
SELECT * FROM t WHERE x IN ALL (1,2)
行なし
SELECT * FROM t WHERE NOT (x NOT IN SOME (1,2))
行なし
SELECT * FROM t WHERE x NOT IN (1 TO 5)
行なし
IS NULL/IS NOT NULL
目的
式の中に NULL 値を探したり、除外したりします。
構文
expression
IS
NULL
NOT
SQL 関数、演算子、式および述部
875
第 20 章 論理述部
IS NULL/IS NOT NULL
構文要素
expression
null のテスト対象の値を指定する式。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
例
例
部門を割り当てられていないすべての社員の名前を検索するには、次の文を入力し
ます。
SELECT Name
FROM Employee
WHERE DeptNo IS NULL;
この問合わせの結果は、DeptNo フィールドが null であるすべての社員の名前です。
例
その反対に、部門が割り当てられているすべての社員の名前を検索するには、次の
文を入力します。
SELECT Name
FROM Employee
WHERE DeptNo IS NOT NULL;
この問合わせは、DeptNo フィールドの値が非 NULL の従業員全員の名前を返します。
例: 同じ文中での NULL および NOT-NULL の検索
同じ文中で NULL 値と非 NULL 値を検索するには、NULL の検索条件を別に示さな
ければなりません。
例えば、肩書が Manager または Vice Pres 以外のすべての社員の名前と、JobTitle
列が null のすべての社員の名前を選択するには、次の文を入力します。
SELECT Name, JobTitle
FROM Employee
WHERE (JobTitle NOT IN ('Manager' OR 'Vice Pres'))
OR (JobTitle IS NULL) ;
876
SQL 関数、演算子、式および述部
第 20 章 論理述部
LIKE
例: Null を含む可能性のあるテーブルの検索
null 値を含んでいるかもしれないテーブルの検索時には、特に注意しなければなり
ません。たとえば、EdLev 列が null 値を含んでいる場合、次の文を入力すると、結
果には学歴が 16 年よりも少ない社員の名前だけが含まれます。
SELECT Name, EdLev
FROM Employee
WHERE (EdLev < 16) ;
文の結果に null を含めるには、文を次のように構成します。
SELECT Name, EdLev
FROM Employee
WHERE (EdLev < 16)
OR (EdLev IS NULL) ;
LIKE
目的
ある文字列のパターンを別の文字列または文字列式の中で検索します。
構文
expression
LIKE
pattern_expression
NOT
expression
ESCAPE
LIKE
NOT
escape_character
( subquery )
ALL
ESCAPE
escape_character
ANY
SOME
,
(
expression
LIKE
)
( subquery )
NOT
ESCAPE
ALL
escape_character
ANY
SOME
,
(
expression
,
)
LIKE
NOT
(
ALL
pattern_expression
)
ESCAPE
escape_character
ANY
SOME
SQL 関数、演算子、式および述部
877
第 20 章 論理述部
LIKE
構文要素
expression
副文字列の pattern_expression が検索される文字列または文字列式の引数。
pattern_expression
expression が検索される文字式。
ANY
ALL
SOME
1 つ以上の式の中の 1 つ以上のパターンを、または副問合わせによって戻される 1
つ以上の値を検索することを可能にする数量詞。
subquery
式または式のリストで指定された数と同じ数の式を選択する副問合わせ。
Subquery で SELECT AND CONSUME 文を指定することはできません。
ESCAPE escape_character
単一のエスケープ文字(1 バイトまたはマルチバイト)を指定するキーワード/変数の
組み合わせ。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
NUSI を使用した性能の最適化
コスト効率が良ければ、最適化ルーチンは基本テーブルへのアクセスを伴う(もしく
は伴わない)NUSI の走査によって LIKE 式を評価します。NUSI 使用のコストは、LIKE
式の選択性、NUSI サブテーブルのサイズ、また NUSI がカバー索引か部分的なカバー
索引かによって異なります。部分的なカバー索引の場合、RowID スプールを整列す
るコストも含まれます。NUSI と問合わせカバーの詳細は、<データベース設計、
B035-1094>を参照してください。
最適化ルーチンは、次の条件を満たす場合に、NUSI の使用と全行スキャンの使用に
ついて、優れたコスト比較を実行できるようになります。
• expression 文字列の評価の対象となる基本テーブルの基本索引と NUSI 列の両方
について、統計が収集されている。
• expression 文字列が、基本テーブルの統計ヒストグラムの最低 1 つの間隔におい
て、最頻値か最大値のどちらかである。
次の場合には、LIKE 式の処理に VARCHAR フィールドを持つ NUSI は使用できませ
ん。
878
SQL 関数、演算子、式および述部
第 20 章 論理述部
LIKE
• NUSI に VARCHAR フィールドが含まれ、その VARCHAR フィールドが NOT LIKE
演算で使用される。
• NUSI に VARCHAR フィールドが含まれ、その VARCHAR フィールドが文字列関
数で使用される。例えば、d1 が VARCHAR タイプの NUSI 列の場合、次の例は許
容されていません。
d1||‘ab’ LIKE ‘b ab’
また、VARCHAR フィールドを持つ NUSI は、制約のない集約問合わせに対する部
分的なカバー索引として使用することはできません。
Null 式
比較におけるいずれかの式が null であると、比較の結果は不明です。
LIKE 操作が NULL 値を含む可能性のあるフィールドの検索時に真の結果を得るため
に、その文には、IS [NOT] NULL 演算子を含めなければなりません。
大文字小文字の区別
pattern_expression にも expression にも CASESPECIFIC が指定されていない場合、
pattern_expression および expression 内の英小文字は、比較操作が行なわれる前に
英大文字に変換されます。ESCAPE が指定されていてエスケープ文字が英小文字の
場合も、そのエスケープ文字は比較操作が行なわれる前に英大文字に変換されます。
expression か pattern_expression のどちらかに CASESPECIFIC が指定されている場
合、2 つの文字は、同じ文字でしかも同じ英大文字または英小文字が揃っている場
合にのみ、一致したとみなされます。
ワイルドカード文字
%と_文字を pattern_expression 内で任意に組み合わせて使用することができます。
文字
説明
% (パーセント記号)
0 以上の任意の文字からなる任意の列を表わす。
パーセントはあらゆる文字列で置換え可能です。
_ (下線)
1 つの任意の文字だけを表わす。
下線文字が現われる箇所は、あらゆる単一文字で置換え可能です。
下線文字およびパーセント文字をパターン内で使用することはできません。これら
の文字をパターンで使用するためには、pattern_expression に加えて単一のエスケー
プ文字を指定します。詳細については、「LIKE の ESCAPE 機能」を参照してくださ
い。
次の表では、さまざまなサーバー文字セットについて文字列を照合するときにメタ
文字の%と_ (およびその全角表記)がどのように機能するかを説明します。ANSI で
SQL 関数、演算子、式および述部
879
第 20 章 論理述部
LIKE
は、1 バイトのスペース下線とパーセント記号のメタ文字のみが定義されることに
注意する必要があります。
Teradata SQL では、LIKE 述部で使用可能なメタ文字セットが拡張され、全角の下線
と全角のパーセント記号が含まれるようになりました。
サーバー文字
セット
使用するメタ文字
KANJI1
一致する文字
ANSI モード
Teradata モード
スペース下線
1 つの 1 バイト文字
またはマルチバイト
文字。
1 つの 1 バイト文字。
全角のスペース下線
1 つの 1 バイト文字
またはマルチバイト
文字。
1 つの 1 バイト文字ま
たはマルチバイト文字。
パーセント記号
1 バイト文字またはマ 1 バイト文字またはマ
ルチバイト文字の文 ルチバイト文字の文
字列
字列
全角のパーセント記号
1 バイト文字またはマ 1 バイト文字またはマ
ルチバイト文字の文 ルチバイト文字の文
字列
字列
UNICODE
LATIN
KANJISJIS
全角のスペース下線
なし
全角のパーセント記号
これらの文字は、ANSI SQL 規格に適合させる
ために、メタ文字として処理されません。
GRAPHIC
全角のスペース下線
1 つの単一 GRAPHIC 文字。
全角のパーセント記号
GRAPHIC 文字の文字列
LIKE の ESCAPE 機能
定義済みの ESCAPE 文字をパターン内で使用する場合には、その ESCAPE 文字の直
後に下線、パーセント符号、または他のエスケープ文字を続けなければなりません。
ESCAPE 文字を指定した場合には、パターンを左側から右側に走査するときに以下の
規則が適用されます。
• ESCAPE 文字のインスタンスが現われるまでは、パターン内の文字は、表示され
ているとおりに解釈されます。
• ESCAPE 文字の直後にもう 1 つ ESCAPE 文字が現われた場合には、その 2 つの文
字列は、その ESCAPE 文字の単一のインスタンスのように扱われ、通常の文字と
みなされます。
• ESCAPE 文字の直後に下線のメタ文字が現われた場合には、その文字列は、文字
としての 1 つの下線として扱われます(ワイルドカード文字ではなく)。
880
SQL 関数、演算子、式および述部
第 20 章 論理述部
LIKE
• ESCAPE 文字の直後にパーセントのメタ文字が現われた場合には、その文字列
は、文字としての 1 つのパーセントとして扱われます(ワイルドカード文字では
なく)。
• ESCAPE 文字の直後に下線のメタ文字、パーセントのメタ文字、またはその
ESCAPE 文字自体の別のインスタンスが現われなかった場合には、走査は停止さ
れ、エラーが報告されます。
例
次の例で、ESCAPE の使用法を示します。
「Result is 95% effective」などの文字列でパターン「95%」を検索して、検査する
フィールドが Result である場合には、次の文を使用します。
WHERE Result LIKE '%95Z%%' ESCAPE 'Z'
この句は、値「95%」を検出します。
埋め込み文字
埋め込み文字および文字列内での埋め込み文字の扱い方について、以下の注釈が適
用されます。
• 埋め込み文字は、文字式とパターンの両方で意味があります。
• パターンを照合する場合、フィールドまたは式の先頭や末尾の埋め込み文字がパ
ターンと正確に一致しなければなりません。
例えば、‘A%BC’は‘AxxBC’に一致しますが、‘AxxBCΔ’に一致しません。また、‘A
%BCΔ’は‘AxxBCΔ’に一致しますが、‘AxxBC’にも‘AxxBCΔΔ’ (Δ は埋め込み文字
を示します)にも一致しません。
• すべての状況で行を検索するには、TRIM 関数の使用を考慮してください。この
関数は、パターン照合が行なわれる前に、元の文字列から先頭や末尾の埋め込み
文字を取り除きます。
末尾の埋め込み文字を取り除く例を挙げます。
TRIM (TRAILING FROM expression) LIKE pattern-string
先頭と末尾の埋め込み文字を取り除くには、次の文を使用します。
TRIM (BOTH FROM expression) LIKE pattern-string
• pattern_expression が強制的に固定長に設定されている場合、末尾の埋め込み文
字を付加することができます。このような場合、フィールドには照合のために末
尾の埋め込み文字が同じ数だけなければなりません。
たとえば、次の文は 5 文字より短いパターンの文字列の末尾に埋め込み文字を付
加します。
CREATE MACRO (pattern (CHAR(5)) AS
field LIKE :pattern…
SQL 関数、演算子、式および述部
881
第 20 章 論理述部
LIKE
• どのように定義されている行でも取り出すためには、TRIM 関数をパターンの文
字列に適用するか(TRIM(TRAILING FROM :パターン))、またはマクロ パラメータ
を VARCHAR と定義します。
この 2 つの方法が常に同じ結果を返すとは限りません。TRIM は埋め込み文字を
取り除き、一方、VARCHAR では、入力されたとおりの正確なデータ パターンを
保持します。
例
例
次の例は、LIKE 述部を使用して、肩書に文字列「Pres」が含まれている社員のリス
トを選択します。
SELECT Name, DeptNo, JobTitle
FROM Employee
WHERE JobTitle LIKE '%Pres%' ;
この%文字列%の形式は、各文字列の出現を検査することを Teradata Database に要
求します。検索文字列が長く、テーブルに多くの行がある場合は、行の限定のため
に長い時間がかかることがあります。
返される結果は、次のとおりです。
Name
DeptNo
JobTitle
Watson L
500
Vice President
Phan A
300
Vice President
Russel S
300
President
例
次の例は、名字が P の字で始まるすべての社員のリストを選択します。
SELECT Name
FROM Employee
WHERE Name LIKE 'P%';
返される結果は、次のとおりです。
Name
---------Phan A
Peterson J
例
この例では、% と _ の文字を使用して、名字の 2 番目の文字が A である社員のリス
トを選択します。返される文字列の長さは、2 文字以上になります。
882
SQL 関数、演算子、式および述部
第 20 章 論理述部
LIKE
SELECT Name
FROM Employee
WHERE Name LIKE '_a%';
これは、次の結果を返します。
Name
---------Marston A
Watson L
Carter J
_a%を_a_に置き換えると、2 番目の文字が a の 3 文字の文字列の検索になります。
Employee テーブルにはこの記述に合う名前がないため、この問合わせは行を返し
ません。
パターン内の先行および末尾の埋め込み文字は両方とも、照合の規則には意味があ
ることに注意する必要があります。
例
LIKE ’ΔΔZ%’は、2 つの埋め込み文字で始まり、後ろに Z が続くフィールドだけを
探します。
ANY/ALL/SOME 数量詞
SQL は、数量詞の ANY (または SOME)および ALL を認識します。次の一般的な例で
示すように、数量詞によって、1 つ以上の式を 1 つ以上の値と比較できます。
,
expression
LIKE
quantifier
pattern_string
(
)
指定する数量詞
検索条件が満たされるときに expression LIKE
pattern_string …が真となる範囲
ALL
リスト内のすべての文字列
ANY
リスト内のいずれかの文字列
ALL 数量詞は、論理文 FOR ∀です。
ANY 数量詞は、論理文 FOR ∃です。
次の表は、このことを示しています。
式
等価である式
x LIKE ALL ('A%','%B','%C%')
x LIKE 'A%'
AND x LIKE '%B'
AND x LIKE '%C%'
SQL 関数、演算子、式および述部
883
第 20 章 論理述部
LIKE
式
等価である式
x LIKE ANY ('A%','%B','%C%')
x LIKE 'A%'
OR x LIKE '%B'
OR x LIKE '%C%'
次の文は、肩書の中で文字列「Pres」が使われているか、または「Man」で始まる
行を社員テーブルから選択します。
SELECT *
FROM Employee
WHERE JobTitle LIKE ANY ('%Pres%', 'Man%');
この文の結果は、次のとおりです。
EmpNo
Name
DeptNo
JobTitle
Salary
10021
Smith T
700
Manager
45, 000.00
10008
Phan A
300
Vice Pres
55, 000.00
10007
Aguilar J
600
Manager
45, 000.00
10018
Russell S
300
President
65, 000.00
10012
Watson L
500
Vice Pres
56, 000.00
次の形式に対し、ALL または ANY/SOME 限定子が指定された場合には、subquery
は、0 行、1 行、または数行を返します。
expr
LIKE
quantifier
( subquery )
NOT
ただし、次の表に示すように、数量詞が使用されない場合は、副問合わせは何の値
も返さないか、単一の値を返すかのどちらかです。
式
真になる場合の expression の一致対象
expression LIKE (subquery)
Subquery によって返された単一の値。
expression LIKE ANY (subquery)
Subquery によって返された値セットのうち、少な
くとも 1 つの値。Subquery が何の値も戻さない場
合は偽。
expression LIKE ALL (subquery)
Subquery によって返された値セットのそれぞれの
値、subquery が何の値も戻さない場合は偽。
例
次の文は ANY 数量詞を使用して、Project テーブルから各行を検索します。この表
は、プロジェクト コードに Accounts Payable または Accounts Receivable のどちら
かを含みます。
884
SQL 関数、演算子、式および述部
第 20 章 論理述部
LIKE
SELECT * FROM Project
WHERE Proj_Id LIKE ANY
(SELECT Proj_Id
FROM Charges
WHERE Proj_Id LIKE ANY ('A%')) ;
subquery
次の形式を使用した場合、subquery は 0 から数個の値を返すことができます。
expr
LIKE
quantifier
( subquery )
NOT
次の例は、別のテーブルから選択したパターンを使用して突合わせを行なう方法を
示しています。
基本テーブルは、2 つあります。
テーブル
定義されている内容
Project
• 固有のプロジェクト ID
• プロジェクトの説明
Department_Proj
プロジェクト ID のパターンと Department との関連
Department_Proj には、2 つの列があります。つまり、Proj_pattern と Department
です。このテーブルの行は、次のとおりです。
Proj_pattern
Department
AP%
Finance
AR%
Finance
Nut%
R&D
Screw%
R&D
次の問合わせは、LIKE を使用して Department_Proj テーブルから選択したパターン
を突き合わせ、Department_Proj テーブルに定義されているように、Finance 部署
に関連するプロジェクト パターンと一致する Proj_Id を持っている Project テーブ
ル内のすべての行を選択します。
SELECT *
FROM Project
WHERE Proj_Id LIKE ANY
(SELECT Proj_Pattern
FROM Department_Proj
WHERE Department = 'Finance');
次の形式を使用した場合、subquery は、式のリスト内の数と同じ数の式を選択しな
ければなりません。
SQL 関数、演算子、式および述部
885
第 20 章 論理述部
LIKE
,
(
expr
LIKE
)
quantifier
( subquery )
NOT
以下に例を示します。
(x,y) LIKE ALL (SELECT a,b FROM c)
これは、次と等しくなります。
(x LIKE c.a) AND (y LIKE c.b)
ESCAPE 文字の動作
escape_character が(総称)string_2 で使用されている場合には、この直後に適切な
サーバー文字セットのメタ文字か、別の escape_character を続けなければなりません。
string_1 内の文字が string_1 内の escape_character の後の文字とまったく同じであ
る場合、結果として生じる 2 文字列は string_2 内の 1 文字に一致します。
つまり、escape_character は、照合のために無視され、escape_character の後の文
字がそれ自体の単一のオカレンスとして照合されます。
string_1 と string_2 が共通のサーバー文字セットを共用しない場合には、引数が一
致していないときに自動的に UNICODE にコード変換されるため、有効なメタ文字
は、下線とパーセント記号です。これらの動作は、「文字から文字への暗黙の変換」
で説明されているルールに従います。
例
さまざまな例
関数
結果
_KanjiSJIS ‘92
abc’ LIKE _Unicode ‘%abc’
TRUE
_KanjiSJIS ‘92
abc’ LIKE _Unicode ‘%abc’
FALSE
%(全角のパーセント記号)は、
KanjiSJIS または UNICODE のメタ
文字ではありません。
‘c%’ LIKE ‘c%%’ ESCAPE ‘%’
TRUE
‘c%’ LIKE ‘c%%’ ESCAPE ‘%’
FALSE
%(全角のパーセント記号)は、%
(パーセント記号)に一致しません。
886
SQL 関数、演算子、式および述部
第 20 章 論理述部
LIKE
KanjiEBCDIC の例
次の例は、関数(expression LIKE pattern_expression)を使用したときの KanjiEBCDIC
文字列に対する LIKE の動作を示します。
expression
pattern_expression
サーバー文字セット
結果
MN<AB>
%<B>
KANJI1
TRUE
MN<AB>P
<%B>%
KANJI1
TRUE
MN<AB>P
%P
KANJI1
TRUE
MN<AB>P
%<__C>%
KANJI1
FALSE
__は、全角の下線を表わします。
KanjiEUC の例
次の例は、関数(expression LIKE pattern_expression)を使用したときの KanjiEUC 文
字列に対する LIKE の動作を示します。
expression
pattern_expression
サーバー文字セット
結果
ss3A ss2B ss3C ss2D % ss2B%
UNICODE
TRUE
M ss2B N ss2D
GRAPHIC
TRUE
ss3A ss2B ss3C ss2D __%
KANJISJIS
TRUE
ss3A ss2B ss3C ss2D _ %
KANJISJIS
TRUE
M __%
__は、全角の下線を表わします。
_は、スペース下線を表わします。
KanjiShift-JIS の例
次の例は、関数(expression LIKE pattern_expression)を使用したときの KanjiShiftJIS 文字列に対する LIKE の動作を示します。
expression pattern_expressio
n
サーバー文字 ANSI モードの結果
セット
Teradata モードの
結果
ABCD
__B%
GRAPHIC
TRUE
TRUE
mnABCI
%B%
UNICODE
TRUE
TRUE
mnABCI
%I
UNICODE
TRUE
TRUE
mnABCI
mn_%I
KANJI1
TRUE
pattern_expression
の中にある下線は、
ANSI モードの 1 バイ
SQL 関数、演算子、式および述部
887
第 20 章 論理述部
OVERLAPS
expression pattern_expressio
n
mnABCI
mn__%I
サーバー文字 ANSI モードの結果
セット
KANJI1
Teradata モードの
結果
ト文字またはマルチ
バイト文字に一致し
ます。
pattern_expression
の中にある下線は、
Teradata モードの
1 バイト文字に一致
します。
TRUE
TRUE
__は、全角の下線を表わします。
_は、スペース下線を表わします。
OVERLAPS
OVERLAPS は、OVERLAPS を参照してください。
888
SQL 関数、演算子、式および述部
第 21 章
Null 処理のための関数
概要
この章では、null 入力値を処理する関数について説明します。
NVL
目的
NULL を結果値として数値または文字列値で置き換えます。
構文
NVL
( expr1, expr2 )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
expr1
数値または文字式。
• expr1 が NULL の場合は、expr2 が返されます。
• expr1 が NULL でない場合は、expr1 が返されます。
expr2
数値または文字式。
呼出し
NVL は埋め込みサービス システム関数です。埋め込みサービス関数の有効化と呼び
出しについて、詳細は「埋め込みサービス システム関数 」を参照してください。
SQL 関数、演算子、式および述部
889
第 21 章 Null 処理のための関数
NVL
引数のタイプと規則
この関数に渡された式は、次のデータ タイプを持っている必要があります。
BYTEINT、SMALLINT、INTEGER、BIGINT、DECIMAL/NUMERIC、FLOAT/REAL/
DOUBLE PRECISION、NUMBER、CHAR、VARCHAR
すべての入力引数は同じデータ タイプか、あるいはタイプに互換性がなければなり
ません。
結果のタイプ
NVL は、渡された引数に関連付けられたデータ タイプによって戻り値のデータ タイ
プが異なるスカラー関数です。
• 入力引数が数値タイプの場合、関数は最も優先順位が高い引数を決定し、その
データ タイプに他の引数を変換して、そのデータ タイプを返します。優先順位
の順序の詳細については、<SQL 外部ルーチン プログラミング、B035-1147>の
「互換データ型」を参照してください。
そのデータ タイプが DECIMAL/NUMERIC であり、入力引数の精度とスケールが
異なる場合、戻りタイプの精度とスケールは最大精度になるように設定されま
す。たとえば、入力引数が DECIMAL(6,3)、DECIMAL(7,4)、および DECIMAL(8,7)
の場合、精度の低下を避けるために、戻りタイプは小数点の左が 3 桁、右が 7 桁
必要になります。
最大精度を維持できない場合、データは DBS 制御レコードの
RoundHalfWayMagUp フィールドに基づいて丸められます。たとえば、入力引数
が DECIMAL(32, 8)と DECIMAL(30, 28)の場合、戻りタイプは DECIMAL(38,14)
になります。これにより、小数点の左が 24 桁(DECIMAL(32,8)引数に必要)、小数
点の右が 14 桁使用できます。
データ タイプが固定小数点数の NUMBER で精度が 38 以下の場合、戻りタイプ
の精度とスケールは、DECIMAL/NUMERIC と同じメソッドを使用して計算されま
す。ただし、精度が 38 より大きい場合は、精度の低下を避けるために戻りタイ
プを NUMBER(*)に変更します。データ タイプが浮動小数点の NUMBER の場合、
戻りタイプは NUMBER(*)になります。
• 2 つの引数が文字データ タイプの場合、関数は第 2 引数を第 1 引数のデータ タ
イプに変換し、そのタイプを VARCHAR として返します。
• 入力文字のタイプがすべて LATIN の場合、結果は LATIN になります。一部の入
力が LATIN でない場合、関数はすべての入力を Unicode に変換します。返される
文字セットは Unicode になります。
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
890
SQL 関数、演算子、式および述部
第 21 章 Null 処理のための関数
NVL2
例
以下の問合わせを実行します。
SELECT department_name,
NVL(last_name,'NO EMPLOYEE') "LAST NAME"
FROM employee E
FULL OUTER JOIN Department D
ON department_number=d.department_number;
WHERE department_number IN(402,600);
次の結果が得られます。
Department_name
LAST NAME
--------- -------------------Software Support
Crane
New Department
NO EMPLOYEE
この例では、NVL 関数は結果を employee テーブルからの last_name 列値として返
します。last_name 値が NULL の場合、関数は結果を NO EMPLOYEE として返しま
す。
関連トピック
詳細は、以下を参照してください。
• 詳細については、<SQL 外部ルーチン プログラミング、B035-1147>の「互換デー
タ型」を参照してください。
NVL2
目的
expr1 が NULL かどうかに基づいて、2 つの値のいずれか 1 つを返します。
構文
NVL2
( expr1, expr2, expr3 )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
SQL 関数、演算子、式および述部
891
第 21 章 Null 処理のための関数
NVL2
expr1
数値または文字式。
• expr1 が NULL でない場合は、expr2 が返されます。
• expr1 が NULL の場合は、expr3 が返されます。
expr2
数値または文字式。
expr3
数値または文字式。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
NVL2 は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡される式には、次のいずれかのデータ タイプが含まれている必要があ
ります。
BYTEINT、SMALLINT、INTEGER、BIGINT、DECIMAL/NUMERIC、FLOAT/REAL/
DOUBLE PRECISION、NUMBER、CHAR、VARCHAR
expr2 と expr3 は同じデータ型か、あるいは型に互換性がなければなりません。
結果のタイプ
NVL2 は、関数に渡された引数に関連付けられたデータ タイプによって戻り値のデー
タ タイプが異なるスカラー関数です。
• expr2 および expr3 が数値タイプの場合、関数は最も優先順位が高い引数を決定
し、そのデータ型に他の引数を変換して、そのデータ型を返します。優先順位の
順序の詳細については、<SQL 外部ルーチン プログラミング、B035-1147>の「互
換データ型」を参照してください。
そのデータ タイプが DECIMAL/NUMERIC であり、2 つの引数の精度とスケール
が異なる場合、戻りタイプの精度とスケールは最大精度になるように設定されま
す。たとえば、入力引数が DECIMAL(6,3)、DECIMAL(7,4)、および DECIMAL(8,7)
の場合、精度の低下を避けるために、戻りタイプは小数点の左が 3 桁、右が 7 桁
必要になります。この場合、返されるデータ タイプは DECIMAL(10,7)に設定さ
れます。
892
SQL 関数、演算子、式および述部
第 21 章 Null 処理のための関数
NVL2
最大精度を維持できない場合、データは DBS 制御レコードの
RoundHalfWayMagUp フィールドに基づいて丸められます。たとえば、2 つの引
数が DECIMAL(32, 8)と DECIMAL(30, 28)の場合、戻りタイプは
DECIMAL(38,14)になります。これにより、小数点の左が 24 桁(DECIMAL(32,8)
引数に必要)、小数点の右が 14 桁使用できます。
データ タイプが固定小数点数の NUMBER で精度が 38 以下の場合、戻りタイプ
の精度とスケールは、DECIMAL/NUMERIC と同じメソッドを使用して計算され
ます。ただし、精度が 38 より大きい場合は、精度の低下を避けるために戻りタ
イプを NUMBER(*)に変更します。データ タイプが浮動小数点の NUMBER の場
合、戻りタイプは NUMBER(*)になります。
• expr2 と expr3 が文字型の場合、関数は第 2 引数を第 1 引数のデータ型に変換
し、その型を VARCHAR として返します。
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
例
例
以下の問合わせを実行します。
SELECT NVL2('England', 'France', 'Spain');
第 1 引数が NULL でないため、第 2 引数'France'を返します。
例
以下の問合わせを実行します。
SELECT NVL2(NULL, 'France', 'Spain');
第 1 引数が NULL でないため、第 3 引数'Spain'を返します。
関連トピック
詳細は、以下を参照してください。
• 埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービ
ス システム関数 」を参照してください。
• 詳細については、<SQL 外部ルーチン プログラミング、B035-1147>の「互換デー
タ型」を参照してください。
SQL 関数、演算子、式および述部
893
第 21 章 Null 処理のための関数
NVL2
894
SQL 関数、演算子、式および述部
第 22 章
順序付き分析関数/ウィンドウ集約関数
概要
この章では、次の内容について説明します。
• 順序付き分析関数
• ウィンドウ集約関数
順序付き分析関数
順序付き分析関数は、結果行の順序指定セットが必要であるか、または直前の行の
値に基づいて計算が行なわれる、分析処理およびデータ マイニングでの一般的な演
算を多数サポートします。順序付き分析関数では、オンライン分析処理(OLAP)スタ
イルの意思決定支援要求を含む問合わせの処理を効率よく行なえます。
たとえば、7 日間の連続合計を計算する場合、次のことを行なう必要があります。
• まず、日付ごとに行を並べる必要があります。
• さらに、連続合計の値を計算する必要があります。
• そのためには、直前の行からの合計値に現在行の値を加算してから、
• 8 日前の行の値を減算しなければなりません。
利点
順序付き分析関数は Teradata Database 問合わせ実行エンジンを拡張したものであ
り、順序指定セットの概念と、複数行の値を使って新しい値を計算する機能を追加
しています。
順序付き分析関数の結果は、その他の SQL 式と同じように処理されます。結果列と
して示すこともできれば、SELECT 内のさらに複雑な計算式の一部として組み込む
こともできます。
それぞれの順序付き分析関数では、SELECT 文によって取り出した行を並べ替える
ための並替え順序を示した列(複数も可)を指定できます。関数の並替え順序や他の
入力パラメータは、その他の SQL 関数の引数と同じように指定します。その種のパ
ラメータとしては、任意の標準 SQL 式を使用できます。
SQL 関数、演算子、式および述部
895
第 22 章 順序付き分析関数/ウィンドウ集約関数
順序付き分析関数
SQL レベルでの順序付き分析計算
高レベルの OLAP 計算エンジンを使わずに、SQL レベルで順序付き分析計算を実行
することには、はっきりとした利点が 4 つあります。
• プログラミング作業が少ないこと。
• 外部並替えルーチンが不要であること。
• 大きなデータ セットを外部ツールにエクスポートする必要がないこと。順序付き
分析関数を使えば、問合わせの中で条件を指定することにより、ウェアハウス自
体の内部で分析用のデータを特定できます。
• 外部ツールが大きなデータ セットに対して実行する低速の単一スレッド演算に比
べて、分析パフォーマンスが格段に向上すること。
Teradata Warehouse Miner
順序付き分析関数の利点は、SQL 問合わせを直接コーディングする必要がないこと
です。Teradata Database も多数のサード パーティの問合わせ管理分析ツールも、
Teradata SQL 順序付き分析関数を完全に利用できます。たとえば、データベース エ
ンジンの内部でデータ マイニング処理を実行するツールである Teradata Warehouse
Miner は、データ抽出を行なわずに、こうした機能を活用して、データベース自体
の中で関数を実行します。
Teradata Warehouse Miner では、Teradata SQL 固有の関数に基づく、事前定義の
SQL データ マイニング関数が約 40 個用意されています。たとえば、Teradata
Warehouse Miner の FREQ 関数は、Teradata SQL 固有の関数である CSUM と RANK
と QUALIFY を使って頻度を判別します。
例
以下の例は、Marital Status (結婚状況)に対する Gender (性別)の頻度を計算する SQL
問合わせが、どのように Teradata Warehouse Miner を使用するかを示したものです。
SELECT gender, marital_status, xcnt,xpct
,CSUM(xcnt, xcnt DESC, gender, marital_status) AS xcum_cnt
,CSUM(xpct, xcnt DESC, gender, marital_status) AS xcum_pct
,RANK(xcnt DESC, gender ASC, marital_status ASC) AS xrank
FROM
(SELECT gender, marital_status, COUNT(*) AS xcnt
,100.000 * xcnt / xall (FORMAT 'ZZ9.99') AS xpct
FROM customer_table A,
(SELECT COUNT(*) AS xall
FROM customer_table) B
GROUP BY gender, marital_status, xall
HAVING xpct >= 1) T1
QUALIFY xrank <= 8
ORDER BY xcnt DESC, gender, marital_status
896
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
順序付き分析関数の特性
この問合わせの結果は、以下の表のようになります。
gender
marital_status
xcnt
F
Married (既婚)
M
xpct
xcum_cnt
xcum_pct
xrank
391009 36.71
3
3910093
36.71
1
Married (既婚)
241951 22.71
1
6329604
59.42
2
F
Divorced (離婚)
161213 15.13
0
7941734
74.55
3
M
Divorced (離婚)
141262 3.26
4
9354358
87.81
4
F
Single (未婚)
491224 4.61
9845582
92.42
5
F
Widowed (死別)
319881 3.01
10165463
95.43
6
M
Single (未婚)
319794 3.00
10485257
98.43
7
M
Widowed (死別)
197131 1.57
10652388
100.00
8
順序付き分析関数の特性
関数値
行内の列の関数値は、その行(およびグループ内の他のすべての行のサブセット)を
対象として、新しい値を生成します。
この演算を記述した汎用関数は、以下のとおりです。
new_column_value = FUNCTION(column_value,rows_defined_by_window)
QUALIFY 句の使用
行数を減らすには、新しい列値に条件を適用します。QUALIFY 句は集約関数の
HAVING 句に類似しています。QUALIFY 句は、関数値に基づいて行数を減らし、対
象となっている各行について 1 つの新しい値を戻します。たとえば、
SELECT StoreID, SUM(profit) OVER (PARTITION BY StoreID)
FROM facts
QUALIFY SUM(profit) OVER (PARTITION BY StoreID) > 2;
順序付き分析関数と集約関数の両方を指定した SQL 問合わせには、以下の例のよう
に、QUALIFY 句と HAVING 句を両方とも組み込むことができます。
SQL 関数、演算子、式および述部
897
第 22 章 順序付き分析関数/ウィンドウ集約関数
順序付き分析関数の特性
SELECT StoreID, SUM(sale),
SUM(profit) OVER (PARTITION BY StoreID)
FROM facts
GROUP BY StoreID, sale, profit
HAVING SUM(sale) > 15
QUALIFY SUM(profit) OVER (PARTITION BY StoreID) > 2;
DISTINCT 句の制限
ウィンドウ集約関数では DISTINCT 句は使用できません。
対象となる問合わせオブジェクト
順序付き分析関数は、以下のデータベース問合わせオブジェクトを対象としています。
•
•
•
•
ビュー
マクロ
派生テーブル
INSERT ...SELECT
順序付き分析関数を使用できない場合
次の場合、順序付き分析関数を使用することはできません。
• SUBQUERY
• WHERE 句
• SELECT AND CONSUME 文
標準的な SQL 関数の使用
同一の問合わせ内で標準的な SQL 関数も併用して、文をさらに練り上げることもで
きます。
たとえば、以下のような方法で順序付き分析関数を使用できます。
分析関数を使用する操作
目的
INSERT … SELECT
新しい列に値を入れること。
派生テーブル
複雑な問合わせにかかわる新しいテーブルを作
成すること。
それぞれ異なる並替え式を持った順序付き分析関数は、同じスプール ファイルを使
用しながら 1 つずつ評価されます。同じ並替え式を持ったそれぞれ異なる関数は、
同時に評価されます。
898
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
順序付き分析関数の特性
サポートされないデータ タイプ
順序付き分析関数は 次のデータ タイプには動作しません。
• CLOB または BLOB データ タイプ
• UDT データ タイプ
式内で CLOB、BLOB、または UDT データ型を使用できるのは、結果がサポートさ
れるデータ型である場合です。たとえば、
SELECT
RANK() OVER
(PARTITION BY(CASE WHEN b IS NULL THEN 1 ELSE 0 END) ORDER BY id)
FROM btab;
ただし、次の例は、BLOB による並べ替えができないため、エラーになります。
SELECT
RANK() OVER
(PARTITION BY b ORDER BY id)
FROM btab;
順序付き分析関数および Period データ タイプ
Period データ タイプと評価される式は、QUANTILE、RANK (Teradata 固有の関数)、
および RANK (ANSI SQL ウィンドウ関数)といった順序付き分析関数内の任意の式に
指定できます。
順序付き分析関数と再帰的問合わせ
順序付き分析関数は、再帰的問合わせの再帰文では使用できません。ただし、再帰
的問合わせの中の非再帰シード文で順序付き分析関数を指定することができます。
順序付き分析関数とハッシュ索引または結合索引
単一のテーブル問合わせが、単一のテーブル圧縮ハッシュ索引または結合索引用と
しても定義されている列に対して順序付き分析関数を指定した場合、最適化ルーチ
ンは問合わせを処理するときにそのハッシュ索引または結合索引を選択しません 。
順序付き分析関数と行レベル セキュリティ テーブル
行レベル セキュリティで保護されたテーブルを参照する順序付き分析関数(MAVG、
CSUM、RANK など)が要求に含まれている場合、その操作は要求を発行したユーザー
がアクセスできる行にのみ基づいたものになります。この関数をテーブルに含まれ
るすべての行に適用するには、ユーザーには次のいずれかが必要になります。
• テーブルのすべての行にアクセスするために必要なセキュリティ クレデンシャル。
SQL 関数、演算子、式および述部
899
第 22 章 順序付き分析関数/ウィンドウ集約関数
順序付き分析関数の特性
• テーブルのセキュリティ制約に対して必要な OVERRIDE 権限。
整列順序の計算と結果の順序
ウィンドウ指定で指定する整列順序によって関数の適用対象の行に対する整列順序
が定義されますが、それによって結果の順序が定義されるわけではありません。
たとえば、現行月から後の月の平均売上げを計算するには、次のように行を月別に
順序付けします。
SELECT StoreID, SMonth, ProdID, Sales,
AVG(Sales) OVER (PARTITION BY StoreID ORDER BY SMonth
ROWS BETWEEN 1 FOLLOWING AND UNBOUNDED FOLLOWING)
FROM sales_tbl;
StoreID
------1001
1001
1001
1001
1001
1001
SMonth
-----6
5
4
3
2
1
ProdID
-----C
C
C
C
C
C
Sales
--------30000.00
30000.00
25000.00
40000.00
25000.00
35000.00
Remaining Avg(Sales)
-------------------?
30000.00
30000.00
28333.33
31250.00
30000.00
計算でのデフォルトの並替え順序は ASC です。しかし結果は、その逆の順序で戻さ
れます。
結果を順序付けするには、SELECT 文で ORDER BY 句を使用します。たとえば、
SELECT StoreID, SMonth, ProdID, Sales,
AVG(Sales) OVER (PARTITION BY StoreID ORDER BY SMonth
ROWS BETWEEN 1 FOLLOWING AND UNBOUNDED FOLLOWING)
FROM sales_tbl
ORDER BY SMonth;
StoreID
------1001
1001
1001
1001
1001
1001
900
SMonth
-----1
2
3
4
5
6
ProdID
-----C
C
C
C
C
C
Sales
--------35000.00
25000.00
40000.00
25000.00
30000.00
30000.00
Remaining Avg(Sales)
-------------------30000.00
31250.00
28333.33
30000.00
30000.00
?
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
順序付き分析関数の特性
ウィンドウ指定のパーティション化列のデータおよびリソースの影響
ウィンドウ指定の PARTITION BY 句で指定される列で、順序付き分析関数が実行す
るパーティションが決定します。 たとえば、次の問合わせでは PARTITION BY 句で
StoreID 列を指定して、各店舗のグループ売上合計を計算します。
SELECT StoreID, SMonth, ProdID, Sales,
SUM(Sales) OVER (PARTITION BY StoreID)
FROM sales_tbl;
実行時に、Teradata Database は 1 つのパーティションに分類される行のすべてを
同じ AMP に移動します。多くの行が同じパーティションに分類される場合、AMP
ではスプール領域が不足する可能性があります。 たとえば、先行する問合わせの
sales_tbl テーブルに何百万または何十億もの行があり、StoreID 列に小数の明確な
値がある場合は、膨大な数の行が同じパーティションに分類されることになり、ス
プール不足エラーの原因となります。
この問題を回避するには、PARTITION BY 句の列のデータを検査します。 必要に応
じて、PARTITION BY 句で追加の列を含めるように問合わせを書き換え、Teradata
Database が AMP でより均等に分配を行なうことができるように、小さいパーティ
ションを作成します。 たとえば、先行する問合わせは、月ごとに各店舗のグループ
売上合計を計算するように書き換えることができます。
SELECT StoreID, SMonth, ProdID, Sales,
SUM(Sales) OVER (PARTITION BY StoreID, SMonth)
FROM sales_tbl;
順序付き分析関数の使用
例: RANK および AVG の使用
順序付き分析関数である RANK と AVG を使った以下の SELECT 文の結果について考
えてみます。
SELECT item, smonth, sales,
RANK() OVER (PARTITION BY item ORDER BY sales DESC),
AVG(sales) OVER (PARTITION BY item
ORDER BY smonth
ROWS 3 PRECEDING)
FROM sales_tbl
ORDER BY item, smonth;
結果テーブルは、たとえば以下のようなものになります。
Item
SMonth
Sales
Rank(Sales)
Moving Avg(Sales)
A
1996-01
110
13
110
SQL 関数、演算子、式および述部
901
第 22 章 順序付き分析関数/ウィンドウ集約関数
順序付き分析関数の特性
Item
SMonth
Sales
Rank(Sales)
Moving Avg(Sales)
A
1996-02
130
10
120
A
1996-03
170
6
137
A
1996-04
210
3
155
A
1996-05
270
1
195
A
1996-06
250
2
225
A
1996-07
190
4
230
A
1996-08
180
5
222
A
1996-09
160
7
195
A
1996-10
140
9
168
A
1996-11
150
8
158
A
1996-12
120
11
142
A
1997-01
120
11
132
B
1996-02
30
5
30
...
...
...
...
...
例: QUALIFY と RANK の使用
問合わせに QUALIFY 句を追加すると、該当しないテーブルから行数を減らすことが
できます。
たとえば、高い売上げを記録した月が例年どおりなのか、そうでないのかを調べる
場合は、前の問合わせに QUALIFY 句を追加します。
SELECT item, smonth, sales,
RANK() OVER (PARTITION BY item ORDER BY sales DESC),
AVG(sales) OVER (PARTITION BY item ORDER BY smonth ROWS 3 PRECEDING)
FROM sales_tbl
ORDER BY item, smonth
QUALIFY RANK() OVER(PARTITION BY item ORDER BY sales DESC) <=5;
このように限定節を追加すると、たとえば以下のような結果テーブルが生成されます。
902
Item
SMonth
Sales
Rank(Sales)
Moving Avg(Sales)
A
1996-04
210
3
155
A
1996-05
270
1
195
A
1996-06
250
2
225
A
1996-07
190
4
230
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
順序付き分析関数の特性
Item
SMonth
Sales
Rank(Sales)
Moving Avg(Sales)
A
1996-08
180
5
222
B
1996-02
30
1
30
...
...
...
...
...
この結果は、現在の販売期間が始まる前の売上げがかなり低かったということを物
語っています。
例: QUALIFY と RANK の使用
sales_tbl という名前の以下の売上テーブルを取り上げます。
Store
ProdID
Sales
1003
C
20000.00
1003
D
50000.00
1003
A
30000.00
1002
C
35000.00
1002
D
25000.00
1002
A
40000.00
1001
C
60000.00
1001
D
35000.00
1001
A
100000.00
1001
B
10000.00
ここで、この表に対して以下のシンプルな SELECT 文を実行し、順位によって応答
行を限定します。
SELECT store, prodID, sales,
RANK() OVER (PARTITION BY store ORDER BY sales DESC)
FROM sales_tbl
QUALIFY RANK() OVER (PARTITION BY store ORDER BY sales DESC) <=3;
結果は、以下のような典型的な出力テーブルになります。
Store
ProdID
Sales
Rank(Sales)
1001
A
100000.00
1
1001
C
60000.00
2
1001
D
35000.00
3
SQL 関数、演算子、式および述部
903
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ関数
Store
ProdID
Sales
Rank(Sales)
1002
A
40000.00
1
1002
C
35000.00
2
1002
D
25000.00
3
1003
D
50000.00
1
1003
A
30000.00
2
1003
C
20000.00
3
このように、QUALIFY 句の条件(売上げの順位が店舗内の 3 位より下)に適合しない
行を除き、テーブル内のすべての行には RANK の計算値が戻されています。
関連トピック
詳細は、以下を参照してください。
• 行レベル セキュリティの詳細は、<セキュリティ管理ガイド 、B035-1100>を参
照してください。
• QUALIFY 句の詳細は、< SQL データ操作言語、B035-1146>を参照してください。
ウィンドウ関数
ANSI SQL:2011 ウィンドウ関数を使用して、順序付けされたリレーショナル データ
ベース テーブルの中のデータのサブセット(ウィンドウ)を動的に定義することがで
きます。ウィンドウは OVER()句で指定され、括弧内には次の句を含めることができ
ます。
•
•
•
•
PARTITION BY
ORDER BY
RESET WHEN
ROWS
PARTITION BY 句
PARTITION BY に列参照リストを指定すると、指定された列参照リスト(順序付き分
析関数の実行対象)に基づいて行がグループ化されます。このようなグループ化は静
的になります。条件に基づいたグループやパーティションを定義する場合は、RESET
WHEN 句を使用します。詳細については、「RESET WHEN 句」を参照してください。
PARTITION BY 句または RESET WHEN 句を指定しない場合は、FROM 句から送られ
る単一のパーティションで構成された結果セット全体が、順序付き分析関数の実行
対象になります。
sales_tbl という名前の以下の表を取り上げます。
904
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ関数
StoreID
SMonth
ProdID
Sales
1001
1
C
35000.00
1001
2
C
25000.00
1001
3
C
40000.00
1001
4
C
25000.00
1001
5
C
30000.00
1001
6
C
30000.00
1002
1
C
40000.00
1002
2
C
35000.00
1002
3
C
110000.00
1002
4
C
60000.00
1002
5
C
35000.00
1002
6
C
100000.00
PARTITION BY を含まない次の SELECT 文は、この表のすべての店舗の平均売上げ
を計算します。
SELECT StoreID, SMonth, ProdID, Sales,
AVG(Sales) OVER ()
FROM sales_tbl;
StoreID
------1001
1001
1001
1001
1001
1001
1002
1002
1002
1002
1002
1002
SMonth
-----1
2
3
4
5
6
1
2
3
4
5
6
ProdID
-----C
C
C
C
C
C
C
C
C
C
C
C
Sales
--------35000.00
25000.00
40000.00
25000.00
30000.00
30000.00
40000.00
35000.00
110000.00
60000.00
35000.00
100000.00
Group Avg(Sales)
---------------47083.33
47083.33
47083.33
47083.33
47083.33
47083.33
47083.33
47083.33
47083.33
47083.33
47083.33
47083.33
店舗ごとの平均売上げを計算するには、sales_tbl のデータを次のように StoreID ご
とに区分します。
SQL 関数、演算子、式および述部
905
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ関数
SELECT StoreID, SMonth, ProdID, Sales,
AVG(Sales) OVER (PARTITION BY StoreID)
FROM sales_tbl;
StoreID
------1001
1001
1001
1001
1001
1001
1002
1002
1002
1002
1002
1002
SMonth
-----3
5
6
4
2
1
3
5
6
4
2
1
ProdID
-----C
C
C
C
C
C
C
C
C
C
C
C
Sales
--------40000.00
30000.00
30000.00
25000.00
25000.00
35000.00
110000.00
35000.00
100000.00
60000.00
35000.00
40000.00
Group Avg(Sales)
---------------30833.33
30833.33
30833.33
30833.33
30833.33
30833.33
63333.33
63333.33
63333.33
63333.33
63333.33
63333.33
ORDER BY 句
ORDER BY で、区分内に行を順序付けする方法を指定し、関数が適用される行の並
替え順序を決定します。
sales_tbl テーブルの店舗の月別売上げを直前の月の売上げに追加するには、次のよ
うに、売上げの累積合計を計算し、各区分内の行を Smonth 別に順序付けします。
SELECT StoreID, SMonth, ProdID, Sales,
SUM(Sales) OVER (PARTITION BY StoreID ORDER BY SMonth
ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW)
FROM sales_tbl;
StoreID
------1001
1001
1001
1001
1001
1001
1002
1002
1002
1002
906
SMonth
-----1
2
3
4
5
6
1
2
3
4
ProdID
-----C
C
C
C
C
C
C
C
C
C
Sales
--------35000.00
25000.00
40000.00
25000.00
30000.00
30000.00
40000.00
35000.00
110000.00
60000.00
Cumulative Sum(Sales)
--------------------35000.00
60000.00
100000.00
125000.00
155000.00
185000.00
40000.00
75000.00
185000.00
245000.00
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ関数
1002
1002
5
6
C
C
35000.00
100000.00
280000.00
380000.00
RESET WHEN 句
RESET WHEN は、ANSI SQL 規格に対する Teradata 拡張機能です。
RESET WHEN では、指定された条件の評価に応じて、順序付き分析関数の実行対象
になるグループまたはパーティションが決まります。条件が TRUE と評価されると、
指定されたウィンドウ パーティション内に新しい動的パーティションが作成されま
す。列参照リストに基づいてパーティションを定義する場合は、PARTITION BY 句
を使用します。詳細については、「PARTITION BY 句」を参照してください。
RESET WHEN 句または PARTITION BY 句を指定しない場合は、FROM 句から送ら
れる単一のパーティションで構成された結果セット全体が、順序付き分析関数の実
行対象になります。
同じ SELECT リスト内に、異なる RESET WHEN 句を指定することができます。
注: RESET WHEN 句を指定するウィンドウ指定には、ORDER BY 句も指定する必要
があります。
RESET WHEN 条件のルール
RESET WHEN 句の条件は、QUALIFY 句の条件と適用範囲は同じですが、ネストさ
れた順序付き分析関数は条件によるパーティション化を指定できないという追加の
制約があります。
条件は、指定されたすべてのウィンドウ パーティション内の行に適用され、その
ウィンドウ パーティション内にサブ パーティションを作成します。
RESET WHEN 条件に適用されるルールは、次のとおりです。
RESET WHEN 条件に含めることができる項目:
•
•
•
•
RESET WHEN 句を含まない順序付き分析関数
スカラー SUBQUERY
集約演算子
DEFAULT 関数
ただし、明示的な列指定のない DEFAULT は、述部でスタンドアロンの条件とし
て指定された場合にのみ有効です。詳細については、「RESET WHEN 条件の一
部として DEFAULT 関数を使用する場合のルール」を参照してください。
RESET WHEN 条件に含めることのできない項目:
•
•
•
•
RESET WHEN 句を含む順序付き分析関数
SELECT 文
LOB 列
UDT 値を返す UDF が含まれている UDT 式
SQL 関数、演算子、式および述部
907
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ関数
ただし、UDT を含む式が事前定義データ型を持つ結果を戻す場合に限り、その式
を RESET WHEN 条件に含めることができます。
RESET WHEN 条件の一部として DEFAULT 関数を使用する場合のルール
RESET WHEN 条件の一部として DEFAULT 関数を使用する場合、以下のルールが適
用されます。
• DEFAULT 関数は、述部において列名の引数で指定できます。DEFAULT 関数は、
その引数として指定された列のデフォルト値と評価されます。評価後、DEFAULT
関数は述部でリテラルのように扱われます。
• 式内で比較演算子の各側に条件として 1 つの列指定と 1 つの DEFAULT 関数があ
る場合に限り、述部で列名の引数を使用せずに DEFAULT 関数を指定できます。
• DEFAULT 関数が null の値を取った場合、既存の比較ルールに従って、IS [NOT]
NULL 以外の比較演算子とともに使用された DEFAULT 関数のある条件は不明な
値になります。
IS [NOT]NULL 以外の条件で DEFAULT 関数が含まれた条件が NULL と比較される
と不明な値を取ります。
DEFAULT 関数と一緒に使用する条件
比較
IS NULL
デフォルトが NULL の場合は TRUE
そうでない場合は FALSE
IS NOT NULL
デフォルトが NULL の場合は FALSE
そうでない場合は TRUE
例
例1
次の例は、各地域の売上げ上昇の全期間の累積売上げを検索します。
SUM(sales) OVER (
PARTITION BY region
ORDER BY day_of_calendar
RESET WHEN sales < /* preceding row */ SUM(sales) OVER (
PARTITION BY region
ORDER BY day_of_calendar
ROWS BETWEEN 1 PRECEDING AND 1 PRECEDING)
ROWS UNBOUNDED PRECEDING
)
例
次の例では、残高増加の連続性を検索します。そのため、現在の残高が直前(前月
末)の残高以下になるたびにリセットを実行する必要があります。
908
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ関数
SELECT account_key, month, balance,
ROW_NUMBER() over
(PARTITION BY account_key
ORDER BY month
RESET WHEN balance /* current row balance */ <=
SUM(balance) over (PARTITION BY account_key ORDER BY month
ROWS BETWEEN 1 PRECEDING AND 1 PRECEDING) /* prev row */
) - 1 /* to get the count started at 0 */ as balance_increase
FROM accounts;
上記の SELECT 文の結果は、たとえば以下のような表になります。
account_key
----------1
1
1
1
1
1
1
1
1
1
1
1
month
----1
2
3
4
5
6
7
8
9
10
11
12
balance
------60
99
94
90
80
88
90
92
10
60
80
10
balance_increase
---------------0
1
0
0
0
1
2
3
0
1
2
0
例
次の例では、ネストされた集約を伴うウィンドウ関数を示します。問合わせは、次
のように処理されます。
1 集約関数の SUM(balance)を使用して、特定の口座に対して、特定の四半期内の
残高すべての合計を計算します。
2 特定の四半期内の(特定の口座に対する)残高が、直前の四半期の残高を上回って
いるかどうかを確認します。
3 残高が増加していれば、累積カウント値に記録します。RESET WHEN 条件の評
価が偽の間は、連続する四半期を通して残高が増加し続けているので、引き続
き累積カウントを増加させます。
4 累積カウント値を計算するために、順序付き分析関数 ROW_NUMBER()を使用し
ます。残高が直前の四半期の残高以下になる四半期に到達すると、RESET WHEN
条件の評価が真になるので、新しいパーティションを開始します。
ROW_NUMBER()はカウントを 1 から再開します。直前の値にアクセスするため
に、ROWS BETWEEN 1 PRECEDING AND 1 PRECEDING を指定しています。
5 最後に、カウント値が確実に 0 から始まるようにするために、1 を引いています。
SQL 関数、演算子、式および述部
909
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ関数
balance_increase 列では、残高が増加し続けていた四半期の連続数を示します。こ
の例では、残高が増加した四半期は 1 期(1->2)だけでした。
SELECT account_key, quarter, sum(balance),
ROW_NUMBER() over
(PARTITION BY account_key
ORDER BY quarter
RESET WHEN sum(balance) /* current row balance */ <=
SUM(sum(balance)) over (PARTITION BY account_key ORDER BY quarter
ROWS BETWEEN 1 PRECEDING AND 1 PRECEDING)/* prev row */
) - 1 /* to get the count started at 0 */ as balance_increase
FROM accounts
GROUP BY account_key, quarter;
上記の SELECT 文の結果は、たとえば以下のような表になります。
account_key
----------1
1
1
1
quarter
------1
2
3
4
balance
------253
258
192
150
balance_increase
---------------0
1
0
0
例
次の例では、RESET WHEN 句内の条件に、ネストされた subquery として SELECT
が含まれています。これは、許容されず、エラーになります。
SELECT SUM(a1) OVER
(ORDER BY 1
RESET WHEN 1 in (SELECT 1))
FROM t1;
$
*** Failure 3706 Syntax error: SELECT clause not supported in
RESET...WHEN clause.
ROWS 句
ROWS で、区分内の各行を求める集約関数の計算対象の行を定義します。
ROWS が指定される場合、区分内の各行を求める集約関数の計算には、ROWS 句の
中の行のサブセットのみが含まれます。
ROWS 句がない場合は、区分内のすべての行が計算に含まれます。
sales_tbl テーブルの店舗ごとの 3 か月の移動平均売上げを計算するには、次のよう
に StoreID 別に区分し、SMonth によって順序付けして、現在行から 2 つ前の行まで
を対象に計算を実行します。
910
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ関数
SELECT StoreID, SMonth, ProdID, Sales,
AVG(Sales) OVER (PARTITION BY StoreID
ORDER BY SMonth
ROWS BETWEEN 2 PRECEDING AND CURRENT ROW)
FROM sales_tbl;
StoreID
------1001
1001
1001
1001
1001
1001
1002
1002
1002
1002
1002
1002
SMonth
-----1
2
3
4
5
6
1
2
3
4
5
6
ProdID
-----C
C
C
C
C
C
C
C
C
C
C
C
Sales
--------35000.00
25000.00
40000.00
25000.00
30000.00
30000.00
40000.00
35000.00
110000.00
60000.00
35000.00
100000.00
Moving Avg(Sales)
----------------35000.00
30000.00
33333.33
30000.00
31666.67
28333.33
40000.00
37500.00
61666.67
68333.33
68333.33
65000.00
ウィンドウの複数指定
複数のウィンドウ関数を使用する SQL 文では、各ウィンドウ関数のウィンドウ指定
をそれぞれ固有のものにすることができます。
たとえば、次のような例があります。
SELECT StoreID, SMonth, ProdID, Sales,
AVG(Sales) OVER (PARTITION BY StoreID
ORDER BY SMonth
ROWS BETWEEN 2 PRECEDING AND CURRENT ROW),
RANK() OVER (PARTITION BY StoreID ORDER BY Sales DESC)
FROM sales_tbl;
関連トピック
詳細は、以下を参照してください。
• DEFAULT 関数について、詳細は DEFAULT を参照してください。
• ウィンドウ指定は、ユーザー定義の集約関数にも適用できます。詳細について
は、SQL UDF を参照してください。
SQL 関数、演算子、式および述部
911
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ集約関数
• OVER()句とそれに関連する句の構文については、ウィンドウ集約関数を参照して
ください。
ウィンドウ集約関数
ウィンドウ指定が適用される集約関数は、ウィンドウ集約関数と呼ばれます。ウィ
ンドウ指定がない場合、集約関数は、限定されたすべての対象行についての値を 1
つ戻します。ウィンドウ集約関数は、問合わせに含まれる限定行ごとに新しい値を
1 つ戻します。
例えば、集約 AVG を含む次の SELECT 文では、値(売上げの平均)が 1 つだけ戻され
ます。
SELECT AVG(sale)
FROM monthly_sales;
Average(sale)
------------1368
AVG ウィンドウ関数では、各限定行が保持されます。
たとえば次の SELECT 文は、以下に示す結果を戻します。
SELECT territory, smonth, sales,
AVG(sales) OVER (PARTITION BY territory
ORDER BY smonth ROWS 2 PRECEDING)
FROM sales_history;
territory
--------East
East
East
East
East
West
West
West
West
West
912
smonth
------199810
199811
199812
199901
199902
199810
199811
199812
199901
199902
sales
----10
4
10
7
10
8
12
7
11
6
Moving Avg(sales)
----------------10
7
8
7
9
8
10
9
10
8
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
ウィンドウ指定
目的
集約関数の累計、グループ、移動、または残存計算
構文
AVG
CORR
COUNT
A
(value_expression )
(value_expression_1, value_expression_2 )
value_expression
(
)
*
COVAR_POP
(value_expression_1, value_expression_2 )
COVAR_SAMP
(value_expression_1, value_expression_2 )
MAX
(value_expression )
MIN
(value_expression )
REGR_AVGX
(dependent_variable_expression_independentvariable_expression )
REGR_AVGY
(dependent_variable_expression_independentvariable_expression )
REGR_COUNT
(dependent_variable_expression_independentvariable_expression )
REGR_INTERCEPT
REGR_R2
(dependent_variable_expression_independentvariable_expression )
(dependent_variable_expression_independentvariable_expression )
REGR_SLOPE
(dependent_variable_expression_independentvariable_expression )
REGR_SXX
(dependent_variable_expression_independentvariable_expression )
REGR_SXY
(dependent_variable_expression_independentvariable_expression )
REGR_SYY
(dependent_variable_expression_independentvariable_expression )
STDDEV_POP
STDDEV_SAMP
SUM
VAR_POP
VAR_SAMP
A
SQL 関数、演算子、式および述部
(value_expression )
(value_expression )
(value_expression )
(value_expression )
(value_expression )
window
913
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
window
OVER
A
(
,
column_reference
PARTITION BY
A
B
,
ORDER BY
value_expression
ASC
DESC
NULLS FIRST
NULLS LAST
RESET WHEN condition
)
B
ROWS
UNBOUNDED PRECEDING
value
PRECEDING
CURRENT ROW
ROWS BETWEEN
UNBOUNDED PRECEDING AND
UNBOUNDED FOLLOWING
value
PRECEDING
CURRENT ROW
value
value
PRECEDING AND
FOLLOWING
UNBOUNDED FOLLOWING
value
PRECEDING
CURRENT ROW
value
CURRENT ROW AND
FOLLOWING
UNBOUNDED FOLLOWING
CURRENT ROW
value
value
FOLLOWING AND
FOLLOWING
UNBOUNDED FOLLOWING
value
FOLLOWING
構文要素
ASC
結果が昇順で整列されます。
整列フィールドが文字列の場合、システムは現在のセッションの照合順序の定義に
従って、昇順で整列します。
デフォルトの順序は ASC です。
OVER
累計、グループ、または移動関数を計算する際に、値をグループ化、順序付け、お
よび処理対象とする方法。
914
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
値は、PARTITION BY 句および RESET WHEN 句に基づいてグループ化され、ORDER
BY 句に基づいて整列され、パーティション内の集約グループに基づいて処理の対象
とされます。
PARTITION BY
column_reference の中に、または列参照のカンマ区切りのリストで、関数の実行対
象のグループを指定(複数も可)。
PARTITION BY は任意指定です。PARTITION BY 句または RESET WHEN 句を指定し
ない場合は、FROM 句から送られる結果セット全体が、単一のグループまたはパー
ティションとなります。
PARTITION BY 句は、ウィンドウ パーティション句と呼ばれることもあります。
ORDER BY
value_expression の中の、グループまたはパーティション内の値の整列順序。
DESC
結果が降順で整列されます。
整列フィールドが文字列の場合、システムは現在のセッションの照合順序の定義に
従って、降順で整列します。
NULLS FIRST
NULL 結果が最初にリストされることを指定します。
NULLS LAST
NULL 結果が最後にリストされることを指定します。
RESET WHEN
順序付き分析関数の実行対象になるグループまたはパーティション。指定された条
件の評価に応じて変化します。条件が TRUE と評価されると、指定されたウィンド
ウ パーティション内に新しい動的パーティションが作成されます。
RESET WHEN は任意指定です。RESET WHEN 句または PARTITION BY 句を指定し
ない場合は、FROM 句から送られる結果セット全体が単一のパーティションになり
ます。
RESET WHEN を指定する場合は、ORDER BY 句も指定する必要があります。
condition
条件によるパーティション化を決めるために使用する条件式。RESET WHEN 句の条
件は、QUALIFY 句の条件と適用範囲は同じですが、ネストされた順序付き分析関数
は RESET WHEN 句を指定できないという追加の制約があります。また、条件内の
subquery としての SELECT は指定できません。
条件は、指定されたすべてのウィンドウ パーティション内の行に適用され、その
ウィンドウ パーティション内にサブ パーティションを作成します。
SQL 関数、演算子、式および述部
915
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
ROWS
区分内の集約グループの開始ポイント。集約グループの終了ポイントは現在行にな
ります。
行 R の集約グループは、区分内の行の順序付けでの R に対して定義される行の集合
です。
ROWS または ROWS BETWEEN 句がない場合のデフォルトの集約グループは、ROWS
BETWEEN UNBOUNDED PRECEDING AND UNBOUNDED FOLLOWING です。
FIRST_VALUE/LAST_VALUE に対し ROWS 句がない場合のデフォルトは異なります。
「FIRST_VALUE/LAST_VALUE」を参照してください。
ROWS BETWEEN
集約グループの開始と終了。これにより、パーティション内の行の順序付けで現在
行に関連した行の集合を定義します。
グループ開始として指定される行は、グループ終了として指定される行より前にな
ければなりません。
ROWS または ROWS BETWEEN 句がない場合のデフォルトの集約グループは、ROWS
BETWEEN UNBOUNDED PRECEDING AND UNBOUNDED FOLLOWING です。
UNBOUNDED PRECEDING
現在行より前にあるパーティション全体。
UNBOUNDED FOLLOWING
現在行より後にあるパーティション全体。
CURRENT ROW
現在行の集約グループの開始または終了。
value PRECEDING
現在行より前にある行の数。
value の値は、常に正の整数リテラルです。
value PRECEDING がグループの開始またはグループの終了になる場合、集約グルー
プ内の行の最大数は 4096 です。
value FOLLOWING
現在行より後にある行の数。
value の値は、常に正の整数リテラルです。
value FOLLOWING がグループの開始またはグループの終了になる場合、集約グルー
プ内の行の最大数は 4096 です。
916
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
ANSI への準拠
この文は、ANSI SQL:2011 に準拠していますが、非 ANSI の Teradata Database 拡
張機能が含まれています。
ORDER BY 句が存在し、ROWS または ROWS BETWEEN 句がない状況では、ANSI
SQL:2011 ウィンドウ集約関数は ROWS UNBOUNDED PRECEDING をデフォルトの
集約グループとして使用しますが、Teradata SQL ウィンドウ集約関数は ROWS
BETWEEN UNBOUNDED PRECEDING AND UNBOUNDED FOLLOWING を使用しま
す。
計算のタイプ
関数の計算対象の 使用する集約グループ
タイプ
累積
• ROWS UNBOUNDED PRECEDING
• ROWS BETWEEN UNBOUNDED PRECEDING AND value PRECEDING
• ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW
• ROWS BETWEEN UNBOUNDED PRECEDING AND value FOLLOWING
グループ
ROWS BETWEEN UNBOUNDED PRECEDING AND UNBOUNDED FOLLOWING
移動
• ROWS value PRECEDING
• ROWS CURRENT ROW
• ROWS BETWEEN value PRECEDING AND value PRECEDING
• ROWS BETWEEN value PRECEDING AND CURRENT ROW
• ROWS BETWEEN value PRECEDING AND value FOLLOWING
• ROWS BETWEEN CURRENT ROW AND CURRENT ROW
• ROWS BETWEEN CURRENT ROW AND value FOLLOWING
• ROWS BETWEEN value FOLLOWING AND value FOLLOWING
残存
• ROWS BETWEEN value PRECEDING AND UNBOUNDED FOLLOWING
• ROWS BETWEEN CURRENT ROW AND UNBOUNDED FOLLOWING
• ROWS BETWEEN value FOLLOWING AND UNBOUNDED FOLLOWING
ウィンドウ集約関数への引数
ウィンドウ集約関数は、リテラル、リテラル式、列名(sales など)、または列式(sales
+ profit など)を引数として取ることができます。
ウィンドウ集約では、通常の集約を PARTITION BY 句と ORDER BY 句の入力パラ
メータとして受け取ることもできます。RESET WHEN 句では、RESET WHEN 条件
句の一部として集約を受け取ることができます。
COUNT は、以下の SQL 問合わせのように、「*」を入力引数として取ることができ
ます。
SQL 関数、演算子、式および述部
917
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
SELECT city, kind, sales, profit,
COUNT(*) OVER (PARTITION BY city, kind
ROWS BETWEEN UNBOUNDED PRECEDING AND
UNBOUNDED FOLLOWING)
FROM activity_month;
結果のタイプと書式
ウィンドウ集約関数の結果のデータ タイプと書式は以下のとおりです。
関数
結果のタイプ
書式
AVG(x)
FLOAT
FLOAT のデフォル
ト書式
FLOAT
オペランド x と同
じ書式
FLOAT
FLOAT のデフォル
ト書式
オペランド x と同じデータ タイプ
オペランド x の
データ タイプのデ
フォルトの書式
x が文字型の場合
AVG(x)
x が数値、DATE、または
INTERVAL 型の場合
CORR(x,y)
COVAR_POP(x,y)
COVAR_SAMP(x,y)
REGR_AVGX( y,x)
REGR_AVGY( y,x)
REGR_INTERCEPT(x,y)
REGR_R2(x,y)
REGR_SLOPE(x,y)
REGR_SXX(x,y)
REGR_SXY(x,y)
REGR_SYY(x,y)
STDDEV_POP(x,)
STDDEV_SAMP(x,)
VAR_POP(x,)
VAR_SAMP(x)
x が文字型の場合
CORR(x,y)
COVAR_POP(x,y)
COVAR_SAMP(x,y)
REGR_AVGX(y,x)
REGR_AVGY( y,x)
REGR_INTERCEPT(x,y)
REGR_R2(x,y)
REGR_SLOPE(x,y)
REGR_SXX(x,y)
918
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
関数
結果のタイプ
書式
REGR_SXY(x,y)
REGR_SYY(x,y)
STDDEV_POP(x)
STDDEV_SAMP(x)
VAR_POP(x)
VAR_SAMP(x)
x が以下のいずれかの型の
場合
• 数値
• DATE
• 間隔
REGR_AVGX(y,x)
REGR_AVGY(y, x)
UDT の暗黙キャス
ト先のデータ タイ
プのデフォルト書
式。
x は UDT
COUNT(x)
COUNT(*)
REGR_COUNT(x ,y)
DBSControl 内の MaxDecimal の値
• 0 または 15。結果の型は DECIMAL(15,0)、フォーマットは(15)9。
トランザクション モード • 18。結果の型は DECIMAL(18,0)、フォーマットは-(18)9。
• 38。結果の型は DECIMAL(38,0)、フォーマットは-(38)9。
が ANSI の場合
テーブルでは、INTEGER の範囲を超えることがあるので、ANSI
トランザクション モードでは、DECIMAL が使用されます。
COUNT(x)
COUNT(*)
REGR_COUNT(x,y)
INTEGER
MAX(x), MIN(x)
オペランド x と同じデータ タイプ
オペランド x と同
じ書式
SUM(x)
オペランド x と同じ。
FLOAT のデフォル
ト書式
Teradata トランザクション モードでは、退
行問題を避けるために、INTEGER が使用さ
トランザクション モード れます。
が Teradata の場合
注: COUNT ウィンドウ集約関数の最終結果
はキャストできます。ただし、COUNT 集約
関数のようにウィンドウ関数の計算の一部
としてキャストが使用されることはありま
せん。そのため、計算中に発生するおそれ
のある数値のオーバーフロー エラーを回避
するためにキャストを使用することはでき
ません。
SQL 関数、演算子、式および述部
INTEGER のデフォ
ルト書式
919
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
関数
結果のタイプ
書式
x が文字型の場合
SUM(x)
x が DECIMAL(n,m)型の
場合
DECIMAL(p,m)。このとき、p は次の規則に DECIMAL のデフォ
従って決定されます。
ルト書式
DBSControl 内の MaxDecimal が 0 または
15 である場合
• n ≤ 15 の場合、p = 15。
• 15 < n ≤ 18, p = 18.
• n > 18 の場合、p = 38。
DBSCControl 内の MaxDecimal が 18 であ
る場合
• n ≤ 18 の場合、p = 18。
• n > 18 の場合、p = 38。
DBSControl の MaxDecimal が 38 で n が任
意の値である場合、p = 38。
SUM(x)
オペランド x と同じ。
オペランドのデー
タ タイプのデフォ
ルトの書式
x が DECIMAL 以外の数
値型の場合
結果のタイトル
表示結果または印刷結果の見出しに表示されるデフォルト タイトルは、実行される
計算のタイプによって異なります。
計算のタイプ
結果のタイトル
累計
Cumulative Function_name (argument_list)
たとえば、次の計算を考えてみましょう。
SELECT AVG(sales) OVER (PARTITION BY region
ORDER BY smonth ROWS UNBOUNDED PRECEDING)
FROM sales_history;
結果の見出しに表示されるタイトルは以下のようになります。
Cumulative Avg(sales)
グループ
Group Function_name (argument_list)
たとえば、次の計算を考えてみましょう。
SELECT AVG(sales) OVER (PARTITION BY region
ORDER BY smonth ROWS BETWEEN UNBOUNDED
920
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
計算のタイプ
結果のタイトル
PRECEDING AND UNBOUNDED FOLLOWING)
FROM sales_history;
結果の見出しに表示されるタイトルは以下のようになります。
Group Avg(sales)
移動
Moving Function_name (argument_list)
たとえば、次の計算を考えてみましょう。
SELECT AVG(sales) OVER (PARTITION BY region
ORDER BY smonth ROWS 2 PRECEDING)
FROM sales_history;
結果の見出しに表示されるタイトルは以下のようになります。
Moving Avg(sales)
残存
Remaining Function_name (argument_list)
たとえば、次の計算を考えてみましょう。
SELECT AVG(sales) OVER (PARTITION BY region
ORDER BY smonth ROWS BETWEEN CURRENT ROW
AND UNBOUNDED FOLLOWING)
FROM sales_history;
結果の見出しに表示されるタイトルは以下のようになります。
Remaining Avg(sales)
データが欠けている場合の問題
分析するデータに、欠けているデータ ポイントがないことを確認してください。欠
けているポイントがあるデータに関して移動関数を計算すると、予期しない不正確
な結果が生成されます。なぜなら、n 個の論理データ ポイントではなく、n 個の物
理データ行が計算の対象になるからです。
ウィンドウ関数内での集約のネスト
ウィンドウ関数(選択リスト、HAVING、QUALIFY、ORDER BY 句など)内に集約をネ
ストできますが、HAVING には RANK() OVER (ORDER BY SUM(x))のようなネストさ
れた構文を含めることができないため、HAVING 句に含めることができるのは集約
関数の参照のみです。
Teradata 固有の関数を使用して集約関数を指定することはできません。
SQL 関数、演算子、式および述部
921
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
例
次の問合わせは、選択リストに含まれる RANK 順序付き分析関数内に SUM 集約関数
をネストします。
SELECT state, city, SUM(sale),
RANK() OVER (PARTITION BY state ORDER BY SUM(sale))
FROM T1
WHERE T1.cityID = T2.cityID
GROUP BY state, city
HAVING MAX(sale) > 10;
代替手段: 派生テーブルの使用
集約を同じ SELECT リストにまとめて指定するのに使用できるのはウィンドウ関数
のみですが、派生テーブルまたはビューを使用して、ウィンドウ関数と Teradata 固
有の関数を集約と組み合わせることができます。派生テーブルまたはビューを使用
すると、計算の意味体系を明確にすることにもなります。
例
以下の例は、店舗内の特定の製品の売上げ順位と、各店舗のトップ 3 の製品が店舗
売上げ全体に占める割合を示したものです。
SELECT RT.storeid, RT.prodid, RT.sales,
RT.rank_sales, RT.sales * 100.0/ST.sum_store_sales
FROM (SELECT storeid, prodid, sales, RANK(sales) AS rank_sales
FROM sales_tbl
GROUP BY storeID
QUALIFY RANK(sales) <=3) AS RT,
(SELECT storeID, SUM(sales) AS sum_store_sales
FROM sales_tbl
GROUP BY storeID) AS ST
WHERE RT.storeID = ST.storeID
ORDER BY RT.storeID, RT.sales;
結果のテーブルは、たとえば以下のようになります。
922
storeID
prodID
sales
1001
D
35000.00 3
17.949
1001
C
60000.00 2
30.769
1001
A
100000.0 1
0
51.282
1002
D
25000.00 3
25.000
1002
C
35000.00 2
35.000
1002
A
40000.00 1
40.000
rank_sales
sales*100.0/sum_store_sales
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
storeID
prodID
sales
rank_sales
sales*100.0/sum_store_sales
1003
C
20000.00 3
20.000
1003
A
30000.00 2
30.000
1003
D
50000.00 1
50.000
...
...
...
...
順序付き分析関数に代わる Teradata 固有の構文
Teradata SQL は、順序付き分析関数の 2 つの代替構文をサポートしています。
• Teradata 固有
• ANSI SQL:2011 準拠
ウィンドウ集約、順位、分布、および行番号関数は ANSI SQL:2011 に準拠していま
す。一方、Teradata 固有の関数は準拠していません。
Teradata 固有の関数および ANSI SQL:2011 ウィンドウ関数
次の表は、Teradata 固有の関数に相当する ANSI SQL:2011 ウィンドウ関数を示し
たものです。
注: 以下の表にリストされている、Teradata 固有の関数の使用は強く推奨されませ
ん。それらの関数は、既存のアプリケーションとの下位互換性のためにのみ残され
ています。新規アプリケーションを開発する場合は、ANSI 準拠のウィンドウ関数を
使用するようにしてください。
Teradata 固有の関数
対応する ANSI SQL:2011 ウィンドウ関数
CSUM
SUM
MAVG
AVG
MDIFF(x, w, y)
SUM から構成可能
MLINREG
SUM および COUNT から構成可能
QUANTILE
RANK および COUNT から構成可能
RANK
RANK
MSUM
SUM
ウィンドウ集約関数と Teradata 固有の関数の比較
ANSI 準拠にして移植可能にするアプリケーションでは、 MAVG、CSUM、および
MSUM などの Teradata 固有の関数の使用は避けてください。
SQL 関数、演算子、式および述部
923
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
ANSI
関数
Teradata 関係
関数
AVG
MAVG
ROWS value PRECEDING の集約グループを指定する AVG ウィンドウ
関数の形式は、Teradata 固有の関数 MAVG に相当する ANSI の形式で
す。
ROWS value PRECEDING 句は、現在行との移動合計の計算対象とな
る、現在行に先行する行の合計数を指定することに注意してください。
集約グループ内の行の合計数は value + 1 です。MAVG 関数の場合の
集約グループ内の行の合計数は width の値です。
AVG ウィンドウ関数の場合、たとえば ROWS 5 PRECEDING の集約グ
ループを指定すると、移動平均の計算対象として、現在行とそれに先
行する 5 つの行が使用されることになります。したがって、区分の 6
番目の行の移動平均は、行 6、5、4、3、2、1 (つまり、全部で 6 行)
が対象になります。
MAVG 関数の場合、width が 5 であれば、現在行とそれに先行する 4
つの行が移動平均の計算に使用されます。したがって、6 番目の行の
移動平均は、行 6、5、4、3、2 (つまり、全部で 5 行)が対象になりま
す。
SUM
CSUM
MSUM
新規アプリケーションを開発する場合は、ANSI 準拠の SUM ウィンド
ウ関数を使用するようにしてください。ANSI 準拠にして移植可能にす
るアプリケーションでは、CSUM および MSUM の使用は避けてくださ
い。
ここでは、SUM ウィンドウ関数と、Teradata 固有の関数である CSUM
関数および MSUM 関数との関係について、それぞれ説明します。
• ORDER BY 句を使い、なおかつ ROWS UNBOUNDED PRECEDING
を指定する SUM ウィンドウ関数は、CSUM の ANSI 版と言えます。
• ORDER BY 句を使い、なおかつ ROWS value PRECEDING を指定す
る SUM ウィンドウ関数は、MSUM の ANSI 版と言えます。
ROWS value PRECEDING 句は、現在行との移動合計の計算対象と
なる、現在行に先行する行の合計数を指定することに注意してくだ
さい。集約グループ内の行の合計数は value + 1 です。MSUM 関数
の場合の集約グループ内の行の合計数は width の値です。
したがって、移動合計を計算する SUM ウィンドウ関数の場合、
ROWS 5 PRECEDING の集約グループを指定すると、移動合計の計
算対象として、現在行とそれに先行する 5 つの行が使用されること
になります。たとえば、区分の 6 番目の行の移動合計は、行 6、5、
4、3、2、1 (つまり、全部で 6 行)が対象になります。
924
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
ANSI
関数
Teradata 関係
関数
MSUM 関数の場合、width が 5 であれば、現在行とそれに先行す
る 4 つの行が移動合計の計算に使用されます。したがって、たとえ
ば 6 番目の行の移動合計は、行 6、5、4、3、2 (つまり、全部で 5
行)が対象になります。
さらに、行の数が width 個よりも少ないデータの場合、MSUM は、
先行するすべての行を使って合計を計算します。MSUM は、サン
プル内の行の数が width よりも少ない場合、null ではなく現在の合
計を返します。
例: グループ カウント
以下の SQL 問合わせを実行すると、その次にあるような結果が生成されます。この
結果では、city と kind で定義した 4 つの各パーティションについて、売上げのグ
ループ カウントが戻されています。売上げのない行がカウントされていないことに
注意する必要があります。
SELECT city, kind, sales, profit,
COUNT(sales) OVER (PARTITION BY city, kind
ROWS BETWEEN UNBOUNDED PRECEDING AND
UNBOUNDED FOLLOWING)
FROM activity_month;
city
------LA
LA
LA
LA
LA
LA
Seattle
Seattle
Seattle
Seattle
Seattle
kind
-------Canvas
Canvas
Canvas
Canvas
Leather
Leather
Canvas
Canvas
Canvas
Leather
Leather
sales
----45
125
125
20
20
?
15
20
20
35
?
profit
-----320
190
400
120
40
?
30
30
100
50
?
Group Count(sales)
-----------------4
4
4
4
1
1
3
3
3
1
1
例: 残存カウント
売上げが入っていない行を含む、すべての行をカウントするには、COUNT(*)を使用
します。現在行より後のパーティションに残っている行の数をカウントする例を次
に示します。
SELECT city, kind, sales, profit,
COUNT(*) OVER (PARTITION BY city, kind ORDER BY profit DESC
SQL 関数、演算子、式および述部
925
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
ROWS BETWEEN 1 FOLLOWING AND UNBOUNDED FOLLOWING)
FROM activity_month;
city
------LA
LA
LA
LA
LA
LA
Seattle
Seattle
Seattle
Seattle
Seattle
kind
-------Canvas
Canvas
Canvas
Canvas
Leather
Leather
Canvas
Canvas
Canvas
Leather
Leather
sales
----20
125
45
125
?
20
15
20
20
?
35
profit
-----120
190
320
400
?
40
30
30
100
?
50
Remaining Count(*)
-----------------?
1
2
3
?
1
?
1
2
?
1
ウィンドウ指定で指定する並替え順序によって関数の適用対象の行の並替え順序が
定義されますが、それによって結果の順序が定義されるわけではないことに注意し
てください。
この例では計算には DESC 並替え順序が指定されていますが、結果はその逆の順序
で戻されています。
結果を順序付けするには、次のように、SELECT 文で ORDER BY 句を使用します。
SELECT city, kind, sales, profit,
COUNT(*) OVER (PARTITION BY city, kind ORDER BY profit DESC
ROWS BETWEEN 1 FOLLOWING AND
UNBOUNDED FOLLOWING)
FROM activity_month
ORDER BY city, kind, profit DESC;
city
------LA
LA
LA
LA
LA
LA
Seattle
Seattle
Seattle
Seattle
Seattle
926
kind
-------Canvas
Canvas
Canvas
Canvas
Leather
Leather
Canvas
Canvas
Canvas
Leather
Leather
sales
----125
45
125
20
20
?
20
20
15
35
?
profit
-----400
320
190
120
40
?
100
30
30
50
?
Remaining Count(*)
-----------------3
2
1
?
1
?
2
1
?
1
?
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
例: 累計最大
以下の SQL 問合わせを実行すると、その次にあるような結果が生成されます。この
結果では、city と kind で定義した区分のそれぞれについて、売上げの累積最大値が
戻されています。
SELECT city, kind, sales, week,
MAX(sales) OVER (PARTITION BY city, kind
ORDER BY week ROWS UNBOUNDED PRECEDING)
FROM activity_month;
city
------LA
LA
LA
LA
LA
LA
LA
LA
Seattle
Seattle
Seattle
Seattle
Seattle
Seattle
Seattle
Seattle
kind
-------Canvas
Canvas
Canvas
Canvas
Leather
Leather
Leather
Leather
Canvas
Canvas
Canvas
Leather
Leather
Leather
Leather
Leather
sales
----263
294
321
274
144
826
489
555
100
182
94
933
840
899
915
462
week
---16
17
18
20
16
17
20
21
16
17
18
16
17
18
19
20
Cumulative Max(sales)
--------------------263
294
321
321
144
826
826
826
100
182
182
933
933
933
933
933
例: 累積最小
以下の SQL 問合わせを実行すると、その次にあるような結果が生成されます。この
結果では、city と kind で定義した区分のそれぞれについて、売上げの累積最小値が
戻されています。
SELECT city, kind, sales, week,
MIN(sales) OVER (PARTITION BY city, kind
ORDER BY week
ROWS UNBOUNDED PRECEDING)
FROM activity_month;
city
------LA
LA
SQL 関数、演算子、式および述部
kind
-------Canvas
Canvas
sales
----263
294
week
---16
17
Cumulative Min(sales)
--------------------263
263
927
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
LA
LA
LA
LA
LA
LA
Seattle
Seattle
Seattle
Seattle
Seattle
Seattle
Seattle
Seattle
Canvas
Canvas
Leather
Leather
Leather
Leather
Canvas
Canvas
Canvas
Leather
Leather
Leather
Leather
Leather
321
274
144
826
489
555
100
182
94
933
840
899
915
462
18
20
16
17
20
21
16
17
18
16
17
18
19
20
263
263
144
144
144
144
100
100
94
933
840
840
840
462
例: 累積合計
以下の問合わせは、取引日付の順序で並べた口座ごとの累積残高を戻します。
SELECT acct_number, trans_date, trans_amount,
SUM(trans_amount) OVER (PARTITION BY acct_number
ORDER BY trans_date
ROWS UNBOUNDED PRECEDING) as balance
FROM ledger
ORDER BY acct_number, trans_date;
上記の SELECT の結果の例を示します。
acct_number
trans_date
trans_amount
balance
73829
1998-11-01
113.45
113.45
73829
1988-11-05
-52.01
61.44
73929
1998-11-13
36.25
97.69
82930
1998-11-01
10.56
10.56
82930
1998-11-21
32.55
43.11
82930
1998-11-29
-5.02
38.09
例: グループ合計
以下の問合わせは、各都市の肉の売上げの総合計を示します。
SELECT city, kind, sales,
SUM(sales) OVER (PARTITION BY city ROWS BETWEEN UNBOUNDED PRECEDING
AND UNBOUNDED FOLLOWING) FROM monthly;
上記の SELECT 文の結果は、たとえば以下のような表になります。
928
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
city
kind
sales
Group Sum (sales)
Omaha
pure pork
45
220
Omaha
pure pork
125
220
Omaha
pure pork
25
220
Omaha
variety pack
25
220
Chicago
variety pack
55
175
Chicago
variety pack
45
175
Chicago
pure pork
50
175
Chicago
variety pack
25
175
例: グループ合計
以下の問合わせは、すべての都市の肉の売上げの総合計を戻します。SUM 関数に
PARTITION BY 句がないため、グループ合計にすべての都市が含まれることに注意
する必要があります。
SELECT city, kind, sales,
SUM(sales) OVER (ROWS BETWEEN UNBOUNDED PRECEDING AND
UNBOUNDED FOLLOWING)
FROM monthly;
上記の SELECT 文の結果は、たとえば以下のような表になります。
city
kind
sales
Group Sum (sales)
Omaha
pure pork
45
395
Omaha
pure pork
125
395
Omaha
pure pork
25
395
Omaha
variety pack
25
395
Chicago
variety pack
55
395
Chicago
variety pack
45
395
Chicago
pure pork
50
395
Chicago
variety pack
25
395
例: 移動合計
以下の問合わせは、都市ごとの肉の売上げの移動合計を戻します。問合わせが、都
市(区分)ごとに、区分の現在行とそれに先行する 3 つの行(可能な場合)について、売
上げの移動合計を戻していることに注意する必要があります。
肉の種類が戻されている順序は、利益に基づくデフォルトの昇順になっています。
SQL 関数、演算子、式および述部
929
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
売上げの数字がない場合は、売上げの移動合計を計算することはできません。この
場合、sum(sales)列は null になります。
SELECT city, kind, sales, profit,
SUM(sales) OVER (PARTITION BY city, kind
ORDER BY profit ROWS 3 PRECEDING)
FROM monthly;
930
city
kind
sales
profit
Moving sum (sales)
Omaha
pure pork
25
40
25
Omaha
pure pork
25
120
50
Omaha
pure pork
45
140
95
Omaha
pure pork
125
190
220
Omaha
pure pork
45
320
240
Omaha
pure pork
1255
400
340
Omaha
variety pack
?
?
?
Omaha
variety pack
25
40
25
Omaha
variety pack
25
120
50
Chicago
pure pork
?
?
?
Chicago
pure pork
15
10
15
Chicago
pure pork
54
12
69
Chicago
pure pork
14
20
83
Chicago
pure pork
54
24
137
Chicago
pure pork
14
34
136
Chicago
pure pork
95
80
177
Chicago
pure pork
95
140
258
Chicago
pure pork
15
220
219
Chicago
variety pack
23
39
23
Chicago
variety pack
25
40
48
Chicago
variety pack
125
70
173
Chicago
variety pack
125
100
298
Chicago
variety pack
23
100
298
Chicago
variety pack
25
120
298
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
例: 残存合計
以下の問合わせは、すべての都市の肉の売上げの残存合計を戻します。SUM 関数に
PARTITION BY 句がないため、残存合計にすべての都市が含まれることに注意する
必要があります。
SELECT city, kind, sales,
SUM(sales) OVER (ORDER BY city, kind
ROWS BETWEEN 1 FOLLOWING AND UNBOUNDED FOLLOWING)
FROM monthly;
上記の SELECT 文の結果は、たとえば以下のような表になります。
city
------Omaha
Omaha
Omaha
Omaha
Chicago
Chicago
Chicago
Chicago
kind
------------variety pack
pure pork
pure pork
pure pork
variety pack
variety pack
variety pack
pure pork
sales
------25
125
25
45
55
25
45
50
Remaining Sum(sales)
-------------------?
25
150
175
220
275
300
345
計算の並替え順序は、まず city 単位でアルファベット順、そして kind 単位でアル
ファベット順であることに注意してください。しかし結果は、その逆の順序で表示
されます。
ウィンドウ指定で指定する並替え順序によって関数の適用対象の行の並替え順序が
定義されますが、それによって結果の順序が定義されるわけではありません。結果
を順序付けするには、SELECT 文で ORDER BY 句を使用します。
以下に例を示します。
SELECT city, kind, sales,
SUM(sales) OVER (ORDER BY city, kind
ROWS BETWEEN 1 FOLLOWING AND UNBOUNDED FOLLOWING)
FROM monthly
ORDER BY city, kind;
上記の SELECT 文の結果は、たとえば以下のような表になります。
city
------Chicago
Chicago
Chicago
Chicago
Omaha
kind
------------pure pork
variety pack
variety pack
variety pack
pure pork
SQL 関数、演算子、式および述部
sales
------50
55
25
45
25
Remaining Sum(sales)
-------------------345
265
320
220
70
931
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
Omaha
Omaha
Omaha
pure pork
pure pork
variety pack
125
45
25
95
25
?
計算対象
使用する関数
累積合計
• SUM ウィンドウ関数
• CSUM
累計、グループ、または移動カウント
COUNT ウィンドウ関数
グループ合計
SUM ウィンドウ関数
移動平均
• AVG ウィンドウ関数
• MAVG
現在の行列値と、それに先行する n 番目の行列値との
間の移動差分
MDIFF
移動線形回帰
MLINREG
移動合計
• SUM ウィンドウ関数
• MSUM
列の値の分位スコア
QUANTILE
グループ内のすべての行の順序付き順位
• RANK ウィンドウ関数
• RANK
グループ内の行の相対的な順位
PERCENT_RANK ウィンドウ関数
ウィンドウのウィンドウ順序に基づく、そのウィンド
ウ パーティション内の行の順次行番号
ROW_NUMBER
累計、グループ、または移動最大値
MAX ウィンドウ関数
累計、グループ、または移動最小値
MIN ウィンドウ関数
GROUP BY 句
GROUP BY とウィンドウ関数
ウィンドウ関数の場合、GROUP BY 句には、以下のものに指定されている列がすべ
て含まれていなければなりません。
•
•
•
•
932
SELECT 句の選択リスト
SELECT 句の選択リストのウィンドウ関数
QUALIFY 句の検索条件のウィンドウ関数
RESET WHEN 句内の条件
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
たとえば、次の SELECT 文の場合、選択リストの中で列 City が指定されており、選
択リストの COUNT ウィンドウ関数の中と QUALIFY 句の中で列 StoreID が指定され
ています。どちらの列も、GROUP BY 句でも指定されています。
SELECT City, StoreID, COUNT(StoreID) OVER ()
FROM sales_tbl
GROUP BY City, StoreID
QUALIFY COUNT(StoreID) >=3;
ウィンドウ関数の場合、GROUP BY は group-by 列に同じ値が入っているすべての
行を 1 つの行に圧縮します。
たとえば、次の文では GROUP BY 句を使用することにより、City と StoreID が同じ
値の行をすべて 1 つの行に圧縮します。
SELECT City, StoreID, COUNT(StoreID) OVER ()
FROM sales_tbl
GROUP BY City, StoreID;
結果は次のようになります。
City
----Pecos
Pecos
Ozona
StoreID
------1001
1002
1003
Group Count(StoreID)
-------------------3
3
3
GROUP BY を使用しない場合の結果は次のようになります。
City
----Pecos
Pecos
Pecos
Pecos
Pecos
Pecos
Pecos
Ozona
Ozona
StoreID
------1001
1001
1001
1001
1002
1002
1002
1003
1003
Group Count(StoreID)
-------------------9
9
9
9
9
9
9
9
9
GROUP BY と Teradata 固有の関数
Teradata 固有の関数の場合、GROUP BY は関数の実行対象の区分を決定します。こ
の句は、group-by 列に同じ値が入っているすべての行を 1 つの行に圧縮することを
しない。したがって、このような場合に GROUP BY 句に必要なのは、関数の区分化
列を指定することだけです。
たとえば、次の文は GROUP BY 句を使用して店舗ごとの連続売上げを計算して、
sales_tbl 内のデータを StoreID 別に区分します。
SQL 関数、演算子、式および述部
933
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
SELECT StoreID, Sales, CSUM(Sales, StoreID)
FROM sales_tbl
GROUP BY StoreID;
結果は次のようになります。
StoreID
------1001
1001
1001
1001
1002
1002
1002
1003
1003
Sales
-------1100.00
400.00
1000.00
2000.00
500.00
1500.00
2500.00
1000.00
3000.00
CSum(Sales,StoreID)
------------------1100.00
1500.00
2500.00
4500.00
500.00
2000.00
4500.00
1000.00
4000.00
ウィンドウ関数、Teradata 固有の関数、および GROUP BY の組み合わせ
次の表は、ウィンドウ関数、Teradata 固有の関数、集約関数、および GROUP BY 句
の使用可能な組み合わせの意味を示したものです。
組み合わせ
ウィンド
ウ関数
Teradata 固有の 集約関数
関数
意味構造
GROUP BY
句
X
値は行ごとに計算される。
X
値は行ごとに計算される。テーブ
ル全体が、Teradata 固有の関数の
実行対象の単一のグループ(区分)を
構成する。
X
X
X
X
934
テーブル全体で 1 つの集約値が計
算される。
X
GROUP BY は、group-by 列に同じ
値が入っているすべての行を 1 つ
の行に圧縮する。値は結果行ごと
に計算される。
X
GROUP BY は、Teradata 固有の関
数の実行対象の区分を決定する。
この句は、group-by 列に同じ値が
入っているすべての行を 1 つの行
に圧縮することをしない。
X
集約はグループごとに行なわれる。
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
ウィンドウ指定
組み合わせ
ウィンド
ウ関数
Teradata 固有の 集約関数
関数
X
X
X
X
X
意味構造
GROUP BY
句
Teradata 固有の関数は区分を持た
ない。テーブル全体が 1 つの区分
になる。
X
X
GROUP BY は、Teradata 固有の関
数の区分を決定する。GROUP BY
は、group-by 列に同じ値が入って
いるすべての行を 1 つの行に圧縮
することをしない。また GROUP
BY は、ウィンドウ関数の計算には
影響しない。
X
GROUP BY は、group-by 列に同じ
値が入っているすべての行を 1 つ
の行に圧縮する。ウィンドウ関数
の場合、値は結果行ごとに計算さ
れる。集約関数の場合、集約はグ
ループごとに行なわれる。
SELECT Sum の結果オーバーフローが発生する可能性
この関数を使用する場合に、データ タイプおよび書式が一致していないと、オー
バーフローが発生することがあります。列を次のように定義したとします。
Salary Decimal(15,2) Format '$ZZZ,ZZ9.99'
以下の問合わせを実行します。
SELECT SUM (Salary) FROM Employee;
小数オペランドおよび書式が一致していないため、オーバーフローが発生します。
オーバーフローが発生する可能性を回避するには、結果のデータ タイプでの、その
小数の合計が収まる十分な大きさで、小数の合計の書式を明示的に指定します。
SELECT Sum(Salary) (format '$Z,ZZZ,ZZZ,ZZ9.99) FROM Employee;
関連トピック
詳細は、以下を参照してください。
• 集約関数および引数の説明については、「集約関数」を参照してください。
• 詳細については、 SQL データ操作言語、B035-1146 の「RESET WHEN 条件の
ルール」と「QUALIFY 句」を参照してください。
• データ タイプのデフォルトの書式、および書式における書式設定文字について
の説明は、<SQL データ型とリテラル>の「データ タイプの書式および書式句」
を参照してください。
SQL 関数、演算子、式および述部
935
第 22 章 順序付き分析関数/ウィンドウ集約関数
CSUM
CSUM
目的
パーティション内の行を sort_expression リストによって整列するという前提で、
パーティション内の各行について、値式の累積合計(または現在までの合計)を戻しま
す。
タイプ
Teradata 固有の関数
構文
CSUM
(
value_expression,
,
sort_expression
(
ASC
DESC
構文要素
value_expression
連続合計を計算するための数値リテラルまたは列式。
デフォルトで CSUM は value_expression のデフォルト データ型を使用します。より
大きな数値は、これをより高位のデータ型にキャストすることによってサポートさ
れます。
この式に順序付き分析関数や集約関数を含めることはできません。
sort_expression
値の並べ替えに使用するリテラルまたは列式、あるいはリテラルまたは列式のカン
マ区切りリスト。
この式に順序付き分析関数や集約関数を含めることはできません。
ASC
昇順の整列順序。
デフォルトは ASC です。
DESC
降順の整列順序。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
936
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
CSUM
CSUM に代わる SUM の使用
CSUM は使用しないようにしてください。これは ANSI SQL:2011 規格の Teradata
拡張機能であり、集約グループとして ROWS UNBOUNDED PRECEDING を指定する
ANSI 準拠の SUM ウィンドウ関数に相当するものです。CSUM は、既存のアプリ
ケーションとの下位互換性のためにのみ残されています。
累積合計の意味
CSUM は、各行に SUM の現在値を与えながら、行の順序セットの合計を累積して
いきます。
SELECT Sum の結果オーバーフローが発生する可能性
SELECT Sum の結果オーバーフローが発生する可能性
この関数を使用する場合に、データ型とフォーマットが同期していないと、結果に
よりオーバーフローが発生することがあります。列が以下のように定義されている
場合:
Salary Decimal(15,2) Format ‘$ZZZ,ZZ9.99’
以下の問合わせを実行します。
SELECT SUM (Salary) FROM Employee;
小数オペランドおよび書式が一致していないため、オーバーフローが発生します。
オーバーフローが発生する可能性を回避するには、結果のデータ タイプでの、その
小数の合計が収まる十分な大きさで、小数の合計の書式を明示的に指定します。
SELECT Sum(Salary) (format ‘$Z,ZZZ,ZZZ,ZZ9.99) FROM Employee;
結果のタイプと属性
CSUM のデータ タイプ、書式、およびタイトルは、次のとおりです。
データ タイプ: オペランド x と同じ
• オペランド x が文字である場合、書式は FLOAT のデフォルトの書式である。
• オペランド x が数値である場合、書式は x と同じ書式である。
例
例
1998 年の各月ごとに、製品コード 10 について、毎日の売上げの連続合計を出して
みます。
SELECT cmonth, CSUM(sumPrice, cdate)
FROM
SQL 関数、演算子、式および述部
937
第 22 章 順序付き分析関数/ウィンドウ集約関数
CUME_DIST
(SELECT a2.month_of_year,
a2.calendar_date,a1.itemID, SUM(a1.price)
FROM Sales a1, SYS_CALENDAR.Calendar a2
WHERE a1.calendar_date=a2.calendar_date
AND a2.calendar_date=1998
AND a1.itemID=10
GROUP BY a2.month_of_year, a1.calendar_date,
a1.itemID) AS T1(cmonth, cdate, sumPrice)
GROUP BY cmonth;
月ごとにグループ化してあるので、各月の月末までの累積合計が出たら、翌月の計
算のために値がゼロに設定されるようになっています。したがって、同一の問合わ
せで各品目の累積合計を計算できます。
例
店舗 5 号について、1 月の各品目の売上げの連続合計を出し、グラフ作成プログラ
ムにエクスポートできる状態の出力を生成してみましょう。
SELECT Item, SalesDate, CSUM(Revenue,Item,SalesDate) AS
CumulativeSales
FROM
(SELECT Item, SalesDate, SUM(Sales) AS Revenue
FROM DailySales
WHERE StoreId=5 AND SalesDate BETWEEN
'1/1/1999' AND '1/31/1999'
GROUP BY Item, SalesDate) AS ItemSales
ORDER BY SalesDate;
結果は、たとえば以下のようなテーブルになります。
Item
SalesDate
CumulativeSales
InstaWoof dog food
01/01/1999
972.99
InstaWoof dog food
01/02/1999
2361.99
InstaWoof dog food
01/03/1999
5110.97
InstaWoof dog food
01/04/1999
7793.91
CUME_DIST
目的
値グループの値の累積分布を計算します。
938
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
CUME_DIST
タイプ
ANSI SQL:2011 ウィンドウ関数。
構文
CUME_DIST()
OVER
A
(
,
PARTITION BY
column_reference
,
A
ORDER BY
)
value_expression
ASC
DESC
NULLS FIRST
NULLS LAST
RESET WHEN condition
構文要素
OVER
累計、グループ、または移動関数を計算する際に、値をグループ化、順序付け、お
よび処理対象とする方法を指定します。
値は、PARTITION BY 句 BEGIN および RESET WHEN 句 END に基づいてグループ化
され、ORDER BY 句に基づいて整列され、パーティション内の集約グループに基づ
いて処理の対象とされます。
PARTITION BY
関数が操作対象とするグループ。
PARTITION BY 句または RESET WHEN 句を指定しない場合は、FROM 句から送ら
れる結果セット全体がパーティションになります。
PARTITION BY 句は、ウィンドウ パーティション句と呼ばれることもあります。
ORDER BY
グループまたはパーティション内の値の整列順序。
ASC
結果が昇順で整列されます。
整列フィールドが文字列の場合、システムは現在のセッションの照合順序の定義に
従って、昇順で整列します。
デフォルトの順序は ASC です。
DESC
結果が降順で整列されます。
整列フィールドが文字列の場合、システムは現在のセッションの照合順序の定義に
従って、降順で整列します。
降順の整列順序。
SQL 関数、演算子、式および述部
939
第 22 章 順序付き分析関数/ウィンドウ集約関数
CUME_DIST
NULLS FIRST
NULL 結果が最初にリストされることを指定します。
NULLS LAST
NULL 結果が最後にリストされることを指定します。
RESET WHEN
関数の実行対象になる 1 つまたは複数のグループ。指定された条件の評価に応じて
変化します。条件が TRUE と評価されると、指定されたウィンドウ パーティション
内に新しい動的パーティションが作成されます。
RESET WHEN は任意指定です。RESET WHEN 句または PARTITION BY 句を指定し
ない場合は、結果セット全体が単一のパーティションになります。
PARTITION BY 句または RESET WHEN 句を指定しない場合は、FROM 句から送られ
る結果セット全体がパーティションになります。
condition
条件によるパーティション化を決めるために使用する条件式。RESET WHEN 句の条
件は、QUALIFY 句の条件と適用範囲は同じですが、ネストされた順序付き分析関数
は RESET WHEN 句を指定できないという追加の制約があります。また、条件内の
subquery としての SELECT は指定できません。
条件は、指定されたすべてのウィンドウ パーティション内の行に適用され、そのウィ
ンドウ パーティション内にサブ パーティションを作成します。
詳細については、<SQL データ操作言語>の「RESET WHEN 条件のルール」および
「QUALIFY 句」を参照してください。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
CUME_DIST の使用
CUME_DIST は、PERCENT_RANK に似ています。同順位の存在下で RANK 値を考慮
する PERCENT_RANK と異なり、CUME_DIST は同順位の最も高い順位を使用しま
す。つまり、同等の順位があるときには、同順位の最後に位置する値を使用します。
CUME_DIST は、パーティション内のその位置の比になります(RANK-HIGH/NUM
ROWS)。
結果
CUME_DIST によって返される値の範囲は、0 より大きく、1 以下となります。
940
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
DENSE_RANK (ANSI)
例
次の SELECT 文について考えてみます。
SELECT lname, serviceyrs,
CUME_DIST()OVER(ORDER BY serviceyrs)
FROM schooltbl
GROUP BY 1,2;
schooltbl に記載されている教師の勤続年数別に累積分布を返します。
lname
serviceyrs
CUME_DIST
Adams
10
0.333333
Peters
10
0.333333
Murray
10
0.333333
Rogers
15
0.444333
Franklin
16
0.555333
Smith
20
0.888889
Ford
20
0.888889
Derby
20
0.888889
Baker
20
1.000000
DENSE_RANK (ANSI)
目的
ORDER BY 句に含まれる value_expression に基づいて、行の順序付き順位を戻しま
す。
タイプ
ANSI SQL:2011 ウィンドウ関数。
SQL 関数、演算子、式および述部
941
第 22 章 順序付き分析関数/ウィンドウ集約関数
DENSE_RANK (ANSI)
構文
DENSE_RANK()
OVER
A
(
,
PARTITION BY
column_reference
,
A
ORDER BY
)
value_expression
ASC
DESC
NULLS FIRST
NULLS LAST
RESET WHEN condition
構文要素
OVER
累計、グループ、または移動関数を計算する際に、値をグループ化、順序付け、お
よび処理対象とする方法を指定します。
値は、PARTITION BY 句 BEGIN および RESET WHEN 句 END に基づいてグループ化
され、ORDER BY 句に基づいて整列され、パーティション内の集約グループに基づ
いて処理の対象とされます。
PARTITION BY
関数が操作対象とするグループ。
PARTITION BY 句または RESET WHEN 句を指定しない場合は、FROM 句から送られ
る結果セット全体がパーティションになります。
PARTITION BY 句は、ウィンドウ パーティション句と呼ばれることもあります。
ORDER BY
グループまたはパーティション内の値の整列順序。
ASC
結果が昇順で整列されます。
整列フィールドが文字列の場合、システムは現在のセッションの照合順序の定義に
従って、昇順で整列します。
デフォルトの順序は ASC です。
DESC
結果が降順で整列されます。
整列フィールドが文字列の場合、システムは現在のセッションの照合順序の定義に
従って、降順で整列します。
NULLS FIRST
NULL 結果が最初にリストされることを指定します。
942
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
DENSE_RANK (ANSI)
NULLS LAST
NULL 結果が最後にリストされることを指定します。
RESET WHEN
関数の実行対象になる 1 つまたは複数のグループ。指定された条件の評価に応じて
変化します。条件が TRUE と評価されると、指定されたウィンドウ パーティション
内に新しい動的パーティションが作成されます。
RESET WHEN 句または PARTITION BY 句を指定しない場合は、結果セット全体が
単一のパーティションになります。
condition
条件によるパーティション化を決めるために使用する条件式。RESET WHEN 句の条
件は、QUALIFY 句の条件と適用範囲は同じですが、ネストされた順序付き分析関数
は RESET WHEN 句を指定できないという追加の制約があります。また、条件内の
subquery としての SELECT は指定できません。
条件は、指定されたすべてのウィンドウ パーティション内の行に適用され、その
ウィンドウ パーティション内にサブ パーティションを作成します。
詳細については、<SQL データ操作言語>の「RESET WHEN 条件のルール」および
「QUALIFY 句」を参照してください。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
DENSE_RANK の使用
順位は、1 で始まる連続する整数です。値が等しい行は、同じ順位になります。同
順位の場合、順位値はスキップされません。
結果のタイプ
結果のデータ タイプは INTEGER です。
例
次の SELECT 文について考えてみます。
SELECT lname, serviceyrs,
DENSE_RANK()OVER(ORDER BY serviceyrs)
FROM schooltbl
GROUP BY 1,2;
schooltbl に記載されている教師の勤続年数別に順序付き順位を返します。
SQL 関数、演算子、式および述部
943
第 22 章 順序付き分析関数/ウィンドウ集約関数
FIRST_VALUE/LAST_VALUE
lname
serviceyrs
DENSE_RANK
Adams
10
1
Peters
10
1
Murray
10
1
Rogers
15
2
Franklin
16
3
Smith
20
4
Ford
20
4
Derby
20
4
Baker
25
5
FIRST_VALUE/LAST_VALUE
目的
値の順序セットの最初の値または最後の値を返します。
タイプ
ANSI SQL:2011 ウィンドウ関数。
構文
FIRST_VALUE
LAST_VALUE
(
value_expression
)
IGNORE
window
NULLS
RESPECT
構文要素
value_expression
列式。
FIRST_VALUE および LAST_VALUE では、value_expression のデフォルトのデータ
タイプが使用されます。
より大きな数値は、これをより高位のデータ タイプにキャストすることによってサ
ポートされます。
この式に順序付き分析関数や集約関数を含めることはできません。
944
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
FIRST_VALUE/LAST_VALUE
IGNORE NULLS
NULL を返さないことを指定するキーワード。
• IGNORE NULLS (FIRST_VALUE あり) = セット内の最初の非 NULL 値を返します。
ただし、すべての値が NULL である場合には NULL を返します。
• IGNORE NULLS (LAST_VALUE あり) = セット内の最後の非 NULL 値を返します。
ただし、すべての値が NULL である場合には NULL を返します。
RESPECT NULLS
NULL を返すかどうかを指定する任意選択のキーワード。
• RESPECT NULLS (FIRST_VALUE あり) = 最初の値が null かどうかを返します。
• RESPECT NULLS(LAST_VALUE あり) = 最後の値が null かどうかを返します。
すべての値が NULL である場合は、NULL が返されます。
window
グループ、累積、または移動の計算。
ウィンドウ集約関数の構文については、ウィンドウ集約関数を参照してください。
ウィンドウ集約関数構文の整列キーに同順位がある場合、FIRST_VALUE および
LAST_VALUE は非確定です。並べ替え値の同順位があるいずれかの行から
value_expression が返されます。
注: ROWS 句を省略し、ORDER BY 句を指定すると、デフォルトの ROWS は
UNBOUNDED PRECEDING AND CURRENT ROW になります。
ROWS 句を省略し、ORDER BY 句を指定しないと、デフォルトの ROWS は
UNBOUNDED PRECEDING AND UNBOUNDED FOLLOWING になります。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
使用上の注意
FIRST_VALUE および LAST_VALUE は、計算のベースラインとしてよく使用される
ため、特に有益です。たとえば、日付順の売上げデータを保持するパーティション
を使用して、各日の売上げ高を期間最初の売上げ日(FIRST_VALUE)と比較できます。
または、行を売上げの少ない順に並べて、地域最大の売上げ高(LAST_VALUE)と比
較した、地域の各売上げ高の比率を確認できます。
IGNORE NULLS は、在庫テーブルに値を正しく取り込む場合に特に便利です。
IGNORE NULLS または RESPECT NULLS のいずれも選択しないことは、RESPECT
NULLS を選択することと同じです。
SQL 関数、演算子、式および述部
945
第 22 章 順序付き分析関数/ウィンドウ集約関数
MAVG
例
次の例では、開始日付別に給与、移動平均(ma)、および移動平均グループの最初と
最後の給与を返しています。
注: この関数は、ウィンドウの最初と最後の値を返します。例では、最初と最後の行
がウィンドウ内に収まっています。ウィンドウが 3 行前と 2 行前の間にあった場合
には、先頭 2 つの行の最初の値に NULL が表示されます。
SELECT start_date, salary,
AVG(salary) OVER(ORDER BY start_date
ROWS BETWEEN 3 PRECEDING AND 1 FOLLOWING) ma,
FIRST_VALUE(salary) OVER(ORDER BY start_date
ROWS BETWEEN 3 PRECEDING AND 1 FOLLOWING) first,
LAST_VALUE(salary) OVER(ORDER BY start_date
ROWS BETWEEN 3 PRECEDING AND 1 FOLLOWING) last
FROM employee
ORDER BY start_date;
start_date
salary
ma
first
last
21-MAR-76
6661.78
6603.280
6661.78
6544.78
12-DEC-78
6544.78
5183.780
6661.78
2344.78
24-OCT-82
2344.78
4471.530
6661.78
2344.78
15-JAN-84
2334.78
4441.780
6661.78
4322.78
30-JUL-87
4322.980
4688.980
6544.78
7897.78
31-DEC-90
7897.78
3626.936
2344.78
1234.56
25-JUL-96
1234.56
3404.536
2334.78
1232.78
17-SEP-96
1232.78
3671.975
4322.78
1232.78
MAVG
目的
現在行とそれに先行する width-1 個の行の指定された値式を使って、区分内の各行
の値式の移動平均を計算します。
タイプ
Teradata 固有の関数
946
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
MAVG
構文
MAVG
(
value_expression,
width,
,
sort_expression
(
ASC
DESC
構文要素
value_expression
この式に順序付き分析関数や集約関数を含めることはできません。
width
計算で使用される前の行の数。
この値は、常に正の整数リテラルです。
最大値は 4096 です。
sort_expression
値の並べ替えに使用するリテラルまたは列式、あるいはリテラルまたは列式のカン
マ区切りリスト。
例えば、MAVG(Sale, 6, Region ASC, Store DESC)のように指定します。Sale は
value_expression, であり、6 は width であり、Region ASC, Store DESC は
sort_expression リストです。
この式に順序付き分析関数や集約関数を含めることはできません。
ASC
結果が昇順で整列されます。
整列フィールドが文字列の場合、システムは現在のセッションの照合順序の定義に
従って、昇順で整列します。
デフォルトの順序は ASC です。
DESC
結果が降順で整列されます。
整列フィールドが文字列の場合、システムは現在のセッションの照合順序の定義に
従って、降順で整列します。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
SQL 関数、演算子、式および述部
947
第 22 章 順序付き分析関数/ウィンドウ集約関数
MAVG
MAVG に代わる AVG の使用
MAVG は使用しないようにしてください。これは ANSI SQL:2011 規格の Teradata
拡張機能であり、集約グループとして ROWS value PRECEDING を指定する ANSI 準
拠の AVG ウィンドウ関数に相当するものです。MAVG は、既存のアプリケーション
との下位互換性のためにのみ残されています。
結果のタイプと属性
MAVG のデータ タイプ、書式、およびタイトルは、次のとおりです。
データ タイプ: オペランド x と同じ
• オペランド x が文字である場合、書式は FLOAT のデフォルトの書式である。
• オペランド x が数値、日付、または間隔である場合、書式は x と同じ書式である。
データが欠けている場合の問題
MAVG を使って分析するデータに、欠けているデータ ポイントがないことを確認し
てください。欠けているデータ ポイントがあるデータに関して移動平均を計算する
と、予期しない不正確な結果が生成されます。なぜなら、n 個の論理データ ポイン
トではなく、n 個の物理データ行が計算の対象になるからです。
行数が width より少ない場合の移動平均の計算
その結果として生じる関係(おそらくグループ化した関係)の場合、width 個の行を対
象とした移動平均は、行が sort_expression リストで整列された状態で計算されます。
行の数が width 個よりも少ない場合、現在行とそれに先行するすべての行を対象と
して平均が計算されます。
例
例
1996 年 10 月について、製品コード 10 の毎日の売上げから 7 日間の移動平均を計
算してみましょう。
SELECT cdate, itemID, MAVG(sumPrice, 7, date)
FROM (SELECT a1.calendar_date, a1.itemID,
SUM(a1.price)
FROM Sales a1
WHERE a1.itemID=10 AND a1.calendar_date
BETWEEN 96-10-01 AND 96-10-31
GROUP BY a1.calendar_date, a1.itemID) AS T1(cdate,
itemID, sumPrice);
948
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
MDIFF
例
以下の例では、Zemlinsky Bros. Corporation の株の毎日の終値から、50 日間の移動
平均を計算します。同社の略号は ZBC です。
SELECT MarketDay, ClosingPrice,
MAVG(ClosingPrice,50, MarketDay) AS ZBCAverage
FROM MarketDailyClosing
WHERE Ticker = 'ZBC'
ORDER BY MarketDay;
この問合わせの結果は、たとえば以下のような表になります。
MarketDay
ClosingPrice
ZBCAverage
12/27/1999
89 1/16
85 1/2
12/28/1999
91 1/8
86 1/16
12/29/1999
92 3/4
86 1/2
12/30/1999
94 1/2
87
MDIFF
目的
現在の行の指定された値式と、それに先行するパーティション内の各行の width 行
との移動差分を返します。
タイプ
Teradata 固有の関数
構文
MDIFF
(
value_expression,
width,
,
sort_expression
(
ASC
DESC
構文要素
value_expression
移動平均を計算するための数値列またはリテラル。
この式に順序付き分析関数や集約関数を含めることはできません。
SQL 関数、演算子、式および述部
949
第 22 章 順序付き分析関数/ウィンドウ集約関数
MDIFF
width
計算で使用される前の行の数。
この値は、常に正の整数リテラルです。
最大値は 4096 です。
sort_expression
値の並べ替えに使用するリテラルまたは列式、あるいはリテラルまたは列式のカン
マ区切りリスト。
ASC
昇順の整列順序。
デフォルトは ASC です。
DESC
降順の整列順序。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
移動差異の意味
現在期間の特定の変数に関する活動と、過去を一定時間さかのぼった別の期間の同
じ変数に関する活動を比較した結果は、ビジネスで普通に使われる判断基準です。
たとえば、現在の売上げ総額を前の四半期の売上げ総額と比較してみることがある
でしょう。これが移動差異の計算です。この場合は、value_expression が四半期の
売上げ総額、width が 4、sort_expression が SYS_CALENDAR.Calendar システム
ビューの quarter_of_calendar 列になるでしょう。
MDIFF に代わる SUM の使用
MDIFF は使用しないようにしてください。これは ANSI SQL:2011 規格の Teradata
拡張機能であり、既存のアプリケーションとの下位互換性のためにのみ保持されて
います。MDIFF(x, w, y)は、次と等価です。
x - SUM(x) OVER (ORDER BY y
ROWS BETWEEN w PRECEDING AND w PRECEDING)
結果のタイプと属性
MDIFF のデータ タイプ、書式、およびタイトルは、次のとおりです。
950
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
MDIFF
• オペランド x が文字である場合、データ タイプは x と同じであり、書式は FLOAT
のデフォルトの書式になります。
• オペランド x が数値である場合、データ タイプは x と同じであり、書式は x と
同じ書式になります。
• オペランドが日付である場合、データ タイプは INTEGER であり、書式は INTEGER
のデフォルトの書式になります。
データが欠けている場合の問題
MDIFF を使って分析する行に、欠けているデータ ポイントがないことを確認してく
ださい。欠けているデータ ポイントがあるデータに関して移動差異を計算すると、
予期しない不正確な結果が生成されます。なぜなら、n 個の論理データ ポイントで
はなく、n 個の物理データ行が計算の対象になるからです。
前に行がないときの移動差異の計算
移動差異の計算に使用する、前にある行の数が、指定した width より少ない場合、
結果は NULL になります。
例
例
製品コード 10 について、各四半期ごとに、昨年の同じ四半期との売上げの差異を
表示してみましょう。
SELECT year_of_calendar, quarter_of_calendar,
MDIFF(sumPrice, 4, year_of_calendar, quarter_of_calendar)
FROM (SELECT a2.year_of_calendar,
a2.quarter_of_calendar, SUM(a2.Price) AS sumPrice
FROM Sales a1, SYS_CALENDAR.Calendar a2
WHERE a1.itemID=10 and a1.calendar_date=a2.calendar_date
GROUP BY a2.year_of_calendar, a2.quarter_of_calendar) AS T1
ORDER BY year_of_calendar, quarter_of_year;
例
以下の例では、Horatio Parker Imports 社の株について、週ごとの取引高の差異を
計算します。同社の略号は HPI です。
SELECT MarketWeek, WeekVolume,
MDIFF(WeekVolume,1,MarketWeek) AS HPIVolumeDiff
FROM
(SELECT MarketWeek, SUM(Volume) AS WeekVolume
FROM MarketDailyClosing
WHERE Ticker = 'HPI'
SQL 関数、演算子、式および述部
951
第 22 章 順序付き分析関数/ウィンドウ集約関数
MEDIAN
GROUP BY MarketWeek)
ORDER BY MarketWeek;
結果は、たとえば以下のような表になります。HPIVolume Diff (HPI 取引高出差異)
列の最初の行が null になっていることに注意する必要があります。これは、差異を
計算するための先行の行がないからです。
MarketWeek
WeekVolume
HPIVolumeDiff
11/29/1999
9817671
?
12/06/1999
9945671
128000
12/13/1999
10099459
153788
12/20/1999
10490732
391273
12/27/1999
11045331
554599
関連トピック
詳細は、以下を参照してください。
• データ タイプのデフォルトの書式の詳細については、< SQL データ型とリテラ
ル、B035-1143>の「データ タイプの書式および書式句」を参照してください。
• SUM ウィンドウ関数の詳細については、「ウィンドウ集約関数」を参照してくだ
さい。
MEDIAN
目的
数値または日時値を取り、中央値、または値の並べ替え後に中央値となる補間値を
返します。計算では NULL は無視されます。
タイプ
MEDIAN は集約関数です。
構文
MEDIAN
(value_expression)
構文要素
value_expression
必ず数値または DateTime データ型となる単一の式。
952
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
MLINREG
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果
この関数は、引数のデータ タイプと同じデータ タイプを返します。
例
MEDIAN は連続分布モデルとなる逆分布関数であり、パーセンタイル値が 0.5 の
PERCENTILE_CONT に固有の事例です。
MEDIAN (value_expression
)
次と同じです。
PERCENTILE_CONT (0.5) WITHIN GROUP (ORDER BY value_expression
)
関連トピック
詳細は、以下を参照してください。
• 「PERCENTILE_CONT/PERCENTILE_DISC」を参照してください。
MLINREG
目的
先行する width -1 (sort_expression に基づく)個の列値の移動線形回帰の最小二乗に
基づいて、式の予測値を戻します。
タイプ
Teradata 固有の関数
構文
MLINREG
(
value_expression,
width,
sort_expression
(
ASC
DESC
SQL 関数、演算子、式および述部
953
第 22 章 順序付き分析関数/ウィンドウ集約関数
MLINREG
構文要素
value_expression
この式に順序付き分析関数や集約関数を含めることはできません。
width
計算で使用される前の行の数。
この値は、常に正の整数リテラルです。
最大値は 4096 です。
sort_expression
線形回帰を計算する IN 従属変数を定義する列式。
例えば、MLINREG(Sales, 6, Fiscal_Year_Month ASC)のように指定します。Sales は
value_expression であり、6 は width であり、Fiscal_Year_Month ASC は
sort_expression です。
この列参照のデータ タイプは数値または Teradata Database が正しく暗黙的に数値
に変換できるデータ タイプでなければなりません。
ASC
昇順の整列順序。
デフォルトは ASC です。
DESC
降順の整列順序。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
MLINREG に代わる ANSI 準拠のウィンドウ関数の使用
MLINREG の代わりに ANSI 準拠のウィンドウ関数を使用することを強くお勧めしま
す。MLINREG は ANSI SQL:2011 規格の Teradata 拡張機能であり、既存のアプリ
ケーションとの下位互換性のためにのみ残されています。
結果のタイプと属性
MLINREG のデータ タイプ、書式、およびタイトルは、次のとおりです。
データ タイプ: オペランド x と同じ
• オペランド x が文字である場合、書式は FLOAT のデフォルトの書式である。
• オペランド x が数値、日付、または間隔である場合、書式は x と同じ書式である。
954
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
MLINREG
デフォルトの独立変数
MLINREG は、sort_expression に独立変数を記述することを前提としています。
先行する行の数が width -1 より小さい場合の MLINREG の計算
先行する行の数が width -1 個よりも少ない場合、MLINREG は、先行するすべての
行を使って回帰を計算します。
MLINREG のレポート構造
結果テーブルの最初の 2 つの行(常に null)以外のすべての行には、予測値が表示さ
れます。
例
sales_table の itemID、smonth、および sales 列について考えてみます。
SELECT itemID, smonth, sales
FROM fiscal_year_sales_table
ORDER BY itemID, smonth;
itemID smonth
sales
------ -------- ----A
1
100
A
2
110
A
3
120
A
4
130
A
5
140
A
6
150
A
7
170
A
8
190
A
9
210
A
10
230
A
11
250
A
12 ?
B
1
20
B
2
30
...
sales 列に NULL があるのは、この例では 12 月(month 12)が将来の日付であって、
値が不明であるためです。
次の文では MLINREG を使用し、過去 6 ヶ月の売上げデータを使って、各製品ごと
の各月の傾向に基づき、予想売上げを表示してみましょう。
SQL 関数、演算子、式および述部
955
第 22 章 順序付き分析関数/ウィンドウ集約関数
MSUM
SELECT itemID, smonth, sales, MLINREG(sales,7,smonth)
FROM fiscal_year_sales_table;
GROUP BY itemID;
itemID smonth
sales MLinReg(sales,7,smonth)
------ -------- ----- ----------------------A
1
100 ?
A
2
110 ?
A
3
120
120
A
4
130
130
A
5
140
140
A
6
150
150
A
7
170
160
A
8
190
177
A
9
210
198
A
10
230
222
A
11
250
247
A
12 ?
270
B
1
20 ?
B
2
30 ?
...
関連トピック
データ タイプのデフォルトの書式、および書式における書式設定文字についての説
明は、< SQL データ型とリテラル、B035-1143>の「データ タイプの書式および書
式句」を参照してください。
MSUM
目的
現在行とそれに先行する n-1 個の行の値式によって指定される移動合計を計算しま
す。この関数は、MAVG 関数とよく似ています。
タイプ
Teradata 固有の関数
構文
MSUM
(
value_expression,
width,
,
sort_expression
(
ASC
DESC
956
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
MSUM
構文要素
value_expression
この式に順序付き分析関数や集約関数を含めることはできません。
width
計算で使用される前の行の数。
この値は、常に正の整数リテラルです。
最大値は 4096 です。
sort_expression
値の並べ替えに使用するリテラルまたは列式、あるいはリテラルまたは列式のカン
マ区切りリスト。
ASC
昇順の整列順序。
デフォルトは ASC です。
DESC
降順の整列順序。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
MSUM に代わる SUM の使用
MSUM は使用しないようにしてください。これは ANSI SQL:2011 規格の Teradata
拡張機能であり、ANSI 準拠の SUM ウィンドウ関数に相当するものです。MSUM
は、既存のアプリケーションとの下位互換性のためにのみ残されています。
結果のタイプと属性
MSUM のデータ タイプ、書式、およびタイトルは、次のとおりです。
データ タイプ: オペランド x と同じ
• オペランド x が文字である場合、書式は FLOAT のデフォルトの書式である。
• オペランド x が数値である場合、書式は x と同じ書式である。
データが欠けている場合の問題
MSUM を使って分析するデータに、欠けているデータ ポイントがないことを確認
してください。欠けているデータ ポイントがあるデータに関して移動平均を計算す
SQL 関数、演算子、式および述部
957
第 22 章 順序付き分析関数/ウィンドウ集約関数
PERCENT_RANK
ると、予期しない不正確な結果が生成されます。なぜなら、n 個の論理データ ポイ
ントではなく、n 個の物理データ行が計算の対象になるからです。
行数が width より少ない場合の MSUM の計算
行の数が width 個よりも少ないデータの場合、MSUM は、先行するすべての行を
使って合計を計算します。MSUM は、サンプル内の行の数が width よりも少ない場
合、null ではなく現在の合計を返します。
SELECT Sum の結果オーバーフローが発生する可能性
この関数を使用する場合に、データ タイプおよび書式が一致していないと、オーバー
フローが発生することがあります。列を次のように定義したとします。
Salary Decimal(15,2) Format ‘$ZZZ,ZZ9.99’
以下の問合わせを実行します。
SELECT SUM (Salary) FROM Employee;
小数オペランドおよび書式が一致していないため、オーバーフローが発生します。
オーバーフローが発生する可能性を回避するには、結果のデータ タイプでの、その
小数の合計が収まる十分な大きさで、小数の合計の書式を明示的に指定します。
SELECT Sum(Salary) (format ‘$Z,ZZZ,ZZZ,ZZ9.99) FROM Employee;
PERCENT_RANK
目的
value_expression の行の相対的な順位を戻します。
タイプ
ANSI SQL:2011 ウィンドウ関数。
構文
PERCENT_RANK()
OVER
A
(
,
PARTITION BY
column_reference
,
A
ORDER BY
)
value_expression
ASC
DESC
958
NULLS FIRST
NULLS LAST
RESET WHEN condition
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
PERCENT_RANK
構文要素
OVER
累計、グループ、または移動関数を計算する際に、値をグループ化、順序付け、お
よび処理対象とする方法を指定します。
値は、PARTITION BY 句 BEGIN および RESET WHEN 句 END に基づいてグループ化
され、ORDER BY 句に基づいて整列され、パーティション内の集約グループに基づ
いて処理の対象とされます。
PARTITION BY
関数が操作対象とするグループ。
PARTITION BY 句または RESET WHEN 句を指定しない場合は、FROM 句から送ら
れる結果セット全体がパーティションになります。
PARTITION BY 句は、ウィンドウ パーティション句と呼ばれることもあります。
ORDER BY
グループまたはパーティション内の値の整列順序。
ASC
昇順の整列順序。
デフォルトは ASC です。
DESC
降順の整列順序。
NULLS FIRST
NULL 結果が最初にリストされることを指定します。
NULLS LAST
NULL 結果が最後にリストされることを指定します。
RESET WHEN
関数の実行対象になる 1 つまたは複数のグループ。指定された条件の評価に応じて
変化します。条件が TRUE と評価されると、指定されたウィンドウ パーティション
内に新しい動的パーティションが作成されます。
PARTITION BY 句または RESET WHEN 句を指定しない場合は、FROM 句から送ら
れる結果セット全体がパーティションになります。
condition
条件によるパーティション化を決めるために使用する条件式。RESET WHEN 句の条
件は、QUALIFY 句の条件と適用範囲は同じですが、ネストされた順序付き分析関数
は RESET WHEN 句を指定できないという追加の制約があります。また、条件内の
subquery としての SELECT は指定できません。
SQL 関数、演算子、式および述部
959
第 22 章 順序付き分析関数/ウィンドウ集約関数
PERCENT_RANK
条件は、指定されたすべてのウィンドウ パーティション内の行に適用され、そのウィ
ンドウ パーティション内にサブ パーティションを作成します。
詳細については、<SQL データ操作言語>の「RESET WHEN 条件のルール」および
「QUALIFY 句」を参照してください。
ANSI への準拠
これは、ANSI SQL:2011 に準拠しています。
RESET WHEN 句は、ANSI SQL 規格に対する Teradata 拡張機能です。
計算
割り当てられた行の順位とは、その行に先行し、その行と同等ではない行の数に 1
を加えたものと定義されます。
PERCENT_RANK は、0.0 から 1.0 までの数値の割合の概算の形で表現されます。
PERCENT_RANK の値
結果行に割り当てられる順位
0.0
1.
1.0
結果内の最大値。
結果のタイプと属性
PERCENT_RANK() OVER (PARTITION BY x ORDER BY y direction)のデータ型、書
式、およびタイトルは、次のとおりです。
データ タイプ
書式
タイトル
REAL
DECIMAL(7,6)のデフォルトの書式
Percent_Rank(y direction)
例
例
percent_rank という、クリスマス セールの相対的な順位を調べます。
以下の問合わせを実行します。
SELECT sales_amt,
PERCENT_RANK() OVER (ORDER BY sales_amt)
FROM xsales;
上記の問合わせは、たとえば以下のような結果を戻します。相対的な順位が昇順(並
替え順序が指定されない場合のデフォルト)で戻されることと、通貨記号が明示的に
報告されないことに注意する必要があります。
960
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
PERCENT_RANK
sales_amt
Percent_Rank
100.00
0.000000
120.00
0.125000
130.00
0.250000
140.00
0.375000
143.00
0.500000
147.00
0.625000
150.00
0.750000
155.00
0.875000
160.00
1.000000
例
クリスマス セールの順位と相対的な順位を調べます。
SELECT sales_amt,
RANK() OVER (ORDER BY sales_amt),
PERCENT_RANK () OVER (ORDER BY sales_amt)
FROM xsales;
sales_amt
Rank
Percent_Rank
100.00
1
0.000000
120.00
2
0.125000
130.00
3
0.250000
140.00
4
0.375000
143.00
5
0.500000
147.00
6
0.625000
150.00
7
0.750000
155.00
8
0.875000
160.00
9
1.000000
例
次の SQL 文は、PERCENT_RANK と累積分布との違いを示しています。
SELECT sales_amt,
PERCENT_RANK() OVER (ORDER BY sales_amt),
SQL 関数、演算子、式および述部
961
第 22 章 順序付き分析関数/ウィンドウ集約関数
PERCENTILE_CONT/PERCENTILE_DISC
CUME_DIST() OVER (ORDER BY sales_amt)
FROM xsales;
sales_amt
PERCENT_Rank
CUME_DIST
100.
.000000
0.125000
120.
.142857
0.250000
130
.285714
.375000
140.
.428571
.500000
147.
.571429
.625000
150.
.714286
.750000
155.
.857143
.875000
160.
1.000000
1.000000
PERCENTILE_CONT/PERCENTILE_DISC
目的
整列指定を基準にして value_expression 内に収まる補間値を返します。
タイプ
PERCENTILE_CONT および PERCENTILE_DISC は集約関数です。
構文
PERCENTILE_CONT
( value_expression_1 )
A
WITHIN GROUP
PERCENTILE_DISC
,
A
(
ORDER BY
)
value_expression_2
ASC
DESC
NULLS FIRST
NULLS LAST
構文要素
value_expression_1
0 から 1 までの数値。
WITHIN GROUP
グループまたはパーティション内の値の整列順序。
962
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
PERCENTILE_CONT/PERCENTILE_DISC
ORDER BY
グループまたはパーティション内の値の整列順序。
value_expression_2
必ず数値または日時値となる単一の式。
ASC
昇順の整列順序。
デフォルトは ASC です。
DESC
降順の整列順序。
NULLS FIRST
NULL 結果が最初にリストされることを指定します。
NULLS LAST
NULL 結果が最後にリストされることを指定します。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
結果
この関数は、引数のデータ タイプと同じデータ タイプを返します。
計算では NULL は無視されます。
使用上の注意
どちらの関数も、連続分布となる逆分布関数です。
• PERCENTILE_CONT は、線形補間の実施後に計算結果を返します。
• PERCENTILE_DISC は、単に値セットから値を返します。
例
次の表を使用します。
Area
Address
Price
Downtown
72 Easy Street
509000
Downtown
29 Right Way
402000
SQL 関数、演算子、式および述部
963
第 22 章 順序付き分析関数/ウィンドウ集約関数
QUANTILE
Area
Address
Price
Downtown
45 Diamond Lane
203000
Downtown
76 Blind Alley
201000
Downtown
15 Tern Pike
199000
Downtown
444 Kanga Road
102000
Uptown
15 Peak Street
456000
Uptown
27 Primrose Path
349000
Uptown
44 Shady Lane
341000
Uptown
34 Design Road
244000
Uptown
2331 Highway 64
244000
Uptown
77 Sunset Strip
102000
次の SQL 文は、その直後のテーブルに指定されたとおりに、線形補間の実施後に計
算結果を返します。
SELECT area,
AVG(price),
PERCENTILE_DISC(0.5) WITHIN GROUP (ORDER BY price),
PERCENTILE_CONT(0.5) WITHIN GROUP (ORDER BY price)
FROM market
GROUP BY area;
Area
Average Price
PERC_DISC
PERC_CONT
Downtown
269333
201000
202000
Uptown
289333
244000
292500
QUANTILE
目的
グループ内の値の分位スコアを計算します。
タイプ
Teradata 固有の関数
964
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
QUANTILE
構文
QUANTILE
(
quantile_literal,
,
sort_expression
(
ASC
DESC
構文要素
quantile_literal
対象となる分位パーティションの数を定義するために使用する正の整数リテラル 。
sort_expression
値の並べ替えに使用するリテラルまたは列式、あるいはリテラルまたは列式のカン
マ区切りリスト。
ASC
昇順の整列順序。
デフォルトは ASC です。
DESC
降順の整列順序。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
定義
分位とは、ユーザー定義の幅を持った汎用間隔です。たとえば、100 分位の場合は
100 等分した間隔、10 分位の場合は 10 等分した間隔、4 分位の場合は 4 等分した
間隔といった具合に、一定の間隔でデータを分割します。分位スコアは、
sort_expression 値が現在値よりも小さい行の割合を示します。例えば、100 分位の
スコアが 98 の場合、リスト内の行のうち 98%の sort_expression 値が現在値より小
さいということです。
QUANTILE に代わる ANSI ウィンドウ関数の使用
QUANTILE は使用しないようにしてください。これは ANSI SQL:2011 規格の
Teradata 拡張機能であり、既存のアプリケーションとの下位互換性のためにのみ保
持されています。
ANSI ウィンドウ関数を使用して QUANTILE(q, s)を計算するには、次を使用します。
(RANK() OVER (ORDER BY s) - 1) * q / COUNT(*) OVER()
SQL 関数、演算子、式および述部
965
第 22 章 順序付き分析関数/ウィンドウ集約関数
QUANTILE
QUANTILE レポート
QUANTILE は、グループ内のすべての行の sort_expression 値に対する、グループ内
の各行の sort_expression 値の分位を表わす整数値を返します。
分位値の範囲
分位値は、0~(Q-1)の範囲になります。Q は quantile_literal で指定する分位区分の
数です。
結果のタイプと属性
QUANTILE(Q, list)のデータ タイプ、書式、およびタイトルは、次のとおりです。
データ タイプ
書式
タイトル
INTEGER
INTEGER データ タイプのデフォルトの書式
Quantile(Q, list)
例
例
売上げ総額に基づいて、10 分位の上から 9 番目に入る各品目とそれぞれの売上げ総
額を表示してみましょう。
SELECT itemID, sumPrice
FROM (SELECT a1.itemID, SUM(price)
FROM Sales a1
GROUP BY a1.itemID) AS T1(itemID, sumPrice)
QUALIFY QUANTILE(10,sumPrice)=9;
例
以下の例では、利益率に基づいて、すべての品目を 10 分位にグループ化します。
SELECT Item, Profit, QUANTILE(10, Profit) AS Decile
FROM
(SELECT Item, Sum(Sales) — (Count(Sales) * ItemCost) AS Profit
FROM DailySales, Items
WHERE DailySales.Item = Items.Item
GROUP BY Item) AS Item;
結果は、たとえば以下のような表になります。
966
Item
Profit
Decile
High Tops
97112
9
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
QUANTILE
Item
Profit
Decile
Low Tops
74699
7
Running
69712
6
Casual
28912
3
Xtrain
100129
9
例
QUANTILE は指定されたデータをパーティション化するために等幅ヒストグラムを
使用するため、QUANTILE が等高ヒストグラムを使用してデータを等しくパーティ
ション化することはありません。言い換えれば、指定された分位ごとに行カウント
が等しくなるとは期待できないということです。例えば、データの中に重複する
sort_expression の値がある場合、空の分位ヒストグラムの生じることが期待されま
す。
たとえば、次の単純な SELECT 文を考えてみましょう。
SELECT itemNo, quantity, QUANTILE(10,quantity) FROM inventory;
報告は、たとえば以下のようなものになります。
itemNo
quantity
Quantile(10, quantity)
13
1
0
9
1
0
7
1
0
2
1
0
5
1
0
3
1
0
1
1
0
6
1
0
4
1
0
10
1
0
8
1
0
11
1
0
12
9
9
分位の整列は quantity に基づいて行なわれ、inventory テーブルには 2 つしか
quantity のスコアがないため、10 分位の 1 から 8 までの報告にはスコアがありま
せん。
SQL 関数、演算子、式および述部
967
第 22 章 順序付き分析関数/ウィンドウ集約関数
RANK (ANSI)
関連トピック
データ タイプのデフォルトの書式の詳細については、< SQL データ型とリテラル、
B035-1143>の「データ タイプの書式および書式句」を参照してください。
RANK (ANSI)
目的
ORDER BY 句に含まれる value_expression に基づいて、行の順序付き順位を戻しま
す。
タイプ
ANSI SQL:2011 ウィンドウ関数。
構文
RANK()
(
OVER
A
,
PARTITION BY
column_reference
,
A
ORDER BY
B
value_expression
ASC
DESC
NULLS FIRST
NULLS LAST
RESET WHEN condition
)
B
WITH
TIES
LOW
HIGH
AVG
DENSE
構文要素
OVER
累計、グループ、または移動関数を計算する際に、値をグループ化、順序付け、お
よび処理対象とする方法を指定します。
値は、PARTITION BY 句 BEGIN および RESET WHEN 句 END に基づいてグループ化
され、ORDER BY 句に基づいて整列され、パーティション内の集約グループに基づ
いて処理の対象とされます。
PARTITION BY
関数が操作対象とするグループ。
PARTITION BY 句または RESET WHEN 句を指定しない場合は、FROM 句から送られ
る結果セット全体がパーティションになります。
968
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
RANK (ANSI)
PARTITION BY 句は、ウィンドウ パーティション句と呼ばれることもあります。
ORDER BY
グループまたはパーティション内の値の整列順序。
ASC
昇順の整列順序。
デフォルトは ASC です。
DESC
降順の整列順序。
NULLS FIRST
NULL 結果が最初にリストされることを指定します。
NULLS LAST
NULL 結果が最後にリストされることを指定します。
RESET WHEN
関数の実行対象になる 1 つまたは複数のグループ。指定された条件の評価に応じて
変化します。条件が TRUE と評価されると、指定されたウィンドウ パーティション
内に新しい動的パーティションが作成されます。
PARTITION BY 句または RESET WHEN 句を指定しない場合は、FROM 句から送ら
れる結果セット全体がパーティションになります。
condition
条件によるパーティション化を決めるために使用する条件式。RESET WHEN 句の条
件は、QUALIFY 句の条件と適用範囲は同じですが、ネストされた順序付き分析関数
は RESET WHEN 句を指定できないという追加の制約があります。また、条件内の
subquery としての SELECT は指定できません。
条件は、指定されたすべてのウィンドウ パーティション内の行に適用され、その
ウィンドウ パーティション内にサブ パーティションを作成します。
詳細については、<SQL データ操作言語>の「RESET WHEN 条件のルール」および
「QUALIFY 句」を参照してください。
TIES LOW
すべての同順位が最も低い順位になるように指定します。
整数データ タイプを返します。
TIES HIGH
すべての同順位が最も高い順位になるように指定します。
整数データ タイプを返します。
SQL 関数、演算子、式および述部
969
第 22 章 順序付き分析関数/ウィンドウ集約関数
RANK (ANSI)
TIES AVG
すべての同順位が平均の順位になるように指定します。
10 進データ型を返します。
TIES DENSE
すべての同順位が DENSE_RANK の順位付けに従って並べられるように指定します。
整数データ タイプを返します。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠していますが、非 ANSI の Teradata Database 拡張
機能が含まれています。
順位の意味
RANK は、ORDER BY 句に含まれる value_expression に基づいて、行の順序付き順
位を戻します。value_expression 値が同じ行にはすべて、同じ順位が割り当てられ
ます。
n 個の行が同じ value_expression 値になっているとすれば、それらの行には同じ順
位(例えば r)が割り当てられます。さらに、次の明確な値に順位 r +n が与えられま
す。以下同様に続いていきます。
正式な機能ではありませんが、RANK は、結果セットを並べ替え、結果内の各行の
数値順位を識別することもします。RANK は結果の中に各行の順位を表わす整数を
戻します。
結果のタイプと属性
RANK() OVER (PARTITION BY x ORDER BY y direction)のデータ型、書式、およびタ
イトルは、次のとおりです。
データ タイプ
書式
タイトル
INTEGER
INTEGER データ タイプのデフォルトの書式
Rank(y direction)
例
例
次の例は、販売地域ごとに売上げに基づいて販売担当者を順位付けします。
SELECT sales_person, sales_region, sales_amount,
RANK() OVER (PARTITION BY sales_region ORDER BY sales_amount DESC)
FROM sales_table;
970
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
RANK (ANSI)
sales_person
sales_region
sales_amount
Rank(sales_amount)
Garabaldi
East
100
1
Baker
East
99
2
Fine
East
89
3
Adams
East
75
4
Edwards
West
100
1
Connors
West
99
2
Davis
West
99
2
上記の表の rank 列では、PARTITION BY 句で指定した列(sales_region)ごとに、販
売担当者が売上げ高の降順でリストアップされており、sales_region が変わると、
売上げの順位(sales_amount)がリセットされます。
例
次の SQL 文は、RANK(ANSI)と DENSE_RANK(ANSI)との違いを示しており、
sales_region および sales_amount 別に sales_person の RANK および DENSE_RANK
を返します。
SELECT sales_person, sales_region, sales_amount,
RANK() OVER
(PARTITION BY sales_region ORDER BY sales_amount DESC) as "Rank",
DENSE_RANK() OVER
(PARTITION BY sales_region ORDER BY sales_amount DESC) as "DenseRank"
FROM sales_table;
sales_person
sales_region
sales_amount
Rank
DenseRank
Garabaldi
East
100
1
1
Baker
East
100
1
1
Fine
East
89
3
2
Adams
East
75
4
3
Edwards
West
100
1
1
Connors
West
99
2
2
Davis
West
99
2
2
Russell
West
50
4
3
関連トピック
詳細は、以下を参照してください。
SQL 関数、演算子、式および述部
971
第 22 章 順序付き分析関数/ウィンドウ集約関数
RANK (Teradata)
• 詳細については、< SQL データ操作言語、B035-1146>の「RESET WHEN 条件の
ルール」と「QUALIFY 句」を参照してください。
• 書式における書式設定文字についての説明は、 < SQL データ型とリテラル、
B035-1143>の「データ タイプの書式および書式句」を参照してください。
RANK (Teradata)
目的
sort_expression リストの値ごとに、グループ内のすべての行の順位(1 … n)を戻しま
す。sort_expression の値が同じ行は同じ順位になります。
タイプ
Teradata 固有の関数
構文
RANK
(
,
sort_expression
(
ASC
DESC
構文要素
sort_expression
値の並べ替えに使用するリテラルまたは列式、あるいはリテラルまたは列式のカン
マ区切りリスト。
この式に順序付き分析関数や集約関数を含めることはできません。
ASC
昇順の整列順序。
デフォルトは ASC です。
DESC
降順の整列順序。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
972
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
RANK (Teradata)
Teradata RANK に代わる ANSI RANK の使用
Teradata RANK は使用しないようにしてください。これは ANSI SQL:2011 規格の
Teradata 拡張機能であり、ANSI 準拠の RANK ウィンドウ関数に相当するものです。
Teradata RANK は、既存のアプリケーションとの下位互換性のためにのみ残されて
います。
順位の意味
順位 r は、sort_expression 値の後にちょうど r-1 個の行があることを示します。
sort_expression 値が同じ行にはすべて、同じ順位が割り当てられます。
例えば、n 個の行が同じ sort_expression 値になっているとすれば、それらの行には
同じ順位(例えば r)が割り当てられます。さらに、次の明確な値に順位 r +n が与え
られます。
正式な機能ではありませんが、RANK は、結果セットを並べ替え、結果内の各行の
数値順位を識別することもします。RANK の唯一の引数は、並替え列(複数も可)で
す。この関数は、結果内の各行の順位を表わす整数を戻します。
上位値と下位値の計算
RANK を使って、以下の例のように、上位値と下位値を計算することもできます。
Top(n, column)は、QUALIFY RANK(column DESC) <=n.として計算されます。
Bottom(n, column)は、QUALIFY RANK(column ASC) <=n として計算されます。
結果のタイプと属性
RANK(x)のデータ タイプ、書式、およびタイトルは、次のとおりです。
データ タイプ
書式
タイトル
INTEGER
INTEGER データ タイプのデフォルトの書式
Rank(x)
例
例
売上げトップ 100 の品目について、各品目、それぞれの売上げ総額、それぞれの売
上げ順位を表示してみましょう。
SELECT itemID, sumPrice, RANK(sumPrice)
FROM
(SELECT a1.itemID, SUM(a1.Price)
FROM Sales a1
SQL 関数、演算子、式および述部
973
第 22 章 順序付き分析関数/ウィンドウ集約関数
RANK (Teradata)
GROUP BY a1.itemID AS T1(itemID, sumPrice)
QUALIFY RANK(sumPrice) <=100;
例
社員をアルファベット順に並べ替え、社内における先任権レベルを識別してみましょ
う。
SELECT EmployeeName, (HireDate - CURRENT_DATE) AS ServiceDays,
RANK(ServiceDays) AS Seniority
FROM Employee
ORDER BY EmployeeName;
結果は、たとえば以下のような表になります。
EmployeeName
Service Days
Seniority
Ferneyhough
9931
2
Lucier
9409
4
Revueltas
9408
5
Ung
9931
2
Wagner
10248
1
例
カテゴリ別に品目を並べ替え、売上げ順位の降順で報告してみましょう。
SELECT Category, Item, Revenue, RANK(Revenue) AS ItemRank
FROM ItemCategory,
(SELECT Item, SUM(sales) AS Revenue
FROM DailySales
GROUP BY Item) AS ItemSales
WHERE ItemCategory.Item = ItemSales.Item
ORDER BY Category, ItemRank DESC;
結果は、たとえば以下のような表になります。
974
Category
Item
Revenue
ItemRank
Hot Cereal
Regular Oatmeal
39112.00
4
Hot Cereal
Instant Oatmeal
44918.00
3
Hot Cereal
Regular COW
59813.00
2
Hot Cereal
Instant COW
75411.00
1
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
ROW_NUMBER
関連トピック
詳細は、以下を参照してください。
• データ タイプのデフォルトの書式の詳細については、< SQL データ型とリテラ
ル、B035-1143>の「データ タイプの書式および書式句」を参照してください。
• RANK ウィンドウ関数の詳細については、「RANK (ANSI)」を参照してください。
ROW_NUMBER
目的
ウィンドウのウィンドウ順序に基づく、そのウィンドウ パーティション内での行の
順次行番号を戻します(最初の行が番号 1 です)。
タイプ
ANSI SQL:2011 ウィンドウ関数。
構文
ROW_NUMBER()
OVER
A
(
,
PARTITION BY
column_reference
,
A
ORDER BY
)
value_expression
ASC
DESC
NULLS FIRST
NULLS LAST
RESET WHEN condition
構文要素
OVER
累計、グループ、または移動関数を計算する際に、値をグループ化、順序付け、お
よび処理対象とする方法を指定します。
値は、PARTITION BY 句 BEGIN および RESET WHEN 句 END に基づいてグループ化
され、ORDER BY 句に基づいて整列され、パーティション内の集約グループに基づ
いて処理の対象とされます。
PARTITION BY
関数が操作対象とするグループ。
関数が操作対象とするグループ。
PARTITION BY 句は、ウィンドウ パーティション句と呼ばれることもあります。
SQL 関数、演算子、式および述部
975
第 22 章 順序付き分析関数/ウィンドウ集約関数
ROW_NUMBER
ORDER BY
グループまたはパーティション内の値の整列順序。
ASC
昇順の整列順序。
デフォルトは ASC です。
DESC
降順の整列順序。
NULLS FIRST
NULL 結果が最初にリストされることを指定します。
NULLS LAST
NULL 結果が最後にリストされることを指定します。
RESET WHEN
関数の実行対象になる 1 つまたは複数のグループ。指定された条件の評価に応じて
変化します。条件が TRUE と評価されると、指定されたウィンドウ パーティション
内に新しい動的パーティションが作成されます。
PARTITION BY 句または RESET WHEN 句を指定しない場合は、FROM 句から送られ
る結果セット全体がパーティションになります。
condition
条件によるパーティション化を決めるために使用する条件式。RESET WHEN 句の条
件は、QUALIFY 句の条件と適用範囲は同じですが、ネストされた順序付き分析関数
は RESET WHEN 句を指定できないという追加の制約があります。また、条件内の
subquery としての SELECT は指定できません。
条件は、指定されたすべてのウィンドウ パーティション内の行に適用され、そのウィ
ンドウ パーティション内にサブ パーティションを作成します。
詳細については、<SQL データ操作言語>の「RESET WHEN 条件のルール」および
「QUALIFY 句」を参照してください。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠していますが、非 ANSI の Teradata Database 拡張
機能が含まれています。
ウィンドウ集約の等価性
ROW_NUMBER() OVER (PARTITION BY 列
ORDER BY value
)
976
SQL 関数、演算子、式および述部
第 22 章 順序付き分析関数/ウィンドウ集約関数
ROW_NUMBER
は、次と等価です。
COUNT(*) OVER (PARTITION BY 列
ORDER BY value
ROWS UNBOUNDED PRECEDING).
例
販売地域内の売上げに基づいて販売担当者を順序付けするために次の SQL 問合わせ
を使用すると、その次に示すような結果が得られます。
SELECT ROW_NUMBER() OVER (PARTITION BY sales_region
ORDER BY sales_amount DESC),
sales_person, sales_region, sales_amount
FROM sales_table;
Row_Number()
-----------1
2
3
4
1
2
3
sales_person
-----------Baker
Edwards
Davis
Adams
Garabaldi
Connors
Fine
sales_region
-----------East
East
East
East
West
West
West
sales_amount
-----------100
99
89
75
100
99
99
関連トピック
詳細は、以下を参照してください。
• 詳細については、< SQL データ操作言語、B035-1146>の「RESET WHEN 条件の
ルール」と「QUALIFY 句」を参照してください。
• COUNT の詳細については、「ウィンドウ集約関数」を参照してください。
SQL 関数、演算子、式および述部
977
第 22 章 順序付き分析関数/ウィンドウ集約関数
ROW_NUMBER
978
SQL 関数、演算子、式および述部
第 23 章
期間関数および演算子
概要
この章では、期間関数および演算子について説明します。
これらの関数および演算子には、真の Period データ タイプと派生 PERIOD 列の両
方をサポートしているものがいくつかあります。 Period データ タイプと派生 PERIOD
列は、派生 PERIOD によって表わされる期間の開始境界値と終了境界値を格納する
2 つの個別の DateTime 列から構成されています。
Period 値コンストラクタ
目的
Period データ タイプのインスタンスを初期設定します。
構文
PERIOD (datetime_expression)
PERIOD (datetime_expression, datetime_expression)
PERIOD (datetime_expression, UNTIL_CHANGED)
PERIOD (datetime_expression, UNTIL_CLOSED)
構文要素
datetime_expression
DATE、TIME、または TIMESTAMP 値と評価される式。
UNTIL_CHANGED
変更されなければ永久とみなされる DATE 値または TIMESTAMP 値。
PERIOD(DATE)タイプの場合、UNTIL_CHANGED は DATE '9999-12-31'の値になり
ます。
PERIOD(TIMESTAMP[(n)] [WITH TIME ZONE])タイプの場合、UNTIL_CHANGED は
TIMESTAMP '9999-12-31 23:59:59.999999 00:00'の値になります(精度は開始境界
SQL 関数、演算子、式および述部
979
第 23 章 期間関数および演算子
Period 値コンストラクタ
の精度にまで切り詰められ、開始境界にタイムゾーンがない場合はタイムゾーンが
省略されます)。
UNTIL_CHANGED は、派生 PERIOD をサポートします。IS UNTIL_CHANGED/IS NOT
UNTIL_CHANGED を参照してください。
UNTIL_CLOSED
行が開いている行であることを示すテンポラル テーブルの transaction-time 列の
PERIOD 値に対する終了境界。
UNTIL_CLOSED のデータ タイプは TIMESTAMP(6) WITH TIME ZONE で、値は
TIMESTAMP '9999-12-31 23:59:59.999999+00: 00' になります。
テンポラル テーブルについて、詳細は<一時テーブルのサポート 、B035-1182>を参
照してください。
UNTIL_CLOSED は、派生 PERIOD をサポートします。IS UNTIL_CLOSED/IS NOT
UNTIL_CLOSED を参照してください。
結果値
結果値には、次に示す規則が適用されます。
• 開始境界または終了境界が NULL の場合や、両方の境界が NULL の場合、結果は
NULL になります。
• 開始境界および終了境界が NULL の場合や、開始境界が NULL で終了境界が
UNTIL_CHANGED の場合、期間のタイプは PERIOD(TIMESTAMP(0))がデフォル
トになります。
• 開始境界のみを指定する場合、結果の終了境界は開始境界に結果の構成要素のタ
イプの 1 最小単位を加算したものになります。結果の終了境界が、PERIOD(DATE)
または PERIOD(TIMESTAMP(n) [WITH TIME ZONE])の結果のデータ タイプに許
容された、最大の DATE 値または TIMESTAMP 値以上になる場合は、エラーが報
告されます。
• 終了境界が値式として指定されていて、開始境界と終了境界の精度が異なる場
合、精度の高い方が結果の精度になります。それ以外の場合、結果の精度は開始
境界の精度になります。
• UNTIL_CHANGED により、結果の終了構成要素には、開始境界のデータ タイプ
に応じて DATE または TIMESTAMP の最大値が設定されます。開始境界のデー
タ タイプが TIMESTAMP(n) WITH TIME ZONE の場合、結果の終了構成要素は、
UTC での(つまり、終了境界のタイムゾーン変位が INTERVAL '00:00' HOUR TO
MINUTE になる)最大の TIMESTAMP(n) WITH TIME ZONE 値に設定されます。
• 開始境界または終了境界、または開始境界および終了境界にタイムゾーン値が含
まれる場合で、終了境界が UNTIL_CHANGED ではない場合、結果のデータ タイ
プは WITH TIME ZONE になります。境界のどちらかにのみタイムゾーン値が含
まれている場合、もう一方のタイムゾーンのフィールドには現在のセッションの
タイムゾーン変位が設定されます。どちらの境界にもタイムゾーン値が含まれて
いる場合は、それに対応するタイムゾーン値が結果の境界に含まれます。
980
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
Period 値コンストラクタ
• 結果の Period データ タイプは、前述の定義のように精度およびタイムゾーンを
除外した開始境界の日時データ タイプと同じ構成要素のタイプを持ちます。
• TIME および TIMESTAMP 構成要素のタイプを持つ Period データ タイプのうる
う秒は、次のように処理されます。開始境界または終了境界の値にうるう秒が含
まれている場合、秒部分が結果の精度にまで精度が切り詰められた 59.999999
に調整されます。この処理中に開始境界と終了境界が同じになると、エラーが報
告されます。
使用上の規則
Period 値コンストラクタには、次の規則が適用されます。
• 開始境界は日時データ タイプを持つ必要があり、終了境界が指定されている場
合は、開始境界および終了境界のデータ タイプを比較できるようにする必要が
あります。
• 開始境界のデータ タイプが DATE または TIMESTAMP の終了境界は、
UNTIL_CHANGED に設定できます。
• 終了境界が UNTIL_CLOSED に設定されている場合、以下が真になります。
• 開始境界値のデータ タイプは、TIMESTAMP(6) WITH TIME ZONE と比較可能
でなければなりません。
• コンストラクタは、結果が割り当てられるターゲット列が transaction-time 列
である場合の割り当て操作でのみ有効です。
• transaction-time 列の値を設定する方法が、非テンポラルの DML を使用する
こと以外にないため、コンストラクタは非テンポラルの DML 文でのみ有効で
す。
• 以下のいずれかが真の場合、Teradata Database はエラーを報告します。
• UNTIL_CHANGED が開始境界に指定されている。
• 結果の開始境界が、結果の終了境界以上か、等しくなる。
• 開始境界および終了境界のデータ タイプが比較可能ではない。
• 終了境界値に UNTIL_CHANGED が指定され、開始境界のデータ タイプが
TIME(n) [WITH TIME ZONE]。
• UNTIL_CLOSED が開始境界に指定されている。
例
次に示す例では、INTEGER 列 c1 および PERIOD(DATE)列 c2 を含むテーブル t1 と、
INTEGER 列 a および 2 つの DATE 列 b と c を含むテーブル t2 があると仮定します。
この例では、2 つの INSERT 文で使用される Period 値コンストラクタを示します。
INSERT INTO t1
VALUES (1, PERIOD(DATE '2005-02-03', DATE '2006-02-04'));
INSERT INTO t1 SELECT a, PERIOD(b, c) FROM t2;
SQL 関数、演算子、式および述部
981
第 23 章 期間関数および演算子
算術演算子
算術演算子
目的
Period 値に対して間隔値を加算または減算します。または、間隔値に Period 値を加
算します。
構文
period_expression
+
_
interval_expression
interval_expression
+
_
period_expression
構文要素
period_expression
変換される PERIOD 式。
PERIOD データ型と評価される任意の式。
interval_expression
INTERVAL データ型と評価される式。
INTERVAL データ タイプについて、詳細は< SQL データ型とリテラル、B035-1143>
を参照してください。
p は構成要素のタイプが DATE または TIMESTAMP の期間式で、v は間隔式だとしま
す。
• p + v および v + p は、どちらも次と等価になります。
PERIOD(BEGIN(p) + v, CASE WHEN END(p) IS UNTIL_CHANGED THEN END(p)
ELSE (END(p) + v) END)
• p - v は、次と等価になります。
PERIOD(BEGIN (p) - v, CASE WHEN END(p) IS UNTIL_CHANGED THEN END(p)
ELSE (END(p) - v) END)
p は構成要素のタイプが TIME の期間式で、v は間隔式だとします。
• p + v および v + p は、どちらも次と等価になります。
PERIOD(BEGIN(p) + v, END(p) + v)
• p - v は、次と等価になります。
PERIOD(BEGIN (p) - v, END(p) - v)
使用上の規則
算術演算子および Period データ タイプには、次に示すルールが適用されます。
982
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
期間タイプの比較
• 間隔式は、有効な間隔式であり、間隔式のルールに従っている必要があります
(「ANSI の間隔式」を参照)。そのようにしないと、エラーが報告されます。たと
えば、間隔式(DATE '2006-02-03' - DATE '2005-02-03') DAY は、結果として 365
日の値になり、間隔修飾子 DAY のデフォルト精度の 2 に収まらなくなるため、
エラーが報告されます。
• 期間に対する間隔の加算または減算や、間隔への期間の加算といった期間算術演
算は、日時式のルールに従います。そのようにしないと、エラーが報告されま
す。日時式のルールの詳細については、「ANSI の間隔式」を参照してください。
• 期間式から間隔式を減算することはできますが、その逆はできません。間隔式か
ら期間式を減算すると、エラーが報告されます。
• TIME の構成要素のタイプを含む期間式の場合、期間算術演算の結果として開始
境界が終了境界よりも小さくなると、エラーが報告されます。
• 構成要素のタイプが DATE または TIMESTAMP の期間では、終了境界が
UNTIL_CHANGED なら、結果として終了境界は UNTIL_CHANGED になります。
終了境界が UNTIL_CHANGED ではない場合に、結果として終了境界が
UNTIL_CHANGED 値と評価されるとエラーが報告されます。
• 期間算術演算では、オペランドの 1 つを INTERVAL データ タイプにする必要が
あります。そのようにしないと、エラーが報告されます。
期間タイプの比較
データ タイプ
主なフィールド
DATE
年、月、および日
TIME
時間、分、および秒
TIMESTAMP
YEAR、MONTH、DAY、HOUR、MINUTE、および
SECOND
2 つの Period 値の要素型が同じ DateTime データ型の場合は、これらの値を比較す
ることができます。日時データ タイプは、DATE、TIME、および TIMESTAMP など
です。
• PERIOD(DATE)データ タイプは、PERIOD(DATE)データ タイプと比較できます。
• PERIOD(TIME(n)[WITH TIME ZONE])データ タイプは、PERIOD(TIME(m)[WITH
TIME ZONE])データ タイプと比較できます。
• PERIOD(TIMESTAMP(n)[WITH TIME ZONE])データ タイプは、
PERIOD(TIMESTAMP(m)[WITH TIME ZONE])データ タイプと比較できます。
Teradata はこれを拡張して、CHARACTER 値と VARCHAR 値をいくつかの演算子に
対して PERIOD データ タイプとして暗黙にキャストできるようにし、これにより、
PERIOD データ タイプを持つことができるようにしています。PERIOD データ型は
他の期間式のデータ型なので、これらの期間式は比較対象になります。
SQL 関数、演算子、式および述部
983
第 23 章 期間関数および演算子
期間タイプの比較
日時および Period データは最大精度 6 で内部的に保存されますが、指定された精度
がこれより少ない場合はゼロが挿入されます。したがって、異なる精度の比較演算
子は、追加のロジックなしで機能します。
さらに、内部値は、時刻またはタイムスタンプ値については UTC に保存され、Period
値については、TIME または TIMESTAMP の構成要素のタイプで保存されます。この
内部表現により、すべての比較可能な期間式は直接比較することができます。タイ
ムゾーン値を含むかどうかや、これらの精度が同じかどうかは関係ありません。
注: 値を比較するときにはタイムゾーン値が無視されます。
システムのバージョン情報が設定された system-time 列またはテンポラル テーブル
の transaction-time 列の UNTIL_CLOSED に関与する、すべての比較演算子は、
UNTIL_CLOSED(TIMESTAMP '9999-12-3123:59:59:999999+00:00')の内部値を使
用して、結果を評価します。
比較演算子
次の表では、比較演算子について説明します。
演算子
目的
EQ または =
例えば、p1 および p2 は期間式で、比較可能な PERIOD データ型を持つと
します。
BEGIN(p1) = BEGIN(p2) AND END(p1) = END(p2)ならば、比較の結果は
TRUE になり、そうでなければ FALSE になります。
どちらかの期間式が NULL になる場合、結果は UNKNOWN となります。
期間式間の要素タイプが異なる場合は、いずれか一方が他方と同じになる
ような明示的な CAST が必要になります。
一方の期間式が Period データ タイプを持ち、他方の期間式が CHARACTER
または VARCHAR データ タイプを持つ場合、CHARACTER または
VARCHAR の式は、比較の前に、期間式のフォーマットに基づいて、期間
式のデータ タイプに暗黙的に変換されます。
EQ は、派生 PERIOD どうしの比較をサポートします。
LT または <
例えば、p1 および p2 は期間式で、比較可能な PERIOD データ型を持つと
します。
BEGIN(p1) < BEGIN(p2) OR (BEGIN(p1) = BEGIN(p2) AND END(p1) <
END(p2))ならば、比較の結果は TRUE になり、そうでなければ FALSE に
なります。
どちらかの期間式が NULL になる場合、結果は UNKNOWN となります。
期間式間の要素タイプが異なる場合は、いずれか一方が他方と同じになる
ような明示的な CAST が必要になります。
984
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
期間タイプの比較
演算子
目的
一方の期間式が Period データ タイプを持ち、他方の期間式が CHARACTER
または VARCHAR データ タイプを持つ場合、CHARACTER または
VARCHAR のオペランドは、比較の前に、期間式のフォーマットに基づい
て、期間式のデータ タイプに暗黙的に変換されます。
システムのバージョン情報が設定された system-time 列またはテンポラ
ル テーブルの transaction-time 列の終了境界値が UNTIL_CLOSED の場合、
終了境界値は TIMESTAMP 列値以下にしかなりません。あるいは、列値ま
たはリテラルがうるう秒で最大の TIMESTAMP 値になる場合も、終了境界
値は TIMESTAMP 定数以下にしかなりません。これは、システムのバー
ジョン情報が設定された system-time 列または transaction-time 列の終了
境界がタイムスタンプ値との比較に使用される場合にのみ可能です。テン
ポラル テーブルについて、詳細は<ANSI 一時テーブルのサポート 、
B035-1186>または<一時テーブルのサポート、B035-1182>を参照してく
ださい。
LT は、派生 PERIOD どうしの比較をサポートします。
GT または >
例えば、p1 および p2 は期間式で、比較可能な PERIOD データ型を持つと
します。
BEGIN(p1) > BEGIN(p2) OR (BEGIN(p1) = BEGIN(p2) AND END(p1) >
END(p2))ならば、比較の結果は TRUE になり、そうでなければ FALSE に
なります。
どちらかの期間式が NULL になる場合、結果は UNKNOWN となります。
一方の期間式が PERIOD データ型を持ち、他方の期間式が CHARACTER ま
たは VARCHAR データ型を持つ場合、CHARACTER または VARCHAR の期
間式は、比較の前に、期間式のフォーマットに基づいて、期間式のデータ
型に暗黙的に変換されます。
GT は、派生 PERIOD どうしの比較をサポートします。
NE または <> ま
たは
NOT = または^=
または
LE または <= ま
たは
GE または >=
SQL 関数、演算子、式および述部
これらの比較演算子は、比較可能な期間式間でサポートされます。
一方の期間式が Period データ タイプを持ち、他方の期間式が CHARACTER
または VARCHAR データ タイプを持つ場合、CHARACTER または
VARCHAR の期間式は、比較の前に、期間式のフォーマットに基づいて、
期間式のデータ タイプに暗黙的に変換されます。
NE、LE、および GE は、派生 PERIOD どうしの比較をサポートします。
985
第 23 章 期間関数および演算子
BEGIN
BEGIN
目的
期間式または派生 PERIOD の開始境界値を返します。
構文
BEGIN
( period_expression )
( derived_period )
構文要素
period_expression
変換される PERIOD 式。
derived_period
PERIOD データ型と評価される任意の式。
戻り値
BEGIN 関数の結果のデータ タイプは、期間式の構成要素のタイプと同じになるか、
または引数が派生 PERIOD 列である場合には開始列のデータ タイプと同じになりま
す。引数が NULL の場合、結果は NULL になります。
フォーマットおよびタイトル
書式は、期間式の構成要素のタイプのデフォルトの書式になるか、または引数が派
生 PERIOD 列である場合には開始列の書式になります。
エラー条件
引数に Period データ タイプがない場合は、エラーが報告されます。
例
例
BEGIN は、Period データ タイプの開始境界値を返します。
SELECT * FROM employee WHERE BEGIN(period1) = DATE '2004-06-19';
period1 が PERIOD(DATE)列の次の employee テーブルに対して、問合わせを実行し
たとします。
986
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
CONTAINS
ename
----Jones
Adams
Mary
Simon
dept
----------Sales
Marketing
Development
Sales
period1
---------------------------('2004-01-02', '2004-01-05')
('2004-06-19', '2005-02-09')
('2004-06-19', '2005-01-05')
('2004-06-22', '2005-01-07')
結果は以下のようになります。
ename
----Adams
Mary
dept
----------Marketing
Development
period1
---------------------------('2004-06-19', '2005-02-09')
('2004-06-19', '2005-01-05')
例
BEGIN は、次の SQL 文を使用して作成された jobduration という派生 PERIOD の開
始境界値(jdbegin)を返します。
CREATE TABLE employee(id INTEGER,
name VARCHAR(50),
jdbegin DATE NOT NULL FORMAT 'YYYY-MM-DD',
jdend
DATE NOT NULL FORMAT 'YYYY-MM-DD',
PERIOD FOR jobduration(jdbegin,jdend)
)PRIMARY INDEX(id);
次の SQL 文を実行します。
INSERT INTO employee(1025,'John',DATE'2011-01-02',DATE'2012-05-02');
SELECT BEGIN (jobduration) FROM employee;
次の結果が得られます。
jdbegin
__________
2011-01-02
CONTAINS
目的
2 つの期間式、派生 PERIOD、または日時式を TRUE、FALSE、または UNKNOWN
に評価します。
SQL 関数、演算子、式および述部
987
第 23 章 期間関数および演算子
CONTAINS
構文
period_expression
CONTAINS
period_expression
datetime_expression
derived_period
CONTAINS
period_expression
CONTAINS
derived_period
datetime_expression
NOT
datetime_expression
NOT
derived_period
NOT
period_expression
構文要素
period_expression
PERIOD データ型と評価される任意の式。
期間式は、他の式との比較が可能である必要があります。Period データ タイプへの
暗黙的なキャストはサポートされていません。
datetime_expression
DATE、TIME、または TIMESTAMP 値と評価される式。
derived_period
PERIOD データ型と評価される任意の式。
エラー条件
どちらかの式が期間または日時以外のデータ タイプと評価されると、エラーが報告
されます。
式に比較可能なデータ タイプがない場合、エラーが報告されます。
結果値
988
EID Name DeptNo
JobSt1
1
Tom
101
DATE'2 DATE'2004-0 DATE'2005-0 DATE'2006-01-01'
001-01- 1-01'
1-01'
01'
2
Rick
201
DATE'2 DATE'2006-0 DATE'2001-0 DATE'2004-01-01'
005-01- 1-01'
1-01'
01'
3
Joo
301
DATE'2 DATE'2006-0 DATE'2006-0 DATE'2007-01-01'
005-01- 1-01'
1-01'
01'
JobEnd1
JobSt2
JobEnd2
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
CONTAINS
EID Name DeptNo
JobSt1
JobEnd1
JobSt2
JobEnd2
4
Tam
401
DATE'2 DATE'2006-0 DATE'2002-0 DATE'2004-01-01'
001-01- 1-01'
1-01'
01'
5
Pat
501
DATE'2 DATE'2007-0 DATE'2006-0 DATE'2008-01-01'
005-01- 1-01'
1-01'
01'
6
Jack
601
DATE'2 DATE'2007-0 DATE'2007-0 DATE'2008-01-01'
005-01- 1-01'
1-01'
01'
7
Yu
701
DATE'2 DATE'2007-0 DATE'2004-0 DATE'2005-01-01'
005-01- 1-01'
1-01'
01'
8
Tim
801
DATE'2 DATE'2007-0 DATE'2005-0 DATE'2007-01-01'
005-01- 1-01'
1-01'
01'
例
例
period1 および period2 が PERIOD(DATE)列の employee テーブルに対して、次の問
合わせを実行したとします。
SELECT * FROM employee WHERE period2 CONTAINS period1;
ename
period1
period2
Adams
('2005-02-03',
'2006-02-03')
('2005-02-03',
'2006-02-03')
Mary
('2005-04-02',
'2006-01-03')
('2005-02-03',
'2006-02-03')
Jones
('2004-01-02',
'2004-03-05')
('2004-03-05',
'2004-10-07')
Randy
('2004-01-02',
'2004-03-05')
('2004-03-07',
'2004-10-07')
Simon
?
('2005-02-03',
'2005-07-27')
結果は以下のようになります。
SQL 関数、演算子、式および述部
989
第 23 章 期間関数および演算子
CONTAINS
ename
period1
period2
Adams
('2005-02-03',
'2006-02-03')
('2005-02-03',
'2006-02-03')
Mary
('2005-04-02',
'2006-01-03')
('2005-02-03',
'2006-02-03')
例
次の CREATE TABLE 文で作成された employee テーブルで、jobdur1 と jobdur2 が
派生 PERIOD 列であるとします。
CREATE TABLE employee (
eid INTEGER NOT NULL,
name VARCHAR(100) NOT NULL,
deptno INTEGER NOT NULL,
jobst1 DATE NOT NULL,
jobend1
DATE NOT NULL,
PERIOD FOR jobdur1(jobst1, jobend1),
jobst2 DATE NOT NULL,
jobend2
DATE NOT NULL,
PERIOD FOR jobdur2(jobst2, jobend2)
) PRIMARY INDEX(eid);
990
EID Name DeptNo
JobSt1
1
Tom
101
DATE'2 DATE'2004-0 DATE'2005-0 DATE'2006-01-01'
001-01- 1-01'
1-01'
01'
2
Rick
201
DATE'2 DATE'2006-0 DATE'2001-0 DATE'2004-01-01'
005-01- 1-01'
1-01'
01'
3
Joo
301
DATE'2 DATE'2006-0 DATE'2006-0 DATE'2007-01-01'
005-01- 1-01'
1-01'
01'
4
Tam
401
DATE'2 DATE'2006-0 DATE'2002-0 DATE'2004-01-01'
001-01- 1-01'
1-01'
01'
5
Pat
501
DATE'2 DATE'2007-0 DATE'2006-0 DATE'2008-01-01'
005-01- 1-01'
1-01'
01'
JobEnd1
JobSt2
JobEnd2
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
END
EID Name DeptNo
JobSt1
JobEnd1
JobSt2
JobEnd2
6
Jack
601
DATE'2 DATE'2007-0 DATE'2007-0 DATE'2008-01-01'
005-01- 1-01'
1-01'
01'
7
Yu
701
DATE'2 DATE'2007-0 DATE'2004-0 DATE'2005-01-01'
005-01- 1-01'
1-01'
01'
8
Tim
801
DATE'2 DATE'2007-0 DATE'2005-0 DATE'2007-01-01'
005-01- 1-01'
1-01'
01'
次の SQL 文では、CONTAINS を employee テーブルの派生 PERIOD 列で使用してい
ます。
SELECT eid, name, jobst1, jobend1, jobst2, jobend2
FROM employee
WHERE jobdur1 CONTAINS jobdur2;
結果は以下のようになります。
EID
Name
Dept
JobSt1
JobEnd1
JobSt2
JobEnd2
No
4
Tam
401
DATE'2001- DATE'200601-01'
01-01'
DATE'200201-01'
DATE'200401-01'
8
Tim
801
DATE'2005- DATE'200701-01'
01-01'
DATE'200501-01'
DATE'200701-01'
END
目的
期間引数の終了境界値を返します。
構文
END
( period_expression )
( derived_period )
SQL 関数、演算子、式および述部
991
第 23 章 期間関数および演算子
END
構文要素
period_expression
PERIOD データ型と評価される任意の式。
derived_period
PERIOD データ型と評価される任意の式。
戻り値
END 関数の結果のデータ タイプは、期間式の構成要素のタイプと同じになるか、ま
たは引数が派生 PERIOD 列である場合には終了列のデータ タイプと同じになりま
す。引数が NULL の場合、結果は NULL になります。
フォーマットおよびタイトル
書式は、期間式の構成要素のタイプのデフォルトの書式になるか、または引数が派
生 PERIOD 列である場合には終了列の書式になります。
エラー条件
Period データ タイプ以外のデータ タイプの引数が関数に渡されると、エラーが報告
されます。
例
例
次の問合わせを仮定します。
SELECT * FROM employee WHERE END(period1) = DATE '2005-01-07';
これを PERIOD(DATE)列が period1 である employee テーブルに対して実行します。
ename
----Jones
Adams
Mary
Simon
dept
----------Sales
Marketing
Development
Sales
period1
---------------------------('2004-01-02', '2004-01-05')
('2004-06-19', '2005-02-09')
('2004-06-19', '2005-01-05')
('2004-06-22', '2005-01-07')
結果は以下のようになります。
ename
----Simon
992
dept
----------Sales
period1
---------------------------('2004-06-22', '2005-01-07')
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
EQUALS
例
END は、次の SQL 文を使用して作成された jobduration という派生 PERIOD の終了
境界値(jdend)を返します。
CREATE TABLE employee(id INTEGER,
name VARCHAR(50),
jdbegin DATE NOT NULL FORMAT 'YYYY-MM-DD',
jdend
DATE NOT NULL FORMAT 'YYYY-MM-DD',
PERIOD FOR jobduration(jdbegin,jdend)
)PRIMARY INDEX(id);
次の SQL 文を実行します。
INSERT INTO employee(1025,'John',DATE'2011-01-02',DATE'2012-05-02');
SELECT END (jobduration) FROM employee;
次の結果が得られます。
jdend
__________
2011-05-02
EQUALS
目的
2 つの期間式または派生 PERIOD を TRUE、FALSE、または UNKNOWN に評価しま
す。
構文
period_expression
EQUALS
period_expression
derived_period
EQUALS
derived_period
period_expression
NOT
derived_period
NOT
構文要素
period_expression
PERIOD データ型と評価される任意の式。
期間式は、他の式との比較が可能である必要があります。Period データ タイプへの
暗黙的なキャストはサポートされていません。
SQL 関数、演算子、式および述部
993
第 23 章 期間関数および演算子
EQUALS
derived_period
PERIOD データ型と評価される任意の式。
結果値
• 両方の式に Period データ タイプまたは派生 PERIOD がある場合、第 1 の式の開
始境界および終了境界が第 2 の式の開始境界および終了境界に等しい場合には
TRUE を返し、それ以外の場合は FALSE を返します。
• どちらかのオペランドが NULL の場合、演算子は UNKNOWN を返します。
例
例
次の CREATE TABLE 文で作成された employee1 テーブルで、period1 と period2 が
PERIOD (DATE)列であるとします。
CREATE TABLE employee1 (
eid INTEGER NOT NULL,
name VARCHAR(100) NOT NULL,
deptno INTEGER NOT NULL,
period1(date),
period2(date)
) PRIMARY INDEX(eid);
EID
Name
DeptNo
Period1
Period2
1
Adams
101
('2005-02-03',
'2006-02-03')
('2005-02-03',
'2006-02-03')
2
Mary
201
('2005-04-02',
'2006-01-03')
('2006-01-03',
'2007-02-03')
3
Jones
301
('2004-01-02',
'2005-03-05')
('2003-03-05',
'2004-01-02')
次の SQL 文では、EQUALS を employee1 テーブルの PERIOD 列で使用しています。
SELECT eid, name, depno, period1, period2
FROM employee1
WHERE period1 EQUALS period2;
結果は以下のようになります。
994
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
EQUALS
EID
Name
DeptNo
Period1
Period2
1
Adams
101
('2005-02-03',
'2006-02-03')
('2005-02-03',
'2006-02-03')
例
次の CREATE TABLE 文で作成された employee テーブルで、jobdur1 と jobdur2 が
派生 PERIOD 列であるとします。
CREATE TABLE employee (
eid INTEGER NOT NULL,
name VARCHAR(100) NOT NULL,
deptno INTEGER NOT NULL,
jobst1 DATE NOT NULL,
jobend1
DATE NOT NULL,
PERIOD FOR jobdur1(jobst1, jobend1),
jobst2 DATE NOT NULL,
jobend2
DATE NOT NULL,
PERIOD FOR jobdur2(jobst2, jobend2)
) PRIMARY INDEX(eid);
EID
Name
Dept
JobSt1
JobEnd1
JobSt2
JobEnd2
No
1
Tom
101
DATE'200101-01'
DATE'200401-01'
DATE'2005- DATE'2006-0
01-01'
1-01'
2
Rick
201
DATE'200501-01'
DATE'200601-01'
DATE'2001- DATE'2004-0
01-01'
1-01'
3
Joo
301
DATE'200501-01'
DATE'200601-01'
DATE'2006- DATE'2007-0
01-01'
1-01'
4
Tam
401
DATE'200101-01'
DATE'200601-01'
DATE'2002- DATE'2004-0
01-01'
1-01'
5
Pat
501
DATE'200501-01'
DATE'200701-01'
DATE'2006- DATE'2008-0
01-01'
1-01'
6
Jack
601
DATE'200501-01'
DATE'200701-01'
DATE'2007- DATE'2008-0
01-01'
1-01'
7
Yu
701
DATE'200501-01'
DATE'200701-01'
DATE'2004- DATE'2005-0
01-01'
1-01'
8
Tim
801
DATE'200501-01'
DATE'200701-01'
DATE'2005- DATE'2007-0
01-01'
1-01'
次の SQL 文では、EQUALS を employee テーブルの派生 PERIOD 列で使用していま
す。
SQL 関数、演算子、式および述部
995
第 23 章 期間関数および演算子
IS UNTIL_CHANGED/IS NOT UNTIL_CHANGED
SELECT eid, name, deptno, jobst1, jobend1, jobst2, jobend2
FROM employee
WHERE jobdur1 EQUALS jobdur2;
結果は以下のようになります。
EID
Name
Dept
JobSt1
JobEnd1
JobSt2
JobEnd2
No
8
Tim
801
DATE'2005- DATE'200701-01'
01-01'
DATE'2005- 'DATE'200701-01'
01-01'
IS UNTIL_CHANGED/IS NOT UNTIL_CHANGED
目的
期間式または派生 PERIOD の終了境界値が UNTIL_CHANGED か、または IS NOT
UNTIL_CHANGED であるかをテストします。
構文
END
( period_expression )
IS
( derived_period )
UNTIL_CHANGED
NOT
構文要素
period_expression
PERIOD データ型と評価される任意の式。次のものがあります。
• PERIOD (TIMESTAMP WITH TIME ZONE)
• PERIOD (TIMESTAMP)
• PERIOD(DATE)タイプ
derived_period
PERIOD データ型と評価される任意の式。
使用上の注意
UNTIL_CHANGED は、要素タイプが DATE または TIMESTAMP WITH TIME ZONE で
ある Period 値の終了境界とのみ比較可能です。そのため、END 関数の結果の型は
DATE または TIMESTAMP WITH TIME ZONE でなければなりません。END 関数につ
いては、「END」を参照してください。
比較の際に、UNTIL_CHANGED 値の精度は、比較対象の終了境界値の精度にまで切
り詰められます。つまり、UNTIL_CHANGED の小数点以下桁数は、比較対象の終了
996
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
IS UNTIL_CHANGED/IS NOT UNTIL_CHANGED
境界値の精度によって変わるということです。終了境界値にタイムゾーンがなけれ
ば、タイムゾーンは省略されます。
終了境界値が NULL の場合、IS [NOT] UNTIL_CHANGED は UNKNOWN を返します。
system-time 列またはテンポラル テーブルの列の終了境界で IS [NOT]
UNTIL_CHANGED を使用することはできません。
例
例
次の employee テーブルでは、列 eduration が PERIOD(DATE)データ型として定義さ
れているとします。
ename
---------Adams
Gunther
Montoya
Chan
Fuller
eid
----------210677
199347
199340
210427
197899
eduration
-----------------------('05/03/01', '06/05/21')
('04/06/06', '99/12/31')
('04/06/02', '99/12/31')
('04/09/24', '99/12/31')
('03/05/27', '03/11/30')
次の SQL 問合わせでは、IS UNTIL_CHANGED を使用して eduration 列の終了境界値
と UNTIL_CHANGED とを比較します。
SELECT ename, eid
FROM employee
WHERE END(eduration) IS UNTIL_CHANGED;
結果は以下のようになります。
ename
---------Gunther
Montoya
Chan
eid
----------199347
199340
210427
例
次の SQL 文で employee テーブルが作成されたとします。
CREATE MULTISET TABLE employee(empno
INTEGER,
ename
VARCHAR(50),
deptno
INTEGER,
jobstart DATE NOT NULL,
jobend
DATE NOT NULL,
PERIOD FOR jobduration(jobstart, jobend))
PRIMARY INDEX(empno);
SQL 関数、演算子、式および述部
997
第 23 章 期間関数および演算子
IS UNTIL_CLOSED/IS NOT UNTIL_CLOSED
次の行が含まれています。
INSERT INTO employee(1025, 'John', '999', DATE'2005-02-03',
UNTIL_CHANGED);
次の SELECT 文について考えてみます。
SELECT empno,ename(CHAR(30)) FROM employee WHERE END(jobduration) IS
UNTIL_CHANGED;
次の結果が得られます。
empno ename
------ -----1025
John
IS UNTIL_CLOSED/IS NOT UNTIL_CLOSED
目的
テンポラル テーブルの system-time 列または transaction-time 列の終了境界値をテ
ストして、行が開いている(終了境界値 IS UNTIL_CLOSED)のか、閉じている(終了境
界値 IS NOT UNTIL_CLOSED)のかを調べます。
構文
END
( period_expression )
IS
( derived_period )
UNTIL_CLOSED
NOT
構文要素
period_expression
PERIOD データ型と評価される任意の式。
derived_period
PERIOD データ型と評価される任意の式。
使用上の注意
system-time 次元(列)または transaction-time 次元(列)のあるテンポラル テーブルで
行が作成されると、Teradata Database により列の終了境界が UNTIL_CLOSED に設
定され、その行は開いていると見なされます。行を閉じると、Teradata Database は
終了境界値を終了のタイムスタンプに設定します。
指定された transaction-time 列の終了境界が最大のタイムスタンプ値(9999-12-31
23:59:59.999999+00: 00)の場合、IS UNTIL_CLOSED が真と評価されます。
998
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
IS UNTIL_CLOSED/IS NOT UNTIL_CLOSED
例
例
CREATE MULTISET TABLE employee(
empno INTEGER,
ename VARCHAR(50),
deptno INTEGER,
jobstart TIMESTAMP WITH TIME ZONE NOT NULL
GENERATED ALWAYS AS ROW START,
jobend TIMESTAMP WITH TIME ZONE NOT NULL AS
GENERATED ALWAYS AS ROW END,
PERIOD FOR SYSTEM_TIME(jobstart,jobend)
)
PRIMARY INDEX(empno) WITH SYSTEM VERSIONING;
テーブルに以下の行が含まれているとします。
empno ename deptno
jobstart
jobend
----- ------ ------ -------------------------------- -------------------------------1025 John
999 2005-02-03 12:12:12.123456+00:00 9999-12-31
23:59:59.999999+00:00
次の SELECT 文の結果は次のとおりです。
SELECT empno,ename(CHAR(6)) FROM employee
WHERE END(SYSTEM_TIME) IS UNTIL_CLOSED;
empno ename
------ -----1025 John
SELECT empno,ename(CHAR(6)) FROM employee
WHERE END(SYSTEM_TIME) IS NOT UNTIL_CLOSED;
*** Query completed. No rows found.
例
次の SQL 文で employee テーブルが作成されたとします。
CREATE MULTISET TABLE employee(
id INTEGER,
name VARCHAR(50),
dept INTEGER,
tt PERIOD(TIMESTAMP(6)WITH TIME ZONE) NOT NULL AS TRANSACTIONTIME
SQL 関数、演算子、式および述部
999
第 23 章 期間関数および演算子
IMMEDIATELY PRECEDES
)
PRIMARY INDEX(id);
次のように実際の期間を表わす行が含まれています。
INSERT INTO employee(102, 'John', 222);
次の SELECT 文について考えてみます。
SELECT * FROM employee WHERE END(tt) IS UNTIL_CLOSED;
次の結果が得られます。
id
name
dept
-------------------102
John
222
IMMEDIATELY PRECEDES
目的
2 つの期間式または派生 PERIOD を TRUE、FALSE、または UNKNOWN に評価しま
す。
構文
構文要素
period_expression1/period_expression2
PERIOD データ型と評価される任意の式。
期間式は、他の式との比較が可能である必要があります。Period データ タイプへの
暗黙的なキャストはサポートされていません。
derived_period1/derived_period2
PERIOD データ型と評価される任意の式。
1000
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
IMMEDIATELY PRECEDES
結果値
この述部は、period_expression_1 と period_expression_2 の両方が PERIOD 列、
PERIOD のコンストラクタ、または Period 値の式である場合に適用されます。この
場合、述部は period_expression_1 の終了境界値が period_expression_2 の開始境
界値と等しい場合に真を返します。オペランドのいずれか、または両方が NULL で
ある場合、結果は UNKNOWN となります。
どちらかの式が NULL の場合、演算子は UNKNOWN を返します。
例
例
次の CREATE TABLE 文で作成された employee1 テーブルで、period1 と period2 が
PERIOD(DATE)列であるとします。
CREATE TABLE employee1 (
eid INTEGER NOT NULL,
name VARCHAR(100) NOT NULL,
deptno INTEGER NOT NULL,
period1(date),
period2(date)
) PRIMARY INDEX(eid);
EID
Name
DeptNo
Period1
Period2
1
Adams
101
('2005-02-03',
'2006-02-03')
('2005-02-03',
'2006-02-03')
2
Mary
201
('2005-04-02',
'2006-01-03')
('2006-01-03',
'2007-02-03')
3
Jones
301
('2004-01-02',
'2005-03-05')
('2003-03-05',
'2004-01-02')
次の SQL 文では、IMMEDIATELY PRECEDES を employee1 テーブルの PERIOD 列
で使用しています。
SELECT eid, name, depno, period1, period2
FROM employee1
WHERE period1 IMMEDIATELY PRECEDES period2;
結果は以下のようになります。
EID
Name
DeptNo
Period1
Period2
2
Mary
201
('2005-04-02',
'2006-01-03')
('2006-01-03',
'2007-02-03')
SQL 関数、演算子、式および述部
1001
第 23 章 期間関数および演算子
IMMEDIATELY PRECEDES
例
次の CREATE TABLE 文で作成された employee テーブルで、jobdur1 と jobdur2 が
派生 PERIOD 列であるとします。
CREATE TABLE employee (
eid INTEGER NOT NULL,
name VARCHAR(100) NOT NULL,
deptno INTEGER NOT NULL,
jobst1 DATE NOT NULL,
jobend1
DATE NOT NULL,
PERIOD FOR jobdur1(jobst1, jobend1),
jobst2 DATE NOT NULL,
jobend2
DATE NOT NULL,
PERIOD FOR jobdur2(jobst2, jobend2)
) PRIMARY INDEX(eid);
1002
EID Name DeptNo
JobSt1
JobEnd1
JobSt2
JobEnd2
1
Tom
101
DATE'2 DATE'2004-0 DATE'2005-0 DATE'2006-01-01'
001-01- 1-01'
1-01'
01'
2
Rick
201
DATE'2 DATE'2006-0 DATE'2001-0 DATE'2004-01-01'
005-01- 1-01'
1-01'
01'
3
Joo
301
DATE'2 DATE'2006-0 DATE'2006-0 DATE'2007-01-01'
005-01- 1-01'
1-01'
01'
4
Tam
401
DATE'2 DATE'2006-0 DATE'2002-0 DATE'2004-01-01'
001-01- 1-01'
1-01'
01'
5
Pat
501
DATE'2 DATE'2007-0 DATE'2006-0 DATE'2008-01-01'
005-01- 1-01'
1-01'
01'
6
Jack
601
DATE'2 DATE'2007-0 DATE'2007-0 DATE'2008-01-01'
005-01- 1-01'
1-01'
01'
7
Yu
701
DATE'2 DATE'2007-0 DATE'2004-0 DATE'2005-01-01'
005-01- 1-01'
1-01'
01'
8
Tim
801
DATE'2 DATE'2007-0 DATE'2005-0 DATE'2007-01-01'
005-01- 1-01'
1-01'
01'
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
IMMEDIATELY SUCCEEDS
IMMEDIATELY SUCCEEDS
目的
2 つの期間式または派生 PERIOD を TRUE、FALSE、または UNKNOWN に評価しま
す。
構文
構文要素
period_expression1/period_expression2
PERIOD データ型と評価される任意の式。
期間式は、他の式との比較が可能である必要があります。Period データ タイプへの
暗黙的なキャストはサポートされていません。
derived_period1/derived_period2
PERIOD データ型と評価される任意の式。
結果値
この述部は、period_expression_1 と period_expression_2 の両方が PERIOD 列、
PERIOD のコンストラクタ、または Period 値の式である場合に適用されます。この
場合、述部は period_expression_1 の開始境界値が period_expression_2 の終了境
界値と等しい場合に真を返します。オペランドのいずれか、または両方が NULL で
ある場合、結果は UNKNOWN となります。
どちらかの式が NULL の場合、演算子は UNKNOWN を返します。
例
例
次の CREATE TABLE 文で作成された employee1 テーブルで、period1 と period2 が
PERIOD(DATE)列であるとします。
CREATE TABLE employee1 (
eid INTEGER NOT NULL,
name VARCHAR(100) NOT NULL,
SQL 関数、演算子、式および述部
1003
第 23 章 期間関数および演算子
IMMEDIATELY SUCCEEDS
deptno INTEGER NOT NULL,
period1(date),
period2(date)
) PRIMARY INDEX(eid);
EID
Name
DeptNo
Period1
Period2
1
Adams
101
('2005-02-03',
'2006-02-03')
('2005-02-03',
'2006-02-03')
2
Mary
201
('2005-04-02',
'2006-01-03')
('2006-01-03',
'2007-02-03')
3
Jones
301
('2004-01-02',
'2005-03-05')
('2003-03-05',
'2004-01-02')
次の SQL 文では、IMMEDIATELY SUCCEEDS を employee1 テーブルの PERIOD 列で
使用しています。
SELECT eid, name, deptno, period1, period2
FROM employee1
WHERE period1 IMMEDIATELY SUCCEEDS period2;
結果は以下のようになります。
EID
Name
DeptNo
Period1
Period2
3
Jones
301
('2004-01-02',
'2005-03-05')
('2003-03-05',
'2004-01-02')
例
次の CREATE TABLE 文で作成された employee テーブルで、jobdur1 と jobdur2 が
派生 PERIOD 列であるとします。
CREATE TABLE employee (
eid INTEGER NOT NULL,
name VARCHAR(100) NOT NULL,
deptno INTEGER NOT NULL,
jobst1 DATE NOT NULL,
jobend1
DATE NOT NULL,
PERIOD FOR jobdur1(jobst1, jobend1),
jobst2 DATE NOT NULL,
jobend2
DATE NOT NULL,
PERIOD FOR jobdur2(jobst2, jobend2)
) PRIMARY INDEX(eid);
1004
EID Name DeptNo
JobSt1
1
DATE'2 DATE'2004-0 DATE'2005-0 DATE'2006-01-01'
001-01- 1-01'
1-01'
01'
Tom
101
JobEnd1
JobSt2
JobEnd2
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
INTERVAL
EID Name DeptNo
JobSt1
JobEnd1
JobSt2
JobEnd2
2
Rick
201
DATE'2 DATE'2006-0 DATE'2001-0 DATE'2004-01-01'
005-01- 1-01'
1-01'
01'
3
Joo
301
DATE'2 DATE'2006-0 DATE'2006-0 DATE'2007-01-01'
005-01- 1-01'
1-01'
01'
4
Tam
401
DATE'2 DATE'2006-0 DATE'2002-0 DATE'2004-01-01'
001-01- 1-01'
1-01'
01'
5
Pat
501
DATE'2 DATE'2007-0 DATE'2006-0 DATE'2008-01-01'
005-01- 1-01'
1-01'
01'
6
Jack
601
DATE'2 DATE'2007-0 DATE'2007-0 DATE'2008-01-01'
005-01- 1-01'
1-01'
01'
7
Yu
701
DATE'2 DATE'2007-0 DATE'2004-0 DATE'2005-01-01'
005-01- 1-01'
1-01'
01'
8
Tim
801
DATE'2 DATE'2007-0 DATE'2005-0 DATE'2007-01-01'
005-01- 1-01'
1-01'
01'
次の SQL 文では、IMMEDIATELY SUCCEEDS を employee テーブルの派生 PERIOD
列で使用しています。
SELECT eid, name, depno, jobst1, jobend1, jobst2, jobend2
FROM employee
WHERE jobdur1 IMMEDIATELY SUCCEEDS jobdur2;
結果は以下のようになります。
EID
Name
DeptNo
JobSt1
7
Yu
701
DATE'2005- DATE'200701-01'
01-01'
JobEnd1
JobSt2
JobEnd2
DATE'200401-01'
DATE'2005-0
1-01'
INTERVAL
目的
期間式または派生 PERIOD の終了境界と開始境界の差を算出し、その差を指定した
間隔修飾子に引数の時間間隔として返します。
SQL 関数、演算子、式および述部
1005
第 23 章 期間関数および演算子
INTERVAL
構文
INTERVAL
( period_expression )
interval_qualifier
( derived_period )
構文要素
period_expression
PERIOD データ型と評価される任意の式。
derived_period
PERIOD データ型と評価される任意の式。
interval_qualifier
引数の要素の型に適合する任意の間隔修飾子。間隔修飾子は、次のとおりです。
年-月の間隔:
• YEAR
• YEAR TO MONTH
• MONTH
日-時刻の間隔:
•
•
•
•
•
•
•
DAY
DAY TO HOUR、MINUTE または SECOND
HOUR
HOUR TO MINUTE または SECOND
MINUTE
MINUTE TO SECOND
SECOND
戻り値
引数 p が期間式で、IQ が間隔修飾子だとすると、INTERVAL (p) IQ 関数の結果は、
(END(p) - BEGIN(p)) IQ の値になります。
引数が NULL の場合、結果は NULL になります。
フォーマットおよびタイトル
フォーマットは、指定した間隔修飾子と一致する間隔データ タイプのデフォルト
フォーマットです。
タイトルは、INTERVAL(period _expression) interval_qualifier です。
エラー条件
エラーが報告される可能性のある条件は、次のとおりです。
1006
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
INTERVAL
• INTERVAL 関数の引数に、Period データ タイプがない場合。
• 引数に PERIOD(DATE)データ タイプがあるのに、間隔修飾子が YEAR、YEAR TO
MONTH、MONTH または DAY ではない場合。
• 引数に PERIOD(TIME(n) [WITH TIME ZONE])データ タイプがあるのに、間隔修
飾子が HOUR、HOUR TO MINUTE、HOUR TO SECOND、MINUTE、MINUTE TO
SECOND または SECOND ではない場合。
• INTERVAL 式の結果が、間隔修飾子の精度に規定されたルールに違反する場合
は、エラーがレポートされる。たとえば、p1 が PERIOD '(2006-01-01 12:12:12,
2007-01-01 12:12:12)'の値を持つ PERIOD(TIMESTAMP(0))式だとします。
INTERVAL(p1) DAY が指定されている場合、DAY 間隔修飾子のデフォルトの精度
は 2 になります。3 桁の値になる 365 日は DAY(2)間隔修飾子に収まらないため、
エラーが報告されます。
• INTERVAL 関数の引数が、DATE または TIMESTAMP(n) [WITH TIME ZONE]を含
む期間で、終了境界の値が UNTIL_CHANGED の場合。
例
例
period1 が PERIOD(DATE)列の employee テーブルに対して、次の問合わせを実行し
たとします。
SELECT INTERVAL (period1) MONTH FROM employee;
ename
dept
period1
-----------------------------------------Jones
Sales
('2004-01-02', '2004-03-05')
結果は以下のようになります。
INTERVAL(period) MONTH
----------------------2
例
INTERVAL は、次の SQL 文を使用して作成された jobduration という派生 PERIOD
の間隔値を返します。
CREATE TABLE employee(id INTEGER,
name VARCHAR(50),
jdbegin DATE NOT NULL FORMAT 'YYYY-MM-DD',
jdend
DATE NOT NULL FORMAT 'YYYY-MM-DD',
PERIOD FOR jobduration(jdbegin,jdend)
)PRIMARY INDEX(id);
次の値が employee テーブルに挿入されるとします。
INSERT INTO employee(1025,'John',DATE'2011-01-02',DATE'2012-05-02');
SQL 関数、演算子、式および述部
1007
第 23 章 期間関数および演算子
LAST
次の SQL 文を実行します。
SELECT INTERVAL(jobduration)MONTH(4) FROM employee;
次の結果が得られます。
INTERVAL(jobduration) MONTH
----------------------------16
LAST
目的
期間引数の最後の値(つまり、終了境界から引数の構成要素のタイプの 1 最小単位を
減算した値)を返します。
構文
LAST
( period_expression )
( derived_period )
構文要素
period_expression
PERIOD データ型と評価される任意の式。
derived_period
PERIOD データ型と評価される任意の式。
戻り値
LAST 関数の結果のデータ タイプは、期間式の構成要素のタイプと同じになるか、
または引数が派生 PERIOD 列である場合には開始列または終了列のデータ タイプと
同じになります。引数が NULL の場合、結果は NULL になります。
フォーマットおよびタイトル
書式は、期間式の構成要素のタイプのデフォルトの書式になるか、または引数が派
生 PERIOD である場合には開始列または終了列の書式になります。
エラー条件
引数に Period データ タイプ以外のデータ タイプがあると、エラーが報告されます。
1008
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
LAST
例
例
period1 が PERIOD(DATE)列の employee テーブルに対して、次の問合わせを実行し
たとします。
SELECT * FROM employee WHERE LAST(period1) = DATE '2004-01-04';
ename
dept
period1
-----------------------------------------Jones
Sales
('2004-01-02', '2004-01-05')
Adams
Marketing
('2004-06-19', '2005-02-09')
Mary
Development
('2004-06-19', '2005-01-05')
Simon
Sales
('2004-06-22', '2005-01-07')
結果は以下のようになります。
ename
----Jones
dept
----------Sales
period1
---------------------------('2004-01-02', '2004-01-05')
例
LAST は、次の SQL 文を使用して作成された jobduration という派生 PERIOD の最
後の値を返します。
CREATE TABLE employee(id INTEGER,
name VARCHAR(50),
jdbegin DATE NOT NULL FORMAT 'YYYY-MM-DD',
jdend
DATE NOT NULL FORMAT 'YYYY-MM-DD',
PERIOD FOR jobduration(jdbegin,jdend)
)PRIMARY INDEX(id);
次の値が employee テーブルに挿入されるとします。
INSERT INTO employee(1025,'John',DATE'2011-01-02',DATE'2012-05-02');
次の SQL 文を実行します。
SELECT LAST (jobduration) FROM employee;
次の結果が得られます。
LAST(jobduration)
-----------------------2012-05-01
SQL 関数、演算子、式および述部
1009
第 23 章 期間関数および演算子
MEETS
MEETS
目的
2 つの期間式、派生 PERIOD、または日時式を TRUE、FALSE、または UNKNOWN
に評価します。
構文
period_expression
MEETS
period_expression
datetime_expression
NOT
derived_period
datetime_expression
MEETS
period_expression
NOT
derived_period
MEETS
NOT
derived_period
period_expression
構文要素
period_expression
PERIOD データ型と評価される任意の式。
期間式は、他の式との比較が可能である必要があります。Period データ タイプへの
暗黙的なキャストはサポートされていません。
datetime_expression
DATE、TIME、または TIMESTAMP 値と評価される式。
derived_period
PERIOD データ型と評価される任意の式。
結果値
• 両方の式に Period データ タイプまたは派生 PERIOD がある場合、第 1 の式の終
了境界が第 2 の式の開始境界に等しいか、第 2 の式の終了境界が第 1 の式の開始
境界に等しい場合には TRUE を返し、それ以外の場合は FALSE を返します。
• 一方の式が Period データ タイプで、他方の式が日時式の場合、期間式の終了境
界が日時式に等しいか、日時式に 1 最小単位を加算したものが期間式の終了境界
に等しい場合は TRUE を返し、それ以外の場合は FALSE を返します。
• どちらかの式が NULL の場合、関数は UNKNOWN を返します。
1010
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
MEETS
エラー条件
どちらかの式が期間または日時以外のデータ タイプと評価されると、エラーが報告
されます。
式の間での比較ができないとエラーが報告されます。
例
例
period1 および period2 が PERIOD(DATE)列の employee テーブルに対して、次の問
合わせを実行したとします。
SELECT * FROM employee WHERE period2 MEETS period1;
ename
period1
period2
Adams
('2005-02-03',
'2006-02-03')
('2005-02-03',
'2006-02-03')
Mary
('2005-04-02',
'2006-01-03')
('2005-02-03',
'2006-02-03')
Jones
('2004-01-02',
'2004-03-05')
('2004-03-05',
'2004-10-07')
Randy
('2004-01-02',
'2004-03-05')
('2004-03-07',
'2004-10-07')
Simon
?
('2005-02-03',
'2005-07-27')
結果は以下のようになります。
ename
period1
Jones
('2004-01-02','2004-03-05') ('2004-03-05',
'2004-10-07')
period2
例: MEETS の使用
次の CREATE TABLE 文で作成された employee テーブルで、jobdur1 と jobdur2 が
派生 PERIOD 列であるとします。
CREATE TABLE employee (
eid INTEGER NOT NULL,
name VARCHAR(100) NOT NULL,
deptno INTEGER NOT NULL,
jobst1 DATE NOT NULL,
jobend1
DATE NOT NULL,
PERIOD FOR jobdur1(jobst1, jobend1),
jobst2 DATE NOT NULL,
SQL 関数、演算子、式および述部
1011
第 23 章 期間関数および演算子
MEETS
jobend2
DATE NOT NULL,
PERIOD FOR jobdur2(jobst2, jobend2)
) PRIMARY INDEX(eid);
EID Name DeptNo
JobSt1
JobEnd1
JobSt2
JobEnd2
1
Tom
101
DATE'2 DATE'2004-0 DATE'2005-0 DATE'2006-01-01'
001-01- 1-01'
1-01'
01'
2
Rick
201
DATE'2 DATE'2006-0 DATE'2001-0 DATE'2004-01-01'
005-01- 1-01'
1-01'
01'
3
Joo
301
DATE'2 DATE'2006-0 DATE'2006-0 DATE'2007-01-01'
005-01- 1-01'
1-01'
01'
4
Tam
401
DATE'2 DATE'2006-0 DATE'2002-0 DATE'2004-01-01'
001-01- 1-01'
1-01'
01'
5
Pat
501
DATE'2 DATE'2007-0 DATE'2006-0 DATE'2008-01-01'
005-01- 1-01'
1-01'
01'
6
Jack
601
DATE'2 DATE'2007-0 DATE'2007-0 DATE'2008-01-01'
005-01- 1-01'
1-01'
01'
7
Yu
701
DATE'2 DATE'2007-0 DATE'2004-0 DATE'2005-01-01'
005-01- 1-01'
1-01'
01'
8
Tim
801
DATE'2 DATE'2007-0 DATE'2005-0 DATE'2007-01-01'
005-01- 1-01'
1-01'
01'
次の SQL 文では、MEETS を employee テーブルの派生 PERIOD 列で使用しています。
SELECT eid, name, deptno, jobst1, jobend1, jobst2, jobend2
FROM employee
WHERE jobdur1 MEETS jobdur2;
結果は以下のようになります。
EID
Name
Dept
JobSt1
JobEnd1
JobSt2
JobEnd2
No
1012
3
Joo
301
DATE'2005-01- DATE'2006-0
01'
1-01'
DATE'2006-01-0 DATE'2007-0
1'
1-01'
6
Jack
601
DATE'2005-01- DATE'2007-0
01'
1-01'
DATE'2007-01-0 DATE'2008-0
1'
1-01'
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
NEXT
EID
Name
Dept
JobSt1
JobEnd1
JobSt2
JobEnd2
No
7
Yu
701
DATE'2005-01- DATE'2007-0
01'
1-01'
DATE'2004-01-0 DATE'2005-0
1'
1-01'
NEXT
目的
引数の次の値(引数と返される値の差が、引数のタイプの最小単位 1 つ分)を返します。
構文
NEXT ( datetime_expression )
構文要素
datetime_expression
DATE、TIME、または TIMESTAMP 値と評価される式。
戻り値
結果のデータ タイプは、引数のデータ タイプと同じになります。引数の値が NULL
の場合、結果は NULL になります。
フォーマットおよびタイトル
フォーマットは、近似引数のデータ タイプのデフォルト フォーマットです。
エラー条件
引数に日時データ タイプがない場合は、エラーが報告されます。
結果が引数のデータ タイプの値に許容された範囲を超えると、エラーが報告されま
す。たとえば、NEXT(DATE '9999-12-31')が指定されると、エラーが報告されます。
例
period1 が PERIOD(DATE)列の employee テーブルに対して、次の問合わせを実行し
たとします。
SQL 関数、演算子、式および述部
1013
第 23 章 期間関数および演算子
OVERLAPS
SELECT *
FROM employee
WHERE NEXT(END(period1)) = DATE '2004-03-06';
ename
dept
period1
-----------------------------------------Jones
Sales
('2004-01-02', '2004-03-05')
Simon
Sales
?
結果は以下のようになります。
ename
----Jones
dept
----------Sales
period1
---------------------------('2004-01-02', '2004-03-05')
OVERLAPS
目的
2 つの時間が相互に重なっているかどうかをテストします。
構文
構文要素
datetime_expression
開始および終了日時。
interval_expression
終了日時。
1014
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
OVERLAPS
row_subquery
式または式のリストで指定された数と同じ数の式を選択する副問合わせ。
Subquery で SELECT AND CONSUME 文を指定することはできません。
period_expression
変換される PERIOD 式。
derived_period
PERIOD データ型と評価される任意の式。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
時間
時間の始まりと終わりの日時値が年代順に配列されない場合には、すべてに
end_DateTime >= start_DateTime という規則を使用して、そのように配列されてか
ら比較されます。
時間に null の start_DateTime と非 null の end_DateTime が含まれている場合、値
は非 null の start_DateTime と null の end_DateTime を示すように切り替わります。
注: Period データ タイプへの暗黙的なキャストはサポートされていません。
結果
次の一般的な OVERLAPS の比較について説明します。
(S1, E1) OVERLAPS (S2, E2)
OVERLAPS の結果は、以下のようになります。
(S1 > S2 AND NOT (S1 >= E2 AND E1 >= E2))
OR
(S2 > S1 AND NOT (S2 >= E1 AND E2 >= E1))
OR
(S1 = S2 AND (E1 = E2 OR E1 <> E2))
Period データ タイプまたは派生 PERIOD(p1 が第 1 の期間式または派生 PERIOD、
p2 が第 2 の期間式または派生 PERIOD)の場合、S1、E1、S2、および E2 の値は、
次のようになります。
S1 = BEGIN(p1)
E1 = END(p1)
SQL 関数、演算子、式および述部
1015
第 23 章 期間関数および演算子
OVERLAPS
S2 = BEGIN(p2)
E2 = END(p2)
規則
• 2 つの日時タイプを指定するときには、比較可能でなければなりません。
• 2 つの期間タイプ(派生 PERIOD も含む)を指定する場合、それらは比較可能でな
ければなりません。
• 期間タイプを 1 つまたは両方の期間に指定する場合、期間式に NULL を明示的に
含めてはいけません。
• 最初の列にある左右の時間がどちらも日時タイプの場合、それらは同じデータ タ
イプ(両方とも DATE、両方とも TIME または両方とも TIMESTAMP)である必要が
あります。
• 一方の時間のみが期間タイプならば、最初の列のもう一方の時間は期間の要素タ
イプと同じデータ タイプである必要があります。
• どちらの時間も期間タイプではない場合、2 番目の列にある左右それぞれの時間
は、その列に対応する最初の列と同じ日時データ タイプであるか、対応する日時
タイプの値に追加できるような精度を持つ日時フィールドのみを伴う間隔タイプ
でなければなりません。
例
例
次の例では、1 つの共通点 CURRENT_TIME を共有する 2 つの期間を比較します。
2 つの期間が 1 つの共通点を共有するときには、定義によって重ならないため、返
される結果は FALSE です。
SELECT 'OVERLAPS'
WHERE (CURRENT_TIME(0), INTERVAL '1' HOUR)
OVERLAPS (CURRENT_TIME(0), INTERVAL -'1' HOUR);
次の例は、前の例とほぼ同じです。ただし、引数は、1 秒ずつ重なるように調整さ
れました。結果は TRUE です。値「OVERLAPS」が返されます。
SELECT 'OVERLAPS'
WHERE (CURRENT_TIME(0), INTERVAL '1' HOUR)
OVERLAPS (CURRENT_TIME(0) + INTERVAL '1' SECOND,INTERVAL -'1' HOUR);
次の例では、datetime_expression, datetime_expression 形式の OVERLAPS を使用し
ています。2 つの DATE 期間が重なり合うので、結果は TRUE です。
SELECT 'OVERLAPS'
WHERE (DATE '2000-01-15',DATE '2002-12-15')
OVERLAPS (DATE '2001-06-15',DATE '2005-06-15');
1016
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
OVERLAPS
次の例は前の例と同じですが、row_subquery の形式になっています。
SELECT 'OVERLAPS'
WHERE (SELECT DATE '2000-01-15', DATE '2002-12-15')
OVERLAPS (SELECT DATE '2001-06-15', DATE '2005-06-15');
次の例にある NULL は、2 番目の datetime_expression の開始時刻が 2001-06-13
15:00:00 で、終了時刻が null であることを示しています。
SELECT 'OVERLAPS'
WHERE (TIMESTAMP '2001-06-12 10:00:00', TIMESTAMP '2001-06-15
08:00:00')
OVERLAPS (TIMESTAMP '2001-06-13 15:00:00', NULL);
2 番目の式の開始時刻は最初の式で定義される TIMESTAMP 間隔内にあるため、結
果は TRUE です。
period1 および period2 が PERIOD(DATE)列の employee テーブルに対して、次の問
合わせを実行したとします。
SELECT * FROM employee WHERE period2 OVERLAPS period1;
Ename
period1
period2
Adams
('2005-02-03', '2006-02-03')
('2005-02-03', '2006-02-03')
Mary
('2005-04-02', '2006-01-03')
('2005-02-03', '2006-02-03')
Jones
('2004-01-02', '2004-03-05')
('2004-03-05', '2004-10-07')
Randy
('2004-01-02', '2004-03-05')
('2004-03-07', '2004-10-07')
Simon
?
('2005-02-03', '2005-07-27')
結果は以下のようになります。
Ename
period1
period2
Adams
('2005-02-03', '2006-02-03')
('2005-02-03', '2006-02-03')
Mary
('2005-04-02', '2006-01-03')
('2005-02-03', '2006-02-03')
次の表と問合わせについて考慮します。
CREATE TABLE project
(id INTEGER,
analysis_phase PERIOD(DATE))
UNIQUE PRIMARY INDEX (id);
INSERT project (1, PERIOD(DATE'2010-06-21',DATE'2010-06-25'));
SELECT 'OVERLAPS'
FROM project
WHERE analysis_phase OVERLAPS
PERIOD(DATE'2010-06-24',NULL);
SQL 関数、演算子、式および述部
1017
第 23 章 期間関数および演算子
OVERLAPS
OVERLAP のオペランドの 1 つが、明示的に NULL を指定する期間式を持つ期間タイ
プであるため、SELECT 文はエラーを返します。
次の CREATE TABLE 文で作成された employee テーブルで、jobdur1 と jobdur2 が
派生 PERIOD 列であるとします。
CREATE TABLE employee (
eid INTEGER NOT NULL,
name VARCHAR(100) NOT NULL,
deptno INTEGER NOT NULL,
jobst1 DATE NOT NULL,
jobend1
DATE NOT NULL,
PERIOD FOR jobdur1(jobst1, jobend1),
jobst2 DATE NOT NULL,
jobend2
DATE NOT NULL,
PERIOD FOR jobdur2(jobst2, jobend2)
) PRIMARY INDEX(eid);
EID
Name
DeptNo
JobSt1
JobEnd1
JobSt2
JobEnd2
1
Tom
101
DATE'2001-01-01'
DATE'2004-01-01' DATE'2005-01-01' DATE'2006-01-01'
2
Rick
201
DATE'2005-01-01'
DATE'2006-01-01' DATE'2001-01-01' DATE'2004-01-01'
3
Joo
301
DATE'2005-01-01'
DATE'2006-01-01' DATE'2006-01-01' DATE'2007-01-01'
4
Tam
401
DATE'2001-01-01'
DATE'2006-01-01' DATE'2002-01-01' DATE'2004-01-01'
5
Pat
501
DATE'2005-01-01'
DATE'2007-01-01' DATE'2006-01-01' DATE'2008-01-01'
6
Jack
601
DATE'2005-01-01'
DATE'2007-01-01' DATE'2007-01-01' DATE'2008-01-01'
7
Yu
701
DATE'2005-01-01'
DATE'2007-01-01' DATE'2004-01-01' DATE'2005-01-01'
8
Tim
801
DATE'2005-01-01'
DATE'2007-01-01' DATE'2005-01-01' DATE'2007-01-01'
次の SQL 文では、OVERLAPS を employee テーブルの派生 PERIOD 列で使用してい
ます。
SELECT eid, name, jobst1, jobend1, jobst2, jobend2
FROM employee
WHERE jobdur1 OVERLAPS jobdur2;
結果は以下のようになります。
EID
Name
DeptNo
JobSt1
JobEnd1
4
Tam
401
DATE'2001-01-01'
DATE'2006-01-01' DATE'2002-01-01' DATE'2004-01-01'
5
Pat
501
DATE'2005-01-01'
DATE'2007-01-01' DATE'2006-01-01' DATE'2008-01-01'
8
Tim
801
DATE'2005-01-01'
DATE'2007-01-01' DATE'2005-01-01' DATE'2007-01-01'
1018
JobSt2
JobEnd2
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
OVERLAPS
例
次の例は、前の例とほぼ同じです。ただし、引数は、1 秒ずつ重なるように調整さ
れました。結果は TRUE です。値「OVERLAPS」が返されます。
SELECT 'OVERLAPS'
WHERE (CURRENT_TIME(0), INTERVAL '1' HOUR)
OVERLAPS (CURRENT_TIME(0) + INTERVAL '1' SECOND,INTERVAL -'1' HOUR);
例
次の例では、datetime_expression, datetime_expression 形式の OVERLAPS を使用し
ています。2 つの DATE 期間が重なり合うので、結果は TRUE です。
SELECT 'OVERLAPS'
WHERE (DATE '2000-01-15',DATE '2002-12-15')
OVERLAPS (DATE '2001-06-15',DATE '2005-06-15');
例
次の例は前の例と同じですが、row_subquery の形式になっています。
SELECT 'OVERLAPS'
WHERE (SELECT DATE '2000-01-15', DATE '2002-12-15')
OVERLAPS (SELECT DATE '2001-06-15', DATE '2005-06-15');
例
次の例にある NULL は、2 番目の datetime_expression の開始時刻が 2001-06-13
15:00:00 で、終了時刻が null であることを示しています。
SELECT 'OVERLAPS'
WHERE (TIMESTAMP '2001-06-12 10:00:00', TIMESTAMP '2001-06-15
08:00:00')
OVERLAPS (TIMESTAMP '2001-06-13 15:00:00', NULL);
2 番目の式の開始時刻は最初の式で定義される TIMESTAMP 間隔内にあるため、結
果は TRUE です。
例
period1 および period2 が PERIOD(DATE)列の employee テーブルに対して、次の問
合わせを実行したとします。
SELECT * FROM employee WHERE period2 OVERLAPS period1;
Ename
period1
period2
Adams
('2005-02-03', '2006-02-03')
('2005-02-03', '2006-02-03')
Mary
('2005-04-02', '2006-01-03')
('2005-02-03', '2006-02-03')
SQL 関数、演算子、式および述部
1019
第 23 章 期間関数および演算子
OVERLAPS
Ename
period1
period2
Jones
('2004-01-02', '2004-03-05')
('2004-03-05', '2004-10-07')
Randy
('2004-01-02', '2004-03-05')
('2004-03-07', '2004-10-07')
Simon
?
('2005-02-03', '2005-07-27')
結果は以下のようになります。
Ename
period1
period2
Adams
('2005-02-03', '2006-02-03')
('2005-02-03', '2006-02-03')
Mary
('2005-04-02', '2006-01-03')
('2005-02-03', '2006-02-03')
例
次の表と問合わせについて考慮します。
CREATE TABLE project
(id INTEGER,
analysis_phase PERIOD(DATE))
UNIQUE PRIMARY INDEX (id);
INSERT project (1, PERIOD(DATE'2010-06-21',DATE'2010-06-25'));
SELECT 'OVERLAPS'
FROM project
WHERE analysis_phase OVERLAPS
PERIOD(DATE'2010-06-24',NULL);
OVERLAP のオペランドの 1 つが、明示的に NULL を指定する期間式を持つ期間タイ
プであるため、SELECT 文はエラーを返します。
例
次の CREATE TABLE 文で作成された employee テーブルで、jobdur1 と jobdur2 が
派生 PERIOD 列であるとします。
CREATE TABLE employee (
eid INTEGER NOT NULL,
name VARCHAR(100) NOT NULL,
deptno INTEGER NOT NULL,
jobst1 DATE NOT NULL,
jobend1
DATE NOT NULL,
PERIOD FOR jobdur1(jobst1, jobend1),
jobst2 DATE NOT NULL,
jobend2
DATE NOT NULL,
PERIOD FOR jobdur2(jobst2, jobend2)
) PRIMARY INDEX(eid);
1020
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
OVERLAPS
EID Name DeptNo
JobSt1
JobEnd1
JobSt2
JobEnd2
1
Tom
101
DATE'2 DATE'2004001-01- 01-01'
01'
DATE'2005-0 DATE'2006-01-01'
1-01'
2
Rick
201
DATE'2 DATE'2006005-01- 01-01'
01'
DATE'2001-0 DATE'2004-01-01'
1-01'
3
Joo
301
DATE'2 DATE'2006005-01- 01-01'
01'
DATE'2006-0 DATE'2007-01-01'
1-01'
4
Tam
401
DATE'2 DATE'2006001-01- 01-01'
01'
DATE'2002-0 DATE'2004-01-01'
1-01'
5
Pat
501
DATE'2 DATE'2007005-01- 01-01'
01'
DATE'2006-0 DATE'2008-01-01'
1-01'
6
Jack
601
DATE'2 DATE'2007005-01- 01-01'
01'
DATE'2007-0 DATE'2008-01-01'
1-01'
7
Yu
701
DATE'2 DATE'2007005-01- 01-01'
01'
DATE'2004-0 DATE'2005-01-01'
1-01'
8
Tim
801
DATE'2 DATE'2007005-01- 01-01'
01'
DATE'2005-0 DATE'2007-01-01'
1-01'
次の SQL 文では、OVERLAPS を employee テーブルの派生 PERIOD 列で使用してい
ます。
SELECT eid, name, jobst1, jobend1, jobst2, jobend2
FROM employee
WHERE jobdur1 OVERLAPS jobdur2;
結果は以下のようになります。
EID
Name
DeptNo
JobSt1
4
Tam
401
DATE'2001- DATE'200601-01'
01-01'
SQL 関数、演算子、式および述部
JobEnd1
JobSt2
JobEnd2
DATE'2002-01- DATE'2004-0101'
01'
1021
第 23 章 期間関数および演算子
P_INTERSECT
EID
Name
DeptNo
JobSt1
JobEnd1
JobSt2
JobEnd2
5
Pat
501
DATE'2005- DATE'200701-01'
01-01'
DATE'2006-01- DATE'2008-0101'
01'
8
Tim
801
DATE'2005- DATE'200701-01'
01-01'
DATE'2005-01- DATE'2007-0101'
01'
P_INTERSECT
目的
期間式の間に重複部分がある場合に、それらに共通する期間式の部分を返します。
構文
period_expression
P_INTERSECT
period_expression
構文要素
period_expression
PERIOD データ型と評価される任意の式。
期間式は、他の式との比較が可能である必要があります。Period データ タイプへの
暗黙的なキャストはサポートされていません。
結果値
• 期間式に重複部分がない場合、結果は NULL になります。どちらかの期間式が
NULL の場合、結果は NULL になります。それ以外の場合の結果は、期間式の間
で比較できる Period データ型になります。
• 期間式の間で精度が異なる PERIOD(TIMESTAMP(n) [WITH TIME ZONE])または
PERIOD(TIME(n) [WITH TIME ZONE])データ型があると、結果は精度が高い方の
データ型の Period 値になります。どちらの期間式にもタイムゾーンがない場合、
結果の期間はタイムゾーンを持ちません。それ以外の場合には、結果の期間はタ
イムゾーンを持ち、結果のタイムゾーンの値は次に示すルールにより決定されま
す:
• 両方の期間式に 1 つのタイムゾーンがある場合、結果の境界に含まれるタイム
ゾーンの変移は、後述の Period 値コンストラクタで定義されているように、
期間式の一致する境界から取得されます。
• どちらか一方の期間式にのみタイムゾーンがある場合、もう一方の期間式は現
在のセッションのタイムゾーンにあるとみなされ、結果は次に示すように計算
されます。
1022
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
P_INTERSECT
例えば、p1 および p2 が期間式で、上述のとおりに決定された結果の構成要素のタ
イプが rt だとします。p1 OVERLAPS p2 が TRUE の場合、p1 P_INTERSECT p2 の
結果は次のようになります。
PERIOD(
CASE WHEN CAST(BEGIN(p1) AS rt) >= CAST(BEGIN(p2) AS rt)
THEN CAST(BEGIN(p1) AS rt)
ELSE CAST(BEGIN(p2) AS rt) END,
CASE WHEN CAST(END(p1) AS rt) <= CAST(END(p2) AS rt)
THEN CAST(END(p1) AS rt)
ELSE CAST(END(p2) AS rt) END)
内部的には、Period 値は UTC で保存されます。その後で、それらの値の UTC 表示
フォーマットを使用して OVERLAPS 演算子が評価され、重複があると P_INTERSECT
操作が実行されます。
フォーマットおよびタイトル
フォーマットは結果の Period データ タイプのデフォルト フォーマットです。
エラー条件
どちらか 一方でも期間式でない場合には、エラーがレポートされます。
期間式の間での比較ができないとエラーが報告されます。
例
例
ename
period1
period2
Adams
('2005-02-03 10:10:10.1',
'2007-02-03 10:10:10.1')
('2004-02-03 10:10:10',
'2006-02-03 10:10:10')
Paul
('2004-02-03 10:10:10.1',
'2006-02-03 10:10:10.1')
('2005-02-03 10:10:10',
'2007-02-03 10:10:10')
James
('2004-03-03 10:10:10.1',
'2006-01-03 10:10:10.1')
('2004-02-03 10:10:10',
'2006-02-03 10:10:10')
Mary
('2007-04-02 10:10:10.1',
'2008-01-03 10:10:10.1')
('2005-02-03 10:10:10',
'2006-02-03 10:10:10')
(period2 P_INTERSECT period1)
('2005-02-03 10:10:10.1', '2006-02-03 10:10:10.0')
SQL 関数、演算子、式および述部
1023
第 23 章 期間関数および演算子
P_INTERSECT
例
次に示す例では、選択リストで P_INTERSECT 演算子を使用しています。
SELECT period2 P_INTERSECT period1
FROM product_tests
WHERE pid = 11804;
次に示すテーブル product_tests に対して、上記の問合わせを実行するとします。こ
こでは、period1 が PERIOD(TIME(1))列、period2 が PERIOD(TIME(0))列だとしま
す。
pid
----11804
10996
period1
---------------------------('10:10:10.1', '11:10:10.1')
('11:10:10.1', '11:40:40.1')
period2
-----------------------('10:10:10', '10:10:11')
('10:10:10', '10:10:11')
結果は、以下のとおりです。
(period2 P_INTERSECT period1)
----------------------------('10:10:10.1', '10:10:11.0')
P_INTERSECT
目的
期間式の間に重複部分がある場合に、それらに共通する期間式の部分を返します。
構文
period_expression
P_INTERSECT
period_expression
構文要素
period_expression
PERIOD データ型と評価される任意の式。
期間式は、他の式との比較が可能である必要があります。Period データ タイプへの
暗黙的なキャストはサポートされていません。
結果値
• 期間式に重複部分がない場合、結果は NULL になります。どちらかの期間式が
NULL になる場合、結果は NULL となります。それ以外の場合の結果は、期間式
の間で比較できる Period データ型になります。
1024
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
P_INTERSECT
• 期間式の間で精度が異なる PERIOD(TIMESTAMP(n) [WITH TIME ZONE])または
PERIOD(TIME(n) [WITH TIME ZONE])データ型があると、結果は精度が高い方の
データ型の Period 値になります。どちらの期間式にもタイムゾーンがない場合、
結果の期間はタイムゾーンを持ちません。それ以外の場合には、結果の期間はタ
イムゾーンを持ち、結果のタイムゾーンの値は次に示すルールにより決定されま
す:
• 両方の期間式に 1 つのタイムゾーンがある場合、結果の境界に含まれるタイ
ムゾーンの変移は、後述の Period 値コンストラクタで定義されているように、
期間式の一致する境界から取得されます。
• どちらか一方の期間式にのみタイムゾーンがある場合、もう一方の期間式は
現在のセッションのタイムゾーンにあるとみなされ、結果は次に示すように
計算されます。
例えば、p1 および p2 が期間式で、上述のとおりに決定された結果の構成要素のタ
イプが rt だとします。p1 OVERLAPS p2 が TRUE の場合、p1 P_INTERSECT p2 の
結果は次のようになります。
PERIOD(
CASE WHEN CAST(BEGIN(p1) AS rt) >= CAST(BEGIN(p2) AS rt)
THEN CAST(BEGIN(p1) AS rt)
ELSE CAST(BEGIN(p2) AS rt) END,
CASE WHEN CAST(END(p1) AS rt) <= CAST(END(p2) AS rt)
THEN CAST(END(p1) AS rt)
ELSE CAST(END(p2) AS rt) END)
内部的には、Period 値は UTC で保存されます。その後で、それらの値の UTC 表示
フォーマットを使用して OVERLAPS 演算子が評価され、重複があると P_INTERSECT
操作が実行されます。
フォーマットおよびタイトル
フォーマットは結果の Period データ タイプのデフォルト フォーマットです。
エラー条件
どちらか 一方でも期間式でない場合には、エラーがレポートされます。
期間式の間での比較ができないとエラーが報告されます。
SQL 関数、演算子、式および述部
1025
第 23 章 期間関数および演算子
P_INTERSECT
例
例
ename
period1
period2
Adams
('2005-02-03 10:10:10.1',
'2007-02-03 10:10:10.1')
('2004-02-03 10:10:10',
'2006-02-03 10:10:10')
Paul
('2004-02-03 10:10:10.1',
'2006-02-03 10:10:10.1')
('2005-02-03 10:10:10',
'2007-02-03 10:10:10')
James
('2004-03-03 10:10:10.1',
'2006-01-03 10:10:10.1')
('2004-02-03 10:10:10',
'2006-02-03 10:10:10')
Mary
('2007-04-02 10:10:10.1',
'2008-01-03 10:10:10.1')
('2005-02-03 10:10:10',
'2006-02-03 10:10:10')
(period2 P_INTERSECT period1)
('2005-02-03 10:10:10.1', '2006-02-03 10:10:10.0')
例
次に示す例では、選択リストで P_INTERSECT 演算子を使用しています。
SELECT period2 P_INTERSECT period1
FROM product_tests
WHERE pid = 11804;
次に示すテーブル product_tests に対して、上記の問合わせを実行するとします。こ
こでは、period1 が PERIOD(TIME(1))列、period2 が PERIOD(TIME(0))列だとしま
す。
pid
----11804
10996
period1
---------------------------('10:10:10.1', '11:10:10.1')
('11:10:10.1', '11:40:40.1')
period2
-----------------------('10:10:10', '10:10:11')
('10:10:10', '10:10:11')
結果は、以下のとおりです。
(period2 P_INTERSECT period1)
----------------------------('10:10:10.1', '10:10:11.0')
1026
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
PRECEDES
PRECEDES
目的
2 つの期間式、派生 PERIOD、または日時式を TRUE、FALSE、または UNKNOWN
に評価します。
構文
period_expression
PRECEDES
period_expression
datetime_expression
NOT
derived_period
datetime_expression
PRECEDES
period_expression
NOT
derived_period
PRECEDES
NOT
derived_period
period_expression
構文要素
period_expression
PERIOD データ型と評価される任意の式。
期間式は、他の式との比較が可能である必要があります。Period データ タイプへの
暗黙的なキャストはサポートされていません。
datetime_expression
DATE、TIME、または TIMESTAMP 値と評価される式。
derived_period
PERIOD データ型と評価される任意の式。
結果値
• 両方の式に Period データ型または派生 PERIOD がある場合、第 1 の式の 終了境
界が第 2 の式の開始境界より小さいか等しい場合には TRUE を返し、それ以外の
場合は FALSE を返します。
• 第 1 の式が期間式で、第 2 の式が日時式の場合、第 1 の式の終了境界が第 2 の
式より小さいか等しい場合は TRUE を返し、それ以外の場合は FALSE を返します。
• 第 1 の式が日時値式で、第 2 の式が Period データ タイプの場合、第 1 の式が第
2 の式の開始境界より小さい場合は TRUE を返し、それ以外の場合は FALSE を返
します。
• どちらかの式が NULL の場合、演算子は UNKNOWN を返します。
SQL 関数、演算子、式および述部
1027
第 23 章 期間関数および演算子
PRECEDES
エラー条件
どちらかの式が Period データ タイプまたは日時値式以外の場合、エラーが報告され
ます。
期間式の間での比較ができないとエラーが報告されます。
例
例
period1 および period2 が PERIOD(DATE)列の employee テーブルに対して、次の問
合わせを実行したとします。
SELECT * FROM employee WHERE period1 PRECEDES period2;
ename
period1
period2
Adams
('2005-02-03',
'2006-02-03')
('2005-02-03',
'2006-02-03')
Mary
('2005-04-02',
'2006-01-03')
('2005-02-03',
'2006-02-03')
Jones
('2004-01-02',
'2004-03-05')
('2004-03-05',
'2004-10-07')
Randy
('2004-01-02',
'2004-03-05')
('2004-03-07',
'2004-10-07')
Simon
?
('2005-02-03',
'2005-07-27')
結果は以下のようになります。
ename
period1
Jones
('2004-01-02','2004-03-05') ('2004-03-05',
'2004-10-07')
Randy
('2004-01-02','2004-03-05') ('2004-03-07',
'2004-10-07')
period2
例
次の CREATE TABLE 文で作成された employee テーブルで、jobdur1 と jobdur2 が
派生 PERIOD 列であるとします。
CREATE TABLE employee (
eid INTEGER NOT NULL,
name VARCHAR(100) NOT NULL,
deptno INTEGER NOT NULL,
1028
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
PRECEDES
jobst1 DATE NOT NULL,
jobend1
DATE NOT NULL,
PERIOD FOR jobdur1(jobst1, jobend1),
jobst2 DATE NOT NULL,
jobend2
DATE NOT NULL,
PERIOD FOR jobdur2(jobst2, jobend2)
) PRIMARY INDEX(eid);
EID
Name
Dept
JobSt1
JobEnd1
JobSt2
JobEnd2
No
1
Tom
101
DATE'2001-0
1-01'
DATE'200401-01'
DATE'200501-01'
DATE'200601-01'
2
Rick
201
DATE'2005-0
1-01'
DATE'200601-01'
DATE'200101-01'
DATE'200401-01'
3
Joo
301
DATE'2005-0
1-01'
DATE'200601-01'
DATE'200601-01'
DATE'200701-01'
4
Tam
401
DATE'2001-0
1-01'
DATE'200601-01'
DATE'200201-01'
DATE'200401-01'
5
Pat
501
DATE'2005-0
1-01'
DATE'200701-01'
DATE'200601-01'
DATE'200801-01'
6
Jack
601
DATE'2005-0
1-01'
DATE'200701-01'
DATE'200701-01'
DATE'200801-01'
7
Yu
701
DATE'2005-0
1-01'
DATE'200701-01'
DATE'200401-01'
DATE'200501-01'
8
Tim
801
DATE'2005-0
1-01'
DATE'200701-01'
DATE'200501-01'
DATE'200701-01'
次の SQL 文では、PRECEDES を employee テーブルの派生 PERIOD 列で使用してい
ます。
SELECT eid, name, jobst1, jobend1, jobst2, jobend2
FROM employee
WHERE jobdur1 PRECEDES jobdur2;
結果は以下のようになります。
EID
Name
Dept
JobSt1
JobEnd1
JobSt2
JobEnd2
DATE'200101-01'
DATE'2004-0 DATE'2005- DATE'2006-01
1-01'
01-01'
-01'
No
1
Tom
SQL 関数、演算子、式および述部
101
1029
第 23 章 期間関数および演算子
PRIOR
EID
Name
Dept
JobSt1
JobEnd1
JobSt2
JobEnd2
No
3
Joo
301
DATE'200501-01'
DATE'2006-0 DATE'2006- DATE'2007-01
1-01'
01-01'
-01'
6
Jack
601
DATE'200501-01'
DATE'2007-0 DATE'2007- DATE'2008-01
1-01'
01-01'
-01'
PRIOR
目的
引数の 1 つ前の値(返される値と引数の差が、引数のタイプの最小単位 1 つ分)を返
します。
構文
PRIOR ( datetime_expression )
構文要素
datetime_expression
DATE、TIME、または TIMESTAMP 値と評価される式。
戻り値
結果のデータ タイプは、引数のデータ タイプと同じになります。引数の値が NULL
の場合、結果は NULL になります。
フォーマットおよびタイトル
フォーマットは、引数のデータ タイプのデフォルト フォーマットです。
制約事項
ビルトイン関数 DATE は PRIOR 関数に対する引数としてサポートされていません 。
たとえば、PRIOR(DATE)は無効です。代わりに、PRIOR(CURRENT_DATE)を使用す
る必要があります。
1030
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
LDIFF
エラー条件
引数に日時データ タイプがない場合は、エラーが報告されます。
結果が引数のデータ タイプに許容された範囲を超えると、エラーが報告されます。
例えば、PRIOR(DATE '0001-01-01')が指定されると、エラーがレポートされます。
例
period1 が PERIOD(DATE)列の employee テーブルに対して、次の問合わせを実行し
たとします。
SELECT *
FROM employee
WHERE PRIOR(END(period1)) = DATE '2004-03-04';
ename
dept
period1
-----------------------------------------Jones
Sales
('2004-01-02', '2004-03-05')
Simon
Sales
?
結果は以下のようになります。
ename
----Jones
dept
----------Sales
period1
---------------------------('2004-01-02', '2004-03-05')
LDIFF
目的
期間式が重複する場合に第 2 の期間式の開始前に存在する第 1 の期間式の部分を返
します。
期間式が重複しているが第 2 の期間式の開始前に第 1 の期間式の部分がない場合、
または期間式が重複していない場合、関数は NULL を返します。どちらかの期間式
が NULL の場合、LDIFF は NULL を返します。
構文
period_expression
LDIFF
period_expression
構文要素
period_expression
PERIOD データ型と評価される任意の式。
SQL 関数、演算子、式および述部
1031
第 23 章 期間関数および演算子
LDIFF
期間式は、他の式との比較が可能である必要があります。Period データ タイプへの
暗黙的なキャストはサポートされていません。
結果値
• 例えば、p1 および p2 が比較できる期間式と仮定します。p1 OVERLAPS p2 が
TRUE、BEGIN(p1)が BEGIN(p2)より小さい場合に p1 LIDFF p2 は
PERIOD(BEGIN(p1), BEGIN(p2))を返します。期間式が NULL、p1 OVERLAPS p2
が FALSE、または BEGIN(p1)が BEGIN(p2)より小さくない場合、結果は NULL に
なります。
• 期間式の間で精度が異なる PERIOD(TIME(n) [WITH TIME ZONE])または
PERIOD(TIMESTAMP(n) [WITH TIME ZONE])データ型があると、結果は精度が高
い方になります。期間式のいずれかにタイムゾーンが含まれ、もう 1 つの期間式
に含まれていない場合、結果には各要素のタイムゾーンが含まれています。結果
のタイムゾーンは、次に示すルールを使用して評価されます。
• 両方の期間式に 1 つのタイムゾーンがある場合、結果の境界に含まれるタイム
ゾーンの変位は、後述の Period 値コンストラクタで定義されているように、
式の一致する境界から取得されます。
• どちらか一方の期間式にのみタイムゾーンがある場合、もう一方の期間式は現
在のセッションのタイムゾーンにあるとみなされ、結果は次に示すように計算
されます。
例えば、p1 および p2 が期間 式で、上述のとおりに決定された結果の構成要素のタ
イプが rt だとします。p1 OVERLAPS p2 が TRUE の場合、p1 LDIFF p2 の結果は次
のようになります。
PERIOD(
CASE WHEN CAST(BEGIN(p1) AS rt) < CAST(BEGIN(p2) AS rt)
THEN CAST(BEGIN(p1) AS rt)
ELSE NULL END,
CASE WHEN CAST(BEGIN(p1) AS rt) < CAST(BEGIN(p2) AS rt)
THEN CAST(BEGIN(p2) AS rt)
ELSE NULL END)
内部的には、Period 値は UTC で保存されます。その後で、それらの値の UTC 表示
フォーマットを使用して OVERLAPS 演算子が評価され、重複があると LDIFF 操作が
実行されます。
フォーマットおよびタイトル
フォーマットは結果の Period データ タイプのデフォルト フォーマットです。
エラー条件
どちらかの式が期間式でないとエラーが報告されます。
1032
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
RDIFF
期間式の間での比較ができないとエラーが報告されます。
例
LDIFF は、第 1 の期間式と第 2 の期間式の左側の違いを検出するために使用されま
す。
SELECT ename, period2 LDIFF period1 FROM employee;
period1 および period2 が PERIOD(DATE)列の以下の employee テーブルに対して、
問合わせを実行したとします。
ename
----Adams
Mary
Jones
Randy
Simon
period1
---------------------------('2005-02-03', '2006-02-03')
('2005-04-02', '2006-01-03')
('2004-01-02', '2004-03-05')
('2006-01-02', '2007-03-05')
?
period2
---------------------------('2005-02-03', '2006-02-03')
('2005-02-03', '2006-02-03')
('2002-03-05', '2004-10-07')
('2004-03-07', '2005-10-07')
('2005-02-03', '2005-07-27')
結果は以下のようになります。
ename
----Adams
Mary
Jones
Randy
Simon
(period2 LDIFF period1)
---------------------------?
('2005-02-03', '2005-04-02')
('2002-03-05', '2004-01-02')
?
?
RDIFF
目的
期間式の間に重複があるときに、2 番目の期間式の終了より後に存在する 1 番目の
期間式の部分を返します。期間式の間に重複があっても 2 番目の期間式の終了より
後に 1 番目の期間式の部分がない場合や、期間式の間に重複がない場合、RDIFF は
NULL を返します。どちらかの期間式が NULL の場合、RDIFF は NULL を返します。
構文
period_expression
SQL 関数、演算子、式および述部
RDIFF
period_expression
1033
第 23 章 期間関数および演算子
RDIFF
構文要素
period_expression
PERIOD データ型と評価される任意の式。
期間式は、他の式との比較が可能である必要があります。Period データ タイプへの
暗黙的なキャストはサポートされていません。
結果値
• 例えば、p1 および p2 が比較できる期間式であると仮定します。p1 OVERLAPS
p2 が TRUE、END(p1)が END(p2)より大きい場合、p1 RDIFF p2 は
PERIOD(END(p2), END(p1))を返します。期間式が NULL、p1 OVERLAPS p2 が
FALSE または END(p1)が END(p2)より大きくない場合、結果は NULL となります。
• 期間式の間で精度が異なる PERIOD(TIME(n) [WITH TIME ZONE])または
PERIOD(TIMESTAMP(n) [WITH TIME ZONE])データ型があると、結果は精度が高
い方になります。期間式のいずれかにタイムゾーンが含まれ、もう 1 つの期間式
に含まれていない場合、結果には各要素のタイムゾーンが含まれています。結果
のタイムゾーンは、次に示すルールを使用して評価されます。
• 両方の期間式に 1 つのタイムゾーンがあると、結果の境界に含まれるタイム
ゾーンの変移は、後述の Period 値コンストラクタで定義されているように、
期間式の該当する境界から取得されます。
• どちらか一方の期間式にのみタイムゾーンがある場合、もう一方の期間式は現
在のセッションのタイムゾーンにあるとみなされ、結果は次に示すように計算
されます。
例えば、p1 および p2 が期間式で、上述のとおりに決定された結果の構成要素のタ
イプが rt だとします。p1 OVERLAPS p2 が TRUE の場合、p1 RDIFF p2 の結果は次
のようになります。
PERIOD(
CASE WHEN CAST(END(p1) AS rt) > CAST(END(p2) AS rt)
THEN CAST(END(p2) AS rt)
ELSE NULL END,
CASE WHEN CAST(END(p1) AS rt) > CAST(END(p2) AS rt)
THEN CAST(END(p1) AS rt)
ELSE NULL END)
内部的には、Period 値は UTC で保存されます。その後で、それらの値の UTC 表示
フォーマットを使用して OVERLAPS 演算子が評価され、重複があると RDIFF 操作が
実行されます。
フォーマットおよびタイトル
フォーマットは結果の Period データ タイプのデフォルト フォーマットです。
1034
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
SUCCEEDS
エラー条件
どちらかの式が期間式でないとエラーが報告されます。
期間式の間での比較ができないとエラーが報告されます。
例
RDIFF は、第 1 の期間式と第 2 の期間式の右側の違いを検出するために使用されま
す。
period1 および period2 が PERIOD(DATE)列の以下の employee テーブルに対して、
問合わせを実行したとします。
SELECT ename, period2 RDIFF period1 FROM employee;
ename
period1
period2
----------------------------------------------------------Adams
('2005-02-03', '2006-02-03')
('2005-02-03', '2006-02-03')
Mary
('2005-04-02', '2006-01-03')
('2005-02-03', '2006-02-03')
Jones
('2001-01-02', '2003-03-05')
('2002-03-05', '2004-10-07')
Randy
('2006-01-02', '2007-03-05')
('2004-03-07', '2005-10-07')
Simon
?
('2005-02-03', '2005-07-27')
結果は以下のようになります。
ename
----Adams
Mary
Jones
Randy
Simon
(period2 RDIFF period1)
---------------------------?
('2006-01-03', '2006-02-03')
('2003-03-05', '2004-10-07')
?
?
SUCCEEDS
目的
2 つの期間式、派生 PERIOD、または日時式を TRUE、FALSE、または UNKNOWN
に評価します。
SQL 関数、演算子、式および述部
1035
第 23 章 期間関数および演算子
SUCCEEDS
構文
period_expression
SUCCEEDS
period_expression
datetime_expression
NOT
derived_period
datetime_expression
SUCCEEDS
period_expression
NOT
derived_period
SUCCEEDS
NOT
derived_period
period_expression
構文要素
period_expression
PERIOD データ型と評価される任意の式。
期間式は、他の式との比較が可能である必要があります。Period データ タイプへの
暗黙的なキャストはサポートされていません。
datetime_expression
DATE、TIME、または TIMESTAMP 値と評価される式。
derived_period
PERIOD データ型と評価される任意の式。
結果値
• 両方の式に Period データ タイプまたは派生 PERIOD がある場合、第 1 の式の開
始境界が第 2 の式の終了境界より大きいか等しい場合には TRUE を返し、それ以
外の場合は FALSE を返します。
• 第 1 の式が期間式で、第 2 の式が日時式の場合、第 1 の式の開始境界が第 2 の式
より大きい場合は TRUE を返し、それ以外の場合は FALSE を返します。
• 第 1 の式が日時式で、第 2 の式が期間式の場合、日時式が第 2 の式の終了境界よ
り大きいか等しい場合は TRUE を返し、それ以外の場合は FALSE を返します。
• どちらかの式が NULL の場合、演算子は UNKNOWN を返します。
エラー条件
どちらかの式が Period データ タイプまたは日時値式以外の場合、エラーが報告され
ます。
式が比較可能なタイプでない場合、エラーが報告されます。
1036
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
SUCCEEDS
例
例
period1 および period2 が PERIOD(DATE)列の以下の employee テーブルに対して、
問合わせを実行したとします。
SELECT * FROM employee WHERE period2 SUCCEEDS period1;
ename
period1
period2
Adams
('2005-02-03',
'2006-02-03')
('2005-02-03',
'2006-02-03')
Mary
('2005-04-02',
'2006-01-03')
('2005-02-03',
'2006-02-03')
Jones
('2004-01-02',
'2004-03-05')
('2004-03-05',
'2004-10-07')
Randy
('2004-01-02',
'2004-03-05')
('2004-03-07',
'2004-10-07')
Simon
?
('2005-02-03',
'2005-07-27')
結果は以下のようになります。
ename
period1
Jones
('2004-01-02','2004-03-05') ('2004-03-05',
'2004-10-07')
Randy
('2004-01-02','2004-03-05') ('2004-03-07',
'2004-10-07')
period2
例
次の CREATE TABLE 文で作成された employee テーブルで、jobdur1 と jobdur2 が
派生 PERIOD 列であるとします。
CREATE TABLE employee (
eid INTEGER NOT NULL,
name VARCHAR(100) NOT NULL,
deptno INTEGER NOT NULL,
jobst1 DATE NOT NULL,
jobend1
DATE NOT NULL,
PERIOD FOR jobdur1(jobst1, jobend1),
jobst2 DATE NOT NULL,
jobend2
DATE NOT NULL,
PERIOD FOR jobdur2(jobst2, jobend2)
) PRIMARY INDEX(eid);
SQL 関数、演算子、式および述部
1037
第 23 章 期間関数および演算子
SUCCEEDS
EID
Name
Dept
JobSt1
JobEnd1
JobSt2
JobEnd2
No
1
Tom
101
DATE'2001- DATE'2004- DATE'200501-01'
01-01'
01-01'
DATE'2006-0
1-01'
2
Rick
201
DATE'2005- DATE'2006- DATE'200101-01'
01-01'
01-01'
DATE'2004-0
1-01'
3
Joo
301
DATE'2005- DATE'2006- DATE'200601-01'
01-01'
01-01'
DATE'2007-0
1-01'
4
Tam
401
DATE'2001- DATE'2006- DATE'200201-01'
01-01'
01-01'
DATE'2004-0
1-01'
5
Pat
501
DATE'2005- DATE'2007- DATE'200601-01'
01-01'
01-01'
DATE'2008-0
1-01'
6
Jack
601
DATE'2005- DATE'2007- DATE'200701-01'
01-01'
01-01'
DATE'2008-0
1-01'
7
Yu
701
DATE'2005- DATE'2007- DATE'200401-01'
01-01'
01-01'
DATE'2005-0
1-01'
8
Tim
801
DATE'2005- DATE'2007- DATE'200501-01'
01-01'
01-01'
DATE'2007-0
1-01'
次の SQL 文では、SUCCEEDS を employee テーブルの派生 PERIOD 列で使用してい
ます。
SELECT eid, name, jobst1, jobend1, jobst2, jobend2
FROM employee
WHERE jobdur1 SUCCEEDS jobdur2;
結果は以下のようになります。
EID
Name
Dept
JobSt1
JobEnd1
JobSt2
JobEnd2
No
1038
2
Rick
201
DATE'2005- DATE'200601-01'
01-01'
DATE'200101-01'
DATE'200401-01'
7
Yu
701
DATE'2005- DATE'200701-01'
01-01'
DATE'200401-01'
DATE'200501-01'
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
TD_NORMALIZE_OVERLAP
TD_NORMALIZE_OVERLAP
目的
すべての関与する行の Period 値から、最古の開始境界と最新の終了境界を含む行を
正規化して、Period 値が重複する行を結合します。
構文
TD_NORMALIZE_OVERLAP
(grouping_column_list, period_column)
TD_SYSFNLIB.
構文要素
grouping_column_list
PERIOD 列を含まない、1 つ以上のグループ化列。入力を動的 UDT として指定する
必要があります。
period_column
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
TD_SYSFNLIB
関数が格納されているデータベースの名前。
呼出し
TD_NORMALIZE_OVERLAP は埋め込みサービス システム関数です 。
使用上の注意
TD_NORMALIZE_OVERLAP は 2 つの引数を持つテーブル関数です。関数に渡され
る引数は、WITH 要求修飾子を使用することにより派生するサブテーブルの指定さ
れた列であり、以下のようになります。
• 第 1 引数は、PERIOD 列を含まない、1 つ以上のグループ化列です。この引数
は、各列が UDT の属性である、動的 UDT として指定する必要があります。詳細
については、「NEW VARIANT_TYPE」を参照してください。
• 第 2 引数は、重複する Period 値を見つける必要がある PERIOD 列です。
テーブル関数への入力は、以下のようにグループ化列でハッシュ再分散され、グルー
プ化列と Period 値別にソートされる列である必要があります。
• グループ化列と PERIOD 列が入力引数で指定されたものと同じ順序で含まれる、
LOCAL ORDER BY 句を指定する必要があります。整列順序は昇順である必要が
あります。
SQL 関数、演算子、式および述部
1039
第 23 章 期間関数および演算子
TD_NORMALIZE_OVERLAP
• HASH BY 句にグループ化列のうち少なくとも 1 つを含める必要があります。HASH
BY 句には PERIOD 列、またはグループ化列の一部ではない列を含めることはで
きません。
以下のように、出力列を指定する RETURNS 句で関数を呼び出す必要があります。
• 出力列が、PERIOD 列を含む、入力引数で指定されている列と同じになるように
指定する必要があります。
• 出力列を対応する入力列と同じデータ タイプで、同じ順序で指定する必要があり
ます。
• RETURNS 句の最後に任意の INTEGER 出力列を指定し、正規化された行数を含め
ることができます。
結果
この関数は、以下のように、RETURNS 句で指定した列を含む結果行を返します。
• 入力引数で指定されたグループ化列。
• 正規化された Period 値を含む PERIOD 列。
• Period 値が条件を満たすために正規化された行数を含む任意の INTEGER 列。
フォーマットおよびタイトル
フォーマットは、PERIOD 値式のエレメント タイプのデフォルト フォーマットです。
タイトルは(period_value_expression)です。
エラー条件
このテーブル関数は、以下の場合にエラーを返します。
• 関数の呼び出しには、グループ化列と PERIOD 列をすべて含む LOCAL ORDER BY
句は含まれません。
• この関数の呼び出しには、以下のグループ化列の 1 つ以上を含む HASH BY 句は
含まれません。
• HASH BY 句には PERIOD 列、またはグループ化列の一部ではない他の列が含まれ
ます。
• 関数が RETURNS 句なしで呼び出されました。または RETURNS 句で指定された
列が入力列に一致しない、または入力列と同じ順序ではありません。
例: TD_NORMALIZE_OVERLAP の使用
WITH subtbl(flight_id, duration) AS
(SELECT flight_id, duration FROM FlightExp)
SELECT *
FROM TABLE (TD_SYSFNLIB.TD_NORMALIZE_OVERLAP(NEW
VARIANT_TYPE(subtbl.flight_id),
1040
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
TD_NORMALIZE_MEET
subtbl.duration)
RETURNS (flight_id INT, duration PERIOD(TIMESTAMP(6) WITH TIME ZONE),
NrmCount INT)
HASH BY flight_id
/* input data is redistributed on column,
flight_id */
LOCAL ORDER BY flight_id, duration)
/* input data is sorted on
these columns */
AS DT(flight_id, duration, NrmCount) ORDER BY 1,2;
TD_NORMALIZE_MEET
目的
すべての関与する行の Period 値から、最古の開始境界と最新の終了境界を含む行を
正規化して、Period 値が一致する行を結合します。
構文
TD_NORMALIZE_MEET
(grouping_column_list, period_column)
TD_SYSFNLIB.
構文要素
grouping_column_list
PERIOD 列を含まない、1 つ以上のグループ化列。入力を動的 UDT として指定する
必要があります。
period_column
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
TD_SYSFNLIB
関数が格納されているデータベースの名前。
呼出し
TD_NORMALIZE_MEET は埋め込みサービス システム関数です 。
使用上の注意
TD_NORMALIZE_MEET は 2 つの引数を持つテーブル関数です。関数に渡される引
数は、WITH 要求修飾子を使用することにより派生するサブテーブルの指定された
列であり、以下のようになります。
SQL 関数、演算子、式および述部
1041
第 23 章 期間関数および演算子
TD_NORMALIZE_MEET
• 第 1 引数は、PERIOD 列を含まない、1 つ以上のグループ化列です。この引数は、
各列が UDT の属性である、動的 UDT として指定する必要があります。詳細につ
いては、「NEW VARIANT_TYPE」を参照してください。
• 第 2 引数は、条件を満たす Period 値を見つける必要がある PERIOD 列です。
テーブル関数への入力は、以下のようにグループ化列でハッシュ再分散され、グルー
プ化列と Period 値別にソートされる列である必要があります。
• グループ化列と PERIOD 列が入力引数で指定されたものと同じ順序で含まれる、
LOCAL ORDER BY 句を指定する必要があります。整列順序は昇順である必要があ
ります。
• HASH BY 句にグループ化列のうち少なくとも 1 つを含める必要があります。HASH
BY 句には PERIOD 列、またはグループ化列の一部ではない列を含めることはで
きません。
以下のように、出力列を指定する RETURNS 句で関数を呼び出す必要があります。
• 出力列が、PERIOD 列を含む、入力引数で指定されている列と同じになるように
指定する必要があります。
• 出力列を対応する入力列と同じデータ タイプで、同じ順序で指定する必要があり
ます。
• RETURNS 句の最後に任意の INTEGER 出力列を指定し、正規化された行数を含め
ることができます。
結果
この関数は、以下のように、RETURNS 句で指定した列を含む結果行を返します。
• 入力引数で指定されたグループ化列。
• 正規化された Period 値を含む PERIOD 列。
• Period 値が条件を満たすために正規化された行数を含む任意の INTEGER 列。
フォーマットおよびタイトル
フォーマットは、PERIOD 値式のエレメント タイプのデフォルト フォーマットです。
タイトルは BEGIN(period_value_expression)です。
エラー条件
このテーブル関数は、以下の場合にエラーを返します。
• 関数の呼び出しには、グループ化列と PERIOD 列をすべて含む LOCAL ORDER BY
句は含まれません。
• この関数の呼び出しには、以下のグループ化列の 1 つ以上を含む HASH BY 句は
含まれません。
• HASH BY 句には PERIOD 列、またはグループ化列の一部ではない他の列が含まれ
ます。
1042
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
TD_NORMALIZE_OVERLAP_MEET
• 関数が RETURNS 句なしで呼び出されました。または RETURNS 句で指定された
列が入力列に一致しない、または入力列と同じ順序ではありません。
例: TD_NORMALIZE_MEET の使用
WITH subtbl(flight_id, duration) AS
(SELECT flight_id, duration FROM FlightExp)
SELECT *
FROM TABLE (TD_SYSFNLIB.TD_NORMALIZE_MEET(NEW
VARIANT_TYPE(subtbl.flight_id),
subtbl.duration)
RETURNS (flight_id INT, duration PERIOD(TIMESTAMP(6) WITH TIME ZONE),
NrmCount INT)
HASH BY flight_id
/* input data is redistributed on column,
flight_id */
LOCAL ORDER BY flight_id, duration)
/* input data is sorted on
these columns */
AS DT(flight_id, duration, NrmCount) ORDER BY 1,2;
関連トピック
埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービス シ
ステム関数」を参照してください。
TD_NORMALIZE_OVERLAP_MEET
目的
すべての関与する行の Period 値から、最古の開始境界と最新の終了境界を含む行を
正規化して、Period 値が条件を満たすか重複する行を結合します。
構文
TD_NORMALIZE_MEET
(grouping_column_list, period_column)
TD_SYSFNLIB.
構文要素
grouping_column_list
PERIOD 列を含まない、1 つ以上のグループ化列。入力を動的 UDT として指定する
必要があります。
SQL 関数、演算子、式および述部
1043
第 23 章 期間関数および演算子
TD_NORMALIZE_OVERLAP_MEET
period_column
PERIOD データ型と評価される任意の式。
期間式は、他の式との比較が可能である必要があります。Period データ タイプへの
暗黙的なキャストはサポートされていません。
TD_SYSFNLIB
関数が格納されているデータベースの名前。
呼出し
TD_NORMALIZE_OVERLAP_MEET は埋め込みサービス システム関数です 。
使用上の注意
TD_NORMALIZE_OVERLAP_MEET は 2 つの引数を持つテーブル関数です。関数に
渡される引数は、WITH 要求修飾子を使用することにより派生するサブテーブルの
指定された列であり、以下のようになります。
• 第 1 引数は、PERIOD 列を含まない、1 つ以上のグループ化列です。この引数は、
各列が UDT の属性である、動的 UDT として指定する必要があります。詳細につ
いては、「NEW VARIANT_TYPE」を参照してください。
• 第 2 引数は、重複する、または条件を満たす Period 値を見つける PERIOD 列です。
テーブル関数への入力は、以下のようにグループ化列でハッシュ再分散され、グルー
プ化列と Period 値別にソートされる列である必要があります。
• グループ化列と PERIOD 列が入力引数で指定されたものと同じ順序で含まれる、
LOCAL ORDER BY 句を指定する必要があります。整列順序は昇順である必要があ
ります。
• HASH BY 句にグループ化列のうち少なくとも 1 つを含める必要があります。HASH
BY 句には PERIOD 列、またはグループ化列の一部ではない列を含めることはで
きません。
以下のように、出力列を指定する RETURNS 句で関数を呼び出す必要があります。
• 出力列が、PERIOD 列を含む、入力引数で指定されている列と同じになるように
指定する必要があります。
• 出力列を対応する入力列と同じデータ タイプで、同じ順序で指定する必要があり
ます。
• RETURNS 句の最後に任意の INTEGER 出力列を指定し、正規化された行数を含め
ることができます。
結果
この関数は、以下のように、RETURNS 句で指定した列を含む結果行を返します。
• 入力引数で指定されたグループ化列。
1044
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
TD_NORMALIZE_OVERLAP_MEET
• 正規化された Period 値を含む PERIOD 列。
• Period 値が条件を満たすために正規化された行数を含む任意の INTEGER 列。
フォーマットおよびタイトル
フォーマットは、PERIOD 値式のエレメント タイプのデフォルト フォーマットです。
タイトルは BEGIN(period_value_expression)です。
エラー条件
このテーブル関数は、以下の場合にエラーを返します。
• 関数の呼び出しには、グループ化列と PERIOD 列をすべて含む LOCAL ORDER BY
句は含まれません。
• この関数の呼び出しには、以下のグループ化列の 1 つ以上を含む HASH BY 句は
含まれません。
• HASH BY 句には PERIOD 列、またはグループ化列の一部ではない他の列が含ま
れます。
• 関数が RETURNS 句なしで呼び出されました。または RETURNS 句で指定された
列が入力列に一致しない、または入力列と同じ順序ではありません。
例: TD_NORMALIZE_OVERLAP_MEET の使用
WITH subtbl(flight_id, duration) AS
(SELECT flight_id, duration FROM FlightExp)
SELECT *
FROM TABLE (TD_SYSFNLIB.TD_NORMALIZE_OVERLAP_MEET(NEW
VARIANT_TYPE(subtbl.flight_id),
RETURNS (flight_id INT, duration PERIOD(TIMESTAMP(6) WITH TIME
ZONE), NrmCount
INT)
subtbl.duration)
HASH BY flight_id
/* input data is redistributed on column,
flight_id */
LOCAL ORDER BY flight_id, duration)
/* input data is sorted on
these columns */
AS DT(flight_id, duration, NrmCount) ORDER BY 1,2;
関連トピック
埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービス シ
ステム関数」を参照してください。
SQL 関数、演算子、式および述部
1045
第 23 章 期間関数および演算子
TD_SUM_NORMALIZE_OVERLAP
TD_SUM_NORMALIZE_OVERLAP
目的
Period 値が重複するため正規化された行すべてに対して、列の合計を算出します。
構文
構文要素
grouping_column_list
PERIOD 列を含まない、1 つ以上のグループ化列。入力を動的 UDT として指定する
必要があります。
numeric_column
SUM()が要求される数値列。入力を動的 UDT として指定する必要があります。
period_column
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
データ型が PERIOD(DATE)、PERIOD(TIMESTAMP)または PERIOD(TIMESTAMP
WITH TIME ZONE)の列。
呼出し
TD_SUM_NORMALIZE_OVERLAP は埋め込みサービス システム関数です 。
使用上の注意
TD_SUM_NORMALIZE_OVERLAP は 3 つの引数を持つテーブル関数です。関数に渡
される引数は、WITH 要求修飾子を使用することにより派生するサブテーブルの指
定された列であり、以下のようになります。
• 第 1 引数は、PERIOD 列を含まない、1 つ以上のグループ化列です。この引数は、
各列が UDT の属性である、動的 UDT として指定する必要があります。詳細は、
NEW VARIANT_TYPE を参照してください。
• 第 2 引数は、SUM()が要求される数値列です。すべての数値データ タイプがサ
ポートされます。この引数は、列が UDT の属性である動的 UDT として指定する
必要があります。
1046
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
TD_SUM_NORMALIZE_OVERLAP
• 第 3 引数は、重複する Period 値を見つける必要がある PERIOD 列です。
テーブル関数への入力は、以下のようにグループ化列でハッシュ再分散され、グルー
プ化列と Period 値別にソートされる列である必要があります。
• グループ化列と PERIOD 列が入力引数で指定されたものと同じ順序で含まれる、
LOCAL ORDER BY 句を指定する必要があります。整列順序は昇順である必要が
あります。
• HASH BY 句にグループ化列のうち少なくとも 1 つを含める必要があります。
HASH BY 句には PERIOD 列、またはグループ化列の一部ではない列を含めるこ
とはできません。
以下のように、出力列を指定する RETURNS 句で関数を呼び出す必要があります。
• 出力列が、PERIOD 列を含む、入力引数で指定されている列と同じになるように
指定する必要があります。
• 出力列を対応する入力列と同じデータ タイプで、同じ順序で指定する必要があ
ります。
• 合計結果値を含めるための数値出力列を含める必要があります。この列のデー
タ タイプは、対応する入力列と同じデータ タイプである必要があります。オー
バーフロー エラーの可能性を回避するために、CAST 関数を使用して、入力列の
データ タイプをより大きな数値データ タイプに変換することができます。
結果
この関数は、以下のように、RETURNS 句で指定した列を含む結果行を返します。
• 入力引数で指定されたグループ化列。
• 正規化された Period 値を含む PERIOD 列。
• Period 値が条件を満たすために正規化された行数を含む任意の INTEGER 列。
フォーマットおよびタイトル
フォーマットは、PERIOD 値式のエレメント タイプのデフォルト フォーマットです。
タイトルは BEGIN(period_value_expression)です。
エラー条件
このテーブル関数は、以下の場合にエラーを返します。
• 関数の呼び出しには、グループ化列と PERIOD 列をすべて含む LOCAL ORDER BY
句は含まれません。
• この関数の呼び出しには、以下のグループ化列の 1 つ以上を含む HASH BY 句は
含まれません。
• HASH BY 句には PERIOD 列、またはグループ化列の一部ではない他の列が含ま
れます。
• 関数が RETURNS 句なしで呼び出されました。または RETURNS 句で指定された
列が入力列に一致しない、または入力列と同じ順序ではありません。
SQL 関数、演算子、式および述部
1047
第 23 章 期間関数および演算子
TD_SUM_NORMALIZE_MEET
例: TD_SUM_NORMALIZE_OVERLAP の使用
WITH subtbl(flight_id, charges, duration) AS
(SELECT flight_id, charges, duration FROM FlightExp)
SELECT *
FROM TABLE (TD_SYSFNLIB.TD_SUM_NORMALIZE_OVERLAP(NEW
VARIANT_TYPE(subtbl.flight_id),
NEW VARIANT_TYPE(subtbl.charges),
subtbl.duration)
RETURNS (flight_id INT, cnt INT, charges FLOAT,
duration PERIOD(TIMESTAMP(6) WITH TIME ZONE))
HASH BY flight_id /* input data is redistributed on column, flight_id */
LOCAL ORDER BY flight_id, duration) /* input data is sorted on these
columns */
AS DT(flight_id, charges, duration) ORDER BY 1,3;
関連トピック
埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービス シ
ステム関数」を参照してください。
TD_SUM_NORMALIZE_MEET
目的
Period 値が条件を満たすため正規化された行すべてに対して、列の合計を算出します。
構文
構文要素
grouping_column_list
PERIOD 列を含まない、1 つ以上のグループ化列。入力を動的 UDT として指定する
必要があります。
numeric_column
SUM()が要求される数値列。入力を動的 UDT として指定する必要があります。
1048
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
TD_SUM_NORMALIZE_MEET
period_column
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
TD_SYSFNLIB
関数が格納されているデータベースの名前。
呼出し
TD_SUM_NORMALIZE_MEET は埋め込みサービス システム関数です 。
使用上の注意
TD_SUM_NORMALIZE_MEET は 3 つの引数を持つテーブル関数です。関数に渡され
る引数は、WITH 要求修飾子を使用することにより派生するサブテーブルの指定さ
れた列であり、以下のようになります。
• 第 1 引数は、PERIOD 列を含まない、1 つ以上のグループ化列です。この引数
は、各列が UDT の属性である、動的 UDT として指定する必要があります。詳細
は、NEW VARIANT_TYPE を参照してください。
• 第 2 引数は、SUM()が要求される数値列です。すべての数値データ タイプがサ
ポートされます。この引数は、列が UDT の属性である動的 UDT として指定する
必要があります。
• 第 3 引数は、条件を満たす Period 値を見つける必要がある PERIOD 列です。
テーブル関数への入力は、以下のようにグループ化列でハッシュ再分散され、グルー
プ化列と Period 値別にソートされる列である必要があります。
• グループ化列と PERIOD 列が入力引数で指定されたものと同じ順序で含まれる、
LOCAL ORDER BY 句を指定する必要があります。整列順序は昇順である必要が
あります。
• HASH BY 句にグループ化列のうち少なくとも 1 つを含める必要があります。
HASH BY 句には PERIOD 列、またはグループ化列の一部ではない列を含めるこ
とはできません。
以下のように、出力列を指定する RETURNS 句で関数を呼び出す必要があります。
• 出力列が、PERIOD 列を含む、入力引数で指定されている列と同じになるように
指定する必要があります。
• 出力列を対応する入力列と同じデータ タイプで、同じ順序で指定する必要があ
ります。
• 合計結果値を含めるための数値出力列を含める必要があります。この列のデー
タ タイプは、対応する入力列と同じデータ タイプである必要があります。オー
バーフロー エラーの可能性を回避するために、CAST 関数を使用して、入力列の
データ タイプをより大きな数値データ タイプに変換することができます。
SQL 関数、演算子、式および述部
1049
第 23 章 期間関数および演算子
TD_SUM_NORMALIZE_MEET
結果
この関数は、以下のように、RETURNS 句で指定した列を含む結果行を返します。
• 入力引数で指定されたグループ化列。
• 正規化された Period 値を含む PERIOD 列。
• Period 値が条件を満たすために正規化された行数を含む任意の INTEGER 列。
フォーマットおよびタイトル
フォーマットは、PERIOD 値式のエレメント タイプのデフォルト フォーマットです。
タイトルは BEGIN(period_value_expression)です。
エラー条件
このテーブル関数は、以下の場合にエラーを返します。
• 関数の呼び出しには、グループ化列と PERIOD 列をすべて含む LOCAL ORDER BY
句は含まれません。
• この関数の呼び出しには、以下のグループ化列の 1 つ以上を含む HASH BY 句は
含まれません。
• HASH BY 句には PERIOD 列、またはグループ化列の一部ではない他の列が含まれ
ます。
• 関数が RETURNS 句なしで呼び出されました。または RETURNS 句で指定された
列が入力列に一致しない、または入力列と同じ順序ではありません。
例: TD_SUM_NORMALIZE_MEET の使用
WITH subtbl(flight_id, charges, duration) AS
(SELECT flight_id, charges, duration FROM FlightExp)
SELECT *
FROM TABLE (TD_SYSFNLIB.TD_SUM_NORMALIZE_MEET(NEW
VARIANT_TYPE(subtbl.flight_id),
NEW
VARIANT_TYPE(subtbl.charges),
subtbl.duration)
RETURNS (flight_id INT, charges FLOAT,
duration PERIOD(TIMESTAMP(6) WITH TIME ZONE))
HASH BY flight_id
/* input data is redistributed on column,
flight_id */
LOCAL ORDER BY flight_id, duration)
/* input data is sorted on
these columns */
AS DT(flight_id, charges, duration) ORDER BY 1,3;
1050
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
TD_SUM_NORMALIZE_OVERLAP_MEET
関連トピック
埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービス シ
ステム関数「を参照してください。
TD_SUM_NORMALIZE_OVERLAP_MEET
目的
Period 値が条件を満たすか重複するため正規化された行すべてに対して、列の合計
を算出します。
構文
構文要素
grouping_column_list
PERIOD 列を含まない、1 つ以上のグループ化列。入力を動的 UDT として指定する
必要があります。
numeric_column
SUM()が要求される数値列。入力を動的 UDT として指定する必要があります。
period_column
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
呼出し
TD_SUM_NORMALIZE_OVERLAP_MEET は埋め込みサービス システム関数です 。
使用上の注意
TD_SUM_NORMALIZE_OVERLAP_MEET は 3 つの引数を持つテーブル関数です。関
数に渡される引数は、WITH 要求修飾子を使用することにより派生するサブテーブ
ルの指定された列であり、以下のようになります。
SQL 関数、演算子、式および述部
1051
第 23 章 期間関数および演算子
TD_SUM_NORMALIZE_OVERLAP_MEET
• 第 1 引数は、PERIOD 列を含まない、1 つ以上のグループ化列です。この引数は、
各列が UDT の属性である、動的 UDT として指定する必要があります。詳細につ
いては、「NEW VARIANT_TYPE」を参照してください。
• 第 2 引数は、SUM()が要求される数値列です。すべての数値データ タイプがサ
ポートされます。この引数は、列が UDT の属性である動的 UDT として指定する
必要があります。
• 第 3 引数は、重複する、または条件を満たす Period 値を検索する PERIOD 列です。
テーブル関数への入力は、以下のようにグループ化列でハッシュ再分散され、グルー
プ化列と Period 値別にソートされる列である必要があります。
• グループ化列と PERIOD 列が入力引数で指定されたものと同じ順序で含まれる、
LOCAL ORDER BY 句を指定する必要があります。整列順序は昇順である必要があ
ります。
• HASH BY 句にグループ化列のうち少なくとも 1 つを含める必要があります。HASH
BY 句には PERIOD 列、またはグループ化列の一部ではない列を含めることはで
きません。
以下のように、出力列を指定する RETURNS 句で関数を呼び出す必要があります。
• 出力列が、PERIOD 列を含む、入力引数で指定されている列と同じになるように
指定する必要があります。
• 出力列を対応する入力列と同じデータ タイプで、同じ順序で指定する必要があり
ます。
• 合計結果値を含めるための数値出力列を含める必要があります。この列のデー
タ タイプは、対応する入力列と同じデータ タイプである必要があります。オー
バーフロー エラーの可能性を回避するために、CAST 関数を使用して、入力列の
データ タイプをより大きな数値データ タイプに変換することができます。
結果
この関数は、以下のように、RETURNS 句で指定した列を含む結果行を返します。
• 入力引数で指定されたグループ化列。
• 正規化された Period 値を含む PERIOD 列。
• Period 値が条件を満たすために正規化された行数を含む任意の INTEGER 列。
例: TD_SUM_NORMALIZE_OVERLAP_MEET の使用
WITH subtbl(flight_id, charges, duration) AS
(SELECT flight_id, charges, duration FROM FlightExp)
SELECT * FROM TABLE (
TD_SYSFNLIB.TD_SUM_NORMALIZE_OVERLAP_MEET(NEW
VARIANT_TYPE(subtbl.flight_id),
NEW
VARIANT_TYPE(subtbl.charges),
subtbl.duration)
1052
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
TD_SEQUENCED_SUM
RETURNS (flight_id INT, charges FLOAT,
duration PERIOD(TIMESTAMP(6) WITH TIME ZONE))
HASH BY flight_id
/* input data is redistributed on column,
flight_id */
LOCAL ORDER BY flight_id, duration)
/* input data is sorted on
these columns */
AS DT(flight_id, charges, duration) ORDER BY 1,3;
関連トピック
埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービス シ
ステム関数」を参照してください。
TD_SEQUENCED_SUM
目的
Period 値が条件を満たすか重複する正規化された行のすべての隣接した期間に対し
て、列の合計を算出します。
構文
構文要素
grouping_column_list
PERIOD 列を含まない、1 つ以上のグループ化列。入力を動的 UDT として指定する
必要があります。
numeric_column
SUM()が要求される数値列。入力を動的 UDT として指定する必要があります。
period_column
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
SQL 関数、演算子、式および述部
1053
第 23 章 期間関数および演算子
TD_SEQUENCED_SUM
データ型が PERIOD(DATE)、PERIOD(TIMESTAMP)または PERIOD(TIMESTAMP
WITH TIME ZONE)の列。
TD_SYSFNLIB
関数が格納されているデータベースの名前。
呼出し
TD_SEQUENCED_SUM は埋め込みサービス システム関数です 。
使用上の注意
TD_SEQUENCED_SUM は 3 つの引数を持つテーブル関数です。関数に渡される引数
は、WITH 要求修飾子を使用することにより派生するサブテーブルの指定された列
であり、以下のようになります。
• 第 1 引数は、PERIOD 列を含まない、1 つ以上のグループ化列です。この引数は、
各列が UDT の属性である、動的 UDT として指定する必要があります。詳細につ
いては、「NEW VARIANT_TYPE」を参照してください。
• 第 2 引数は、SUM()が要求される数値列です。すべての数値データ タイプがサ
ポートされます。この引数は、列が UDT の属性である動的 UDT として指定する
必要があります。
• 第 3 引数は、重複する、または条件を満たす Period 値を検索する PERIOD 列です。
テーブル関数への入力は、以下のようにグループ化列でハッシュ再分散され、グルー
プ化列と Period 値別にソートされる列である必要があります。
• グループ化列と PERIOD 列が入力引数で指定されたものと同じ順序で含まれる、
LOCAL ORDER BY 句を指定する必要があります。整列順序は昇順である必要があ
ります。
• HASH BY 句にグループ化列のうち少なくとも 1 つを含める必要があります。HASH
BY 句には PERIOD 列、またはグループ化列の一部ではない列を含めることはで
きません。
以下のように、出力列を指定する RETURNS 句で関数を呼び出す必要があります。
• 出力列には、すべてのグループ化列を入力列と同じデータ タイプと順序で含める
必要があります。
• 合計結果値を含めるための数値出力列を含める必要があります。この列のデー
タ タイプは、対応する入力列と同じデータ タイプである必要があります。オー
バーフロー エラーの可能性を回避するために、CAST 関数を使用して、入力列の
データ タイプをより大きな数値データ タイプに変換することができます。
• 入力 PERIOD 列と同じ Period データ タイプの PERIOD 列。
結果
この関数は、以下のように、RETURNS 句で指定した列を含む結果行を返します。
1054
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
TD_SEQUENCED_SUM
• 入力引数で指定されたグループ化列。
• 正規化された Period 値を含む PERIOD 列。
• Period 値が条件を満たすために正規化された行数を含む任意の INTEGER 列。
フォーマットおよびタイトル
フォーマットは、PERIOD 値式のエレメント タイプのデフォルト フォーマットです。
タイトルは BEGIN(period_value_expression)です。
エラー条件
このテーブル関数は、以下の場合にエラーを返します。
• 関数の呼び出しには、グループ化列と PERIOD 列をすべて含む LOCAL ORDER BY
句は含まれません。
• この関数の呼び出しには、以下のグループ化列の 1 つ以上を含む HASH BY 句は
含まれません。
• HASH BY 句には PERIOD 列、またはグループ化列の一部ではない他の列が含ま
れます。
• 関数が RETURNS 句なしで呼び出されました。または RETURNS 句で指定された
列が入力列に一致しない、または入力列と同じ順序ではありません。
例: TD_SEQUENCED_SUM の使用
WITH subtbl(flight_id, charges, duration) AS
(SELECT flight_id, charges, duration FROM FlightExp)
SELECT * FROM TABLE (
TD_SYSFNLIB.TD_SEQUENCED_SUM(NEW VARIANT_TYPE(subtbl.flight_id),
NEW VARIANT_TYPE(subtbl.charges),
subtbl.duration)
RETURNS (flight_id INT, charges FLOAT,
duration PERIOD(TIMESTAMP(6) WITH TIME ZONE))
HASH BY flight_id
/* input data is redistributed on column,
flight_id */
LOCAL ORDER BY flight_id, duration)
/* input data is sorted on
these columns */
AS DT(flight_id, charges, duration) ORDER BY 1,3;
関連トピック
埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービス シ
ステム関数」を参照してください。
SQL 関数、演算子、式および述部
1055
第 23 章 期間関数および演算子
TD_SEQUENCED_AVG
TD_SEQUENCED_AVG
目的
Period 値が条件を満たすか重複する正規化された行のすべての隣接した期間に対し
て、列の平均を算出します。
構文
構文要素
grouping_column_list
PERIOD 列を含まない、1 つ以上のグループ化列。入力を動的 UDT として指定する
必要があります。
numeric_column
SUM()が要求される数値列。入力を動的 UDT として指定する必要があります。
period_column
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
TD_SYSFNLIB
関数が格納されているデータベースの名前。
呼出し
TD_SEQUENCED_AVG は埋め込みサービス システム関数です 。
使用上の注意
TD_SEQUENCED_AVG は 3 つの引数を持つテーブル関数です。関数に渡される引数
は、WITH 要求修飾子を使用することにより派生するサブテーブルの指定された列
であり、以下のようになります。
• 第 1 引数は、PERIOD 列を含まない、1 つ以上のグループ化列です。この引数は、
各列が UDT の属性である、動的 UDT として指定する必要があります。詳細につ
いては、「NEW VARIANT_TYPE」を参照してください。
• 第 2 引数は AVG()が要求される数値列です。すべての数値データ タイプがサポー
トされます。この引数は、列が UDT の属性である動的 UDT として指定する必要
があります。
• 第 3 引数は、重複する、または条件を満たす Period 値を検索する PERIOD 列です。
1056
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
TD_SEQUENCED_AVG
テーブル関数への入力は、以下のようにグループ化列でハッシュ再分散され、グルー
プ化列と Period 値別にソートされる列である必要があります。
• グループ化列と PERIOD 列が入力引数で指定されたものと同じ順序で含まれる、
LOCAL ORDER BY 句を指定する必要があります。整列順序は昇順である必要が
あります。
• HASH BY 句にグループ化列のうち少なくとも 1 つを含める必要があります。
HASH BY 句には PERIOD 列、またはグループ化列の一部ではない列を含めるこ
とはできません。
以下のように、出力列を指定する RETURNS 句で関数を呼び出す必要があります。
• 出力列には、すべてのグループ化列を入力列と同じデータ タイプと順序で含め
る必要があります。
• 数値の出力列を含めて、平均の結果値を格納する必要があります。この列のデー
タ タイプは、FLOAT または対応する入力列と同じデータ タイプにできますが、
結果値が丸められる可能性を回避するために、FLOAT を使用することをお勧め
します。オーバーフロー エラーの可能性を回避するために、CAST 関数を使用し
て、入力列のデータ タイプをより大きな数値データ タイプに変換することがで
きます。
• 入力 PERIOD 列と同じ Period データ タイプの PERIOD 列。
結果
この関数は、以下のように、RETURNS 句で指定した列を含む結果行を返します。
• 入力引数で指定されたグループ化列。
• 正規化された Period 値を含む PERIOD 列。
• Period 値が条件を満たすために正規化された行数を含む任意の INTEGER 列。
フォーマットおよびタイトル
フォーマットは、PERIOD 値式のエレメント タイプのデフォルト フォーマットです。
タイトルは BEGIN(period_value_expression)です。
エラー条件
このテーブル関数は、以下の場合にエラーを返します。
• 関数の呼び出しには、グループ化列と PERIOD 列をすべて含む LOCAL ORDER BY
句は含まれません。
• この関数の呼び出しには、以下のグループ化列の 1 つ以上を含む HASH BY 句は
含まれません。
• HASH BY 句には PERIOD 列、またはグループ化列の一部ではない他の列が含ま
れます。
• 関数が RETURNS 句なしで呼び出されました。または RETURNS 句で指定された
列が入力列に一致しない、または入力列と同じ順序ではありません。
SQL 関数、演算子、式および述部
1057
第 23 章 期間関数および演算子
TD_SEQUENCED_COUNT
例: TD_SEQUENCED_AVG の使用
WITH subtbl(flight_id, charges, duration) AS
(SELECT flight_id, charges, duration FROM FlightExp)
SELECT * FROM TABLE (
TD_SYSFNLIB.TD_SEQUENCED_AVG(NEW VARIANT_TYPE(subtbl.flight_id),
NEW VARIANT_TYPE(subtbl.charges),
subtbl.duration)
RETURNS (flight_id INT, charges FLOAT,
duration PERIOD(TIMESTAMP(6) WITH TIME ZONE))
HASH BY flight_id /* input data is redistributed on column, flight_id */
LOCAL ORDER BY flight_id, duration) /* input data is sorted on these
columns */
AS DT(flight_id, charges, duration) ORDER BY 1,3;
関連トピック
埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービス シ
ステム関数」を参照してください。
TD_SEQUENCED_COUNT
目的
Period 値が条件を満たすか重複する正規化された行のすべての隣接した期間に対し
て、列の数を算出します。
構文
構文要素
grouping_column_list
PERIOD 列を含まない、1 つ以上のグループ化列。入力を動的 UDT として指定する
必要があります。
period_column
結果が DATE 値、TIMESTAMP 値、または TIMESTAMP WITH TIME ZONE 値になる
式。
1058
SQL 関数、演算子、式および述部
第 23 章 期間関数および演算子
TD_SEQUENCED_COUNT
TD_SYSFNLIB
関数が格納されているデータベースの名前。
呼出し
TD_SEQUENCED_COUNT は埋め込みサービス システム関数です 。
使用上の注意
TD_SEQUENCED_COUNT は 2 つの引数を持つテーブル関数です。関数に渡される
引数は、WITH 要求修飾子を使用することにより派生するサブテーブルの指定され
た列であり、以下のようになります。
• 第 1 引数は、PERIOD 列を含まない、1 つ以上のグループ化列です。この引数
は、各列が UDT の属性である、動的 UDT として指定する必要があります。詳細
については、「NEW VARIANT_TYPE」を参照してください。
• 第 2 引数は、重複する、または条件を満たす Period 値を見つける PERIOD 列で
す。
テーブル関数への入力は、以下のようにグループ化列でハッシュ再分散され、グルー
プ化列と Period 値別にソートされる列である必要があります。
• グループ化列と PERIOD 列が入力引数で指定されたものと同じ順序で含まれる、
LOCAL ORDER BY 句を指定する必要があります。整列順序は昇順である必要が
あります。
• HASH BY 句にグループ化列のうち少なくとも 1 つを含める必要があります。
HASH BY 句には PERIOD 列、またはグループ化列の一部ではない列を含めるこ
とはできません。
以下のように、出力列を指定する RETURNS 句で関数を呼び出す必要があります。
• 出力列には、すべてのグループ化列を入力列と同じデータ タイプと順序で含め
る必要があります。
• INTEGER の出力列を含めて、カウントの結果を格納する必要があります。
• 入力 PERIOD 列と同じ Period データ タイプの PERIOD 列。
結果
この関数は、以下のように、RETURNS 句で指定した列を含む結果行を返します。
• 入力引数で指定されたグループ化列。
• 正規化された Period 値を含む PERIOD 列。
• Period 値が条件を満たすために正規化された行数を含む任意の INTEGER 列。
フォーマットおよびタイトル
フォーマットは、PERIOD 値式のエレメント タイプのデフォルト フォーマットです。
SQL 関数、演算子、式および述部
1059
第 23 章 期間関数および演算子
TD_SEQUENCED_COUNT
タイトルは(period_value_expression)です。
エラー条件
このテーブル関数は、以下の場合にエラーを返します。
• 関数の呼び出しには、グループ化列と PERIOD 列をすべて含む LOCAL ORDER BY
句は含まれません。
• この関数の呼び出しには、以下のグループ化列の 1 つ以上を含む HASH BY 句は
含まれません。
• HASH BY 句には PERIOD 列、またはグループ化列の一部ではない他の列が含まれ
ます。
• 関数が RETURNS 句なしで呼び出されました。または RETURNS 句で指定された
列が入力列に一致しない、または入力列と同じ順序ではありません。
例: TD_SEQUENCED_COUNT の使用
WITH subtbl(flight_id, duration) AS
(SELECT flight_id, duration FROM FlightExp)
SELECT * FROM TABLE (
TD_SYSFNLIB.TD_SEQUENCED_COUNT(NEW VARIANT_TYPE(subtbl.flight_id),
subtbl.duration)
RETURNS (flight_id INT, cnt INT,
duration PERIOD(TIMESTAMP(6) WITH TIME ZONE))
HASH BY flight_id /* input data is redistributed on column, flight_id */
LOCAL ORDER BY flight_id, duration) /* input
関連トピック
埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービス シ
ステム関数」を参照してください。
1060
SQL 関数、演算子、式および述部
第 24 章
正規表現の関数
概要
この章では、正規表現の関数について説明します。
REGEXP_SUBSTR
目的
regexp_string によって指定される正規表現と一致する副文字列を、source_string
から抽出します。
REGEXP_SUBSTR は 2 個、3 個、4 個または 5 個のパラメータをサポートします。
構文
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
source_string
文字の引数。
source_string が NULL の場合は NULL が返されます。
regexp_string
文字の引数。
regexp_string が NULL の場合は NULL が返されます。
SQL 関数、演算子、式および述部
1061
第 24 章 正規表現の関数
REGEXP_SUBSTR
position_arg
数値引数。
position_arg は source_string 内の、検索が開始される位置を指定します(デフォルト
は 1)。
position_arg が入力文字列より長い場合は NULL が返されます。
position_arg が NULL の場合、値 NULL が使用されます。position_arg が指定されて
いない場合は、デフォルト(1)が使用されます。
occurrence_arg
数値引数。
返される出現回数を指定します(デフォルトは 1)。例えば、occurrence_arg が 2 の
場合、関数は source_string 内の最初のオカレンスと一致し、次に source_string 内
の最初のオカレンスに続く文字から、source_string 内の 2 番目のオカレンスの検索
を開始します。
occurrence_arg が見つかった一致数より大きい場合は NULL が返されます。
occurrence_arg が NULL の場合は、NULL の結果が返されます。occurrence_arg を
省略すると、デフォルト値(1)が使用されます。
match_arg
文字の引数。
有効な値は、次のとおりです。
• 'i' =大文字と小文字を区別しない一致。
• 'c' =大文字と小文字を区別する一致。
• 'n' =ピリオド(任意の文字と一致)は改行文字と一致できます。
• 'm' = source_string は単一行ではなく、複数行として扱われます。このオプショ
ンを指定すると、'^'および'$'文字が source_string 全体ではなく、source_string
内の各行に適用されます。
• 'l' = source_string が source_string の現在の最大許可サイズ(現在は 16 MB)を超
えた場合に、エラーではなく NULL を返します。これは長時間実行する問合わせ
で、問合わせが失敗することになる長い文字列を使用したくない場合に役立ちま
す。
• 'x' = 空白を無視します。
引数は複数の文字を含みます。引数の文字が有効でない場合、文字は無視されます。
match_arg が未指定、または NULL、空の場合:
• 大文字と小文字を区別する一致。
• ピリオドは改行文字と一致しません。
• source_string は単一行として扱われます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
1062
SQL 関数、演算子、式および述部
第 24 章 正規表現の関数
REGEXP_SUBSTR
呼出し
REGEXP_SUBSTR は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡された式は、次のデータ タイプを持っている必要があります。
•
•
•
•
•
source_string = CHAR、VARCHAR、または CLOB
regexp_string = CHAR または VARCHAR
position_arg = NUMBER
occurrence_arg = NUMBER
match_arg = VARCHAR
source_string 最大サイズ:
• Latin の CHAR または VARCHAR であるパラメータの場合、ソースの最大サイズ
は 32000 バイトです。
• Unicode の CHAR または VARCHAR であるパラメータの場合、ソースの最大サイ
ズは 64000 バイトです。
• Latin または Unicode の CLOB であるパラメータの場合、ソースの最大サイズは
16MB です。
regexp_string 最大パターン文字列サイズ:
• パラメータが Latin の CHAR または VARCHAR の場合、最大 regexp_string サイ
ズは 32000 バイトです。
• パラメータが Unicode の CHAR または VARCHAR の場合、最大 regexp_string サ
イズは 32000 バイトです。
• パラメータが Latin の CLOB の場合、最大 regexp_string サイズは 30000 バイト
です。
• パラメータが Unicode の CLOB の場合、最大 regexp_string サイズは 30000 バ
イトです。
最大戻り文字列サイズ:
• Latin の CHAR または VARCHAR であるパラメータの場合、返される文字列の最
大サイズは 16000 バイトです。
• Unicode の CHAR または VARCHAR であるパラメータの場合、返される文字列の
最大サイズは 16000 バイトです。
• Latin または Unicode の CLOB であるパラメータの場合、返される文字列の最大
サイズは 16MB です。
このサイズを越えると、REGEXP_SUBSTR はエラーを返します(match_arg = 'l'が指
定されていない場合。指定されている場合は NULL を返します)。
x 一致オプションは空白を無視します。デフォルトでは、空白はそれ自体に一致し
ます。
SQL 関数、演算子、式および述部
1063
第 24 章 正規表現の関数
REGEXP_SUBSTR
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
結果のタイプ
REGEXP_SUBSTR は、関数に渡された source_string 入力パラメータに関連付けられ
たデータ型によって戻り値のデータ型が異なるスカラー関数です。
source_string が次の場合:
• CHAR および VARCHAR の場合は、source_string と同じ文字セットで VARCHAR
を返します。
• CLOB の場合は、source_string と同じ文字セットで CLOB を返します。
例
例
以下の問合わせを実行します。
SELECT REGEXP_SUBSTR('mint chocolate chip', 'ch(i|o)p', 1, 1, 'c');
'chip'を返します。
例
以下の問合わせを実行します。
SELECT REGEXP_SUBSTR('mint chocolate chip chop', ' ch(i|o)p', 1, 2,
'i');
これは一致の 2 番目のオカレンスなので、'chop'を返します。
関連トピック
詳細は、以下を参照してください。
• <SQL 外部ルーチン プログラミング、B035-1147>の「互換データ型」。
• 埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービ
ス システム関数 」を参照してください。
1064
SQL 関数、演算子、式および述部
第 24 章 正規表現の関数
REGEXP_REPLACE
REGEXP_REPLACE
目的
source_string の regexp_string に一致する部分を replace_string で置換します。
REGEXP_SUBSTR は 2 個、3 個、4 個、5 個または 6 個のパラメータをサポートし
ます。
構文
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
source_string
文字の引数。
source_string が NULL の場合は NULL が返されます。
regexp_string
文字の引数。
regexp_string が NULL の場合、元の文字列が返されます。
replace_string
文字の引数。
replace_string が指定されていないか、NULL または空の文字列の場合は、一致が結
果から削除されます。
replace_string の最大後方参照数は 9(\9 など)です。replace_string の 9 を超える後
方参照は、後方参照とみなされます。
position_arg
数値引数。
position_arg は source_string 内の、検索が開始される位置を指定します(デフォル
トは 1)。
position_arg が入力文字列より長い場合は、なにも置き換えられず、source_string
が返されます。
SQL 関数、演算子、式および述部
1065
第 24 章 正規表現の関数
REGEXP_REPLACE
position_arg が NULL の場合、NULL が使用されます。position_arg が指定されてい
ない場合は、デフォルト(1)が使用されます。
occurrence_arg
数値引数。
occurrence_arg は、オカレンスを指定して、一致が replace_string に置換されるよ
うにします。
• 値 0 を指定すると、すべての発生箇所が置き換えられます。
• 値が 1 を超えると、regexp_string の最初のオカレンスに続く最初の文字から、2
番目のオカレンスの検索が開始します。
occurrence_arg が見つかった一致数より大きい場合は、置換は実行されず、
source_string が返されます。
occurrence_arg が NULL の場合は、NULL の結果が返されます。occurrence_arg を
省略すると、デフォルト値(1)が使用されます。
match_arg
文字の引数。
有効な値は、次のとおりです。
• 'i' =大文字と小文字を区別しない一致。
• 'c' =大文字と小文字を区別する一致。
• 'n' =ピリオド(任意の文字と一致)は改行文字と一致できます。
• 'm' = source_string は単一行ではなく、複数行として扱われます。このオプショ
ンを指定すると、'^'および'$'文字が source_string 全体ではなく、source_string
内の各行に適用されます。
• 'l' = source_string が source_string の現在の最大許可サイズ(現在は 16 MB)を超
えた場合に、エラーではなく NULL を返します。これは長時間実行する問合わせ
で、問合わせが失敗することになる長い文字列を使用したくない場合に役立ちま
す。
• 'x' = 空白を無視します。
引数は複数の文字を含みます。引数の文字が有効でない場合、文字は無視されます。
match_arg が未指定、または NULL、空の場合:
• 大文字と小文字を区別する一致。
• ピリオドは改行文字と一致しません。
• source_string は単一行として扱われます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
REGEXP_REPLACE は埋め込みサービス システム関数です 。
1066
SQL 関数、演算子、式および述部
第 24 章 正規表現の関数
REGEXP_REPLACE
引数のタイプと規則
この関数に渡された式は、次のデータ タイプを持っている必要があります。
•
•
•
•
•
•
source_string = CHAR、VARCHAR、または CLOB
regexp_string = CHAR または VARCHAR
replace_string = CHAR、VARCHAR CLOB
position_arg = NUMBER
occurrence_arg = NUMBER
match_arg = VARCHAR
source_string 最大サイズ:
• Latin の CHAR または VARCHAR であるパラメータの場合、ソースの最大サイズ
は 32000 バイトです。
• Unicode の CHAR または VARCHAR であるパラメータの場合、ソースの最大サイ
ズは 64000 バイトです。
• Latin または Unicode の CLOB であるパラメータの場合、ソースの最大サイズは
16MB です。
regexp_string 最大パターン文字列サイズ:
• パラメータが Latin の CHAR または VARCHAR の場合、最大 regexp_string サイ
ズは 16000 バイトです。
• パラメータが Unicode の CHAR または VARCHAR の場合、最大 regexp_string サ
イズは 16000 バイトです。
• パラメータが Latin または Unicode の CLOB の場合、最大 regexp_string サイズ
は 30000 バイトです。
最大置換文字列サイズ:
• Latin の CHAR または VARCHAR であるパラメータの場合、置換文字列の最大サ
イズは 16000 バイトです。
• Unicode の CHAR または VARCHAR であるパラメータの場合、置換文字列の最大
サイズは 16000 バイトです。
• Latin または Unicode の CLOB であるパラメータの場合、置換文字列の最大サイ
ズは 30000 バイトです。
最大戻り文字列サイズ:
• Latin の CHAR または VARCHAR であるパラメータの場合、返される文字列の最
大サイズは 16000 バイトです。
• Unicode の CHAR または VARCHAR であるパラメータの場合、返される文字列の
最大サイズは 16000 バイトです。
• Latin または Unicode の CLOB であるパラメータの場合、返される文字列の最大
サイズは 16MB です。
このサイズを越えると、この関数はエラーを返します(match_arg = 'l'が指定されて
いない場合。指定されている場合は元の文字列を返します)。
position_arg を省略すると、デフォルト値(1)が使用されます。
SQL 関数、演算子、式および述部
1067
第 24 章 正規表現の関数
REGEXP_REPLACE
置換文字列の最大後方参照数は、9(例: \9)です。置換文字列の 9 を超える後方参照
は、後方参照とみなされません。
x 一致オプションは空白を無視します。デフォルトでは、空白はそれ自体に一致しま
す。
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
結果のタイプ
REGEXP_REPLACE は、関数に渡された source_string 入力パラメータに関連付けら
れたデータ型によって戻り値のデータ型が異なるスカラー関数です。
source_string が次の場合:
• CHAR および VARCHAR の場合は、source_string と同じ文字セットで VARCHAR
を返します。
• CLOB の場合は、source_string と同じ文字セットで CLOB を返します。
例
例
以下の問合わせを実行します。
SELECT REGEXP_REPLACE('Hello World World', '(world)$', 'My', 1, 1, 'i');
結果として"Hello World My"を返します。
例
以下の問合わせを実行します。
SELECT REGEXP_REPLACE('Friday is the best day of the week.', 'of the
week', 'EVER', 1, 1, 'c');
結果として'Friday is the best day EVER'を返します。
例
以下の問合わせを実行します。
SELECT REGEXP_REPLACE('Hello Santa says ho ho', 'ho', 'HO!', 1, 2, 'c');
結果として'Hello Santa says ho HO!'を返します。
1068
SQL 関数、演算子、式および述部
第 24 章 正規表現の関数
REGEXP_INSTR
関連トピック
詳細は、以下を参照してください。
• <SQL 外部ルーチン プログラミング、B035-1147>の「互換データ型」。
• 埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービ
ス システム関数 」を参照してください。
REGEXP_INSTR
目的
source_string から regexp_string との一致を検索します。
REGEXP_INSTR は 2 個、3 個、4 個、5 個または 6 個のパラメータをサポートしま
す。
構文
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
source_string
文字の引数。
source_string が NULL の場合は NULL が返されます。
regexp_string
文字の引数。
regexp_string が NULL の場合は NULL が返されます。
position_arg
数値引数。
position_arg は source_string 内の、検索が開始される位置を指定します(デフォル
トは 1)。
position_arg が入力文字列より長い場合はゼロが返されます。
SQL 関数、演算子、式および述部
1069
第 24 章 正規表現の関数
REGEXP_INSTR
position_arg が NULL の場合、NULL が使用されます。position_arg が指定されてい
ない場合は、デフォルト(1)が使用されます。
occurrence_arg
数値引数。
返されるオカレンスの数を指定します。例えば、occurrence_arg が 2 の場合、関数
は source_string 内の最初のオカレンスと一致し、次に source_string 内の最初のオ
カレンスに続く文字から、source_string 内の 2 番目のオカレンスの検索を開始しま
す。
occurrence_arg が一致の検出数より大きい場合はゼロが返されます。
occurrence_arg が NULL の場合は、NULL の結果が返されます。occurrence_arg を
省略すると、デフォルト値(1)が使用されます。
return_opt
数値引数。
有効な値は、次のとおりです。
• 0 =関数により、一致の開始位置が返されます(デフォルト)。
• 1 = 関数により、一致の終了位置(オカレンスの後ろの文字)が返されます。
この構文要素が NULL の場合、NULL が返されます。構文要素を省略した場合は、
デフォルト値(0)の値が使用されます。
match_arg
文字の引数。
有効な値は、次のとおりです。
• 'i' =大文字と小文字を区別しない一致。
• 'c' =大文字と小文字を区別する一致。
• 'n' =ピリオド(任意の文字と一致)は改行文字と一致できます。
• 'm' = source_string は単一行ではなく、複数行として扱われます。このオプショ
ンを指定すると、'^'および'$'文字が source_string 全体ではなく、source_string
内の各行に適用されます。
• 'l' = source_string が source_string の現在の最大許可サイズ(現在は 16 MB)を超
えた場合に、エラーではなく NULL を返します。これは長時間実行する問合わせ
で、問合わせが失敗することになる長い文字列を使用したくない場合に役立ちま
す。
• 'x' = 空白を無視します。
引数は複数の文字を含みます。引数の文字が有効でない場合、文字は無視されます。
match_arg が未指定、または NULL、空の場合:
• 大文字と小文字を区別する一致。
• ピリオドは改行文字と一致しません。
• source_string は単一行として扱われます。
match_arg が NULL の場合、NULL が使用されます。match_arg を省略すると、0 が
使用されます。
1070
SQL 関数、演算子、式および述部
第 24 章 正規表現の関数
REGEXP_INSTR
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
REGEXP_INSTR は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡された式は、次のデータ タイプを持っている必要があります。
•
•
•
•
•
•
source_string = CHAR、VARCHAR、または CLOB
regexp_string = CHAR または VARCHAR
position_arg = NUMBER
occurrence_arg = NUMBER
return_opt = NUMBER
match_arg = VARCHAR
source_string 最大サイズ:
• Latin の CHAR または VARCHAR であるパラメータの場合、ソースの最大サイズ
は 32000 バイトです。
• Unicode の CHAR または VARCHAR であるパラメータの場合、ソースの最大サイ
ズは 64000 バイトです。
• Latin または Unicode の CLOB であるパラメータの場合、ソースの最大サイズは
16MB です。
regexp_string 最大パターン文字列サイズ:
• パラメータが Latin の CHAR または VARCHAR の場合、最大 regexp_string サイ
ズは 32000 バイトです。
• パラメータが Unicode の CHAR または VARCHAR の場合、最大 regexp_string サ
イズは 32000 バイトです。
• パラメータが Latin の CLOB の場合、最大 regexp_string サイズは 30000 バイト
です。
• パラメータが Unicode の CLOB の場合、最大 regexp_string サイズは 60000 バ
イトです。
最大戻り文字列サイズ:
• Latin の CHAR または VARCHAR であるパラメータの場合、返される文字列の最
大サイズは 16000 バイトです。
• Unicode の CHAR または VARCHAR であるパラメータの場合、返される文字列の
最大サイズは 16000 バイトです。
• Latin または Unicode の CLOB であるパラメータの場合、返される文字列の最大
サイズは 16MB です。
SQL 関数、演算子、式および述部
1071
第 24 章 正規表現の関数
REGEXP_INSTR
このサイズを越える場合、match_arg = 'l'が指定されていない限り、この関数はエ
ラーを返します。これが指定されている場合は、エラーの代わりに NULL を返します。
x 一致オプションは空白を無視します。デフォルトでは、空白はそれ自体に一致しま
す。
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
結果のタイプ
REGEXP_INSTR はスカラー関数であり、戻りデータ タイプは次のようになります。
• source_string が CHAR または VARCHAR の場合は、INTEGER
• source_string が CLOB の場合は、BIGINT
例
例
以下の問合わせを実行します。
SELECT REGEXP_INSTR('Hello Santa says ho ho','Hello Santa says ho ho',
1, 1, 1, 'c');
これは、結果として 23 を返します。
例
以下の問合わせを実行します。
SELECT REGEXP_INSTR('Hello Santa says ho ho', 'Hello Santa says ho ho',
1, 1, 0, 'c');
これは、結果として 1 を返します。
関連トピック
詳細は、以下を参照してください。
• <SQL 外部ルーチン プログラミング、B035-1147>の「互換データ型」。
• 埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービ
ス システム関数 」を参照してください。
1072
SQL 関数、演算子、式および述部
第 24 章 正規表現の関数
REGEXP_SIMILAR
REGEXP_SIMILAR
目的
source_string を regexp_string と比較して、整数値を返します。
REGEXP_SIMILAR は 2 個または 3 個のパラメータをサポートします。
構文
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
source_string
文字の引数。
source_string が NULL の場合は NULL が返されます。
regexp_string
文字の引数。
regexp_string が NULL の場合は NULL が返されます。
match_arg
文字の引数。
有効な値は、次のとおりです。
• 'i' =大文字と小文字を区別しない一致。
• 'c' =大文字と小文字を区別する一致。
• 'n' =ピリオド(任意の文字と一致)は改行文字と一致できます。
• 'm' = source_string は単一行ではなく、複数行として扱われます。このオプショ
ンを指定すると、'^'および'$'文字が source_string 全体ではなく、source_string
内の各行に適用されます。
• 'l' = source_string が source_string の現在の最大許可サイズ(現在は 16 MB)を超
えた場合に、エラーではなく NULL を返します。これは長時間実行する問合わせ
で、問合わせが失敗することになる長い文字列を使用したくない場合に役立ちま
す。
• 'x' = 空白を無視します。
引数は複数の文字を含みます。引数の文字が有効でない場合、文字は無視されます。
match_arg が未指定、または NULL、空の場合:
• 大文字と小文字を区別する一致。
• ピリオドは改行文字と一致しません。
SQL 関数、演算子、式および述部
1073
第 24 章 正規表現の関数
REGEXP_SIMILAR
• source_string は単一行として扱われます。
match_arg が存在しないか、NULL または空の場合、デフォルトの('c')が使用されま
す。match_arg に無効な文字が含まれている場合にもデフォルトが使用されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
REGEXP_SIMILAR は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡された式は、次のデータ タイプを持っている必要があります。
• source_string = CHAR、VARCHAR、CLOB
• regexp_string = CHAR、VARCHAR
• match_arg = VARCHAR
source_string 最大サイズ:
• Latin の CHAR または VARCHAR であるパラメータの場合、ソースの最大サイズ
は 32000 バイトです。
• Unicode の CHAR または VARCHAR であるパラメータの場合、ソースの最大サイ
ズは 64000 バイトです。
• Latin または Unicode の CLOB であるパラメータの場合、ソースの最大サイズは
16MB です。
regexp_string 最大パターン文字列サイズ:
• パラメータが Latin の CHAR または VARCHAR の場合、最大 regexp_string サイ
ズは 32000 バイトです。
• パラメータが Unicode の CHAR または VARCHAR の場合、最大 regexp_string サ
イズは 32000 バイトです。
• パラメータが Latin の CLOB の場合、最大 regexp_string サイズは 30000 バイト
です。
• パラメータが Unicode の CLOB の場合、最大 regexp_string サイズは 60000 バイ
トです。
このサイズを越える場合、match_arg = 'l'が指定されていない限り、この関数はエ
ラーを返します。これが指定されている場合は、エラーの代わりに NULL を返します。
x 一致オプションは空白を無視します。デフォルトでは、空白はそれ自体に一致しま
す。
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
1074
SQL 関数、演算子、式および述部
第 24 章 正規表現の関数
REGEXP_SPLIT_TO_TABLE
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
結果のタイプ
REGEXP_SIMILAR はスカラー関数であり、戻りデータ タイプは整数値で、次のよ
うになります。
• 文字列全部が regexp_arg と一致する場合は 1 (真)。
• 文字列全部が regexp_arg と一致しない場合は 0 (偽)。
例
以下の問合わせを実行します。
SELECT name FROM customers WHERE REGEXP_SIMILAR(name, '(Mike B(i|y)rd)|
(Michael B(i|y)rd)', 'c') = 1;
次の名前と一致する名前を customers テーブルから返します。
•
•
•
•
'Mike Bird'
'Mike Byrd'
'Michael Bird'
'Michael Byrd'
一致は大文字と小文字を区別します。
関連トピック
詳細は、以下を参照してください。
• <SQL 外部ルーチン プログラミング、B035-1147>の「互換データ型」。
• 埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービ
ス システム関数 」を参照してください。
REGEXP_SPLIT_TO_TABLE
目的
regexp_string を区切り文字として使用し、source_string を文字列のテーブルに分
割します。
構文
SQL 関数、演算子、式および述部
1075
第 24 章 正規表現の関数
REGEXP_SPLIT_TO_TABLE
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
inkey
出力結果セットの source_string を一意に識別する数値または文字列の引数。
inkey が NULL の場合は、空の文字列が返されます。
source_string
文字の引数。
この構文要素が NULL の場合、0 行が返されます。source_string が空の文字列であ
る場合にもゼロ行が返されます。
regexp_string
文字の引数。
この構文要素が NULL の場合、元の source_string が返されます。
match_arg
文字の引数。
有効な値は、次のとおりです。
• 'i' =大文字と小文字を区別しない一致。
• 'c' =大文字と小文字を区別する一致。
• 'n' = ピリオド(任意の文字と一致)は改行文字と一致できます
• 'm' = source_string は単一行ではなく、複数行として扱われます。このオプショ
ンを指定すると、'^'および'$'文字が source_string 全体ではなく、source_string
内の各行に適用されます。
• 'l' = source_string が source_string の現在の最大許可サイズ(現在は 16MB)を超え
た場合に、エラーではなく NULL が返されます。これは長時間実行する問合わせ
で、問合わせが失敗することになる長い文字列を使用したくない場合に役立ちま
す。最大 source_string サイズは 16MB ですが、結果として生成されるトークン
は VARCHAR のみが可能で、最大戻りトークンサイズは 64000 バイトです。
match_arg が指定されていない場合はエラーが返されます。
一致がない場合は、元の source_string が返されます。
outkey
inkey の値。
token_ndx
入力文字列でのトークンの序数位置。
token
文字の引数。
1076
SQL 関数、演算子、式および述部
第 24 章 正規表現の関数
REGEXP_SPLIT_TO_TABLE
入力文字列から得た token は、instring と同じ文字セットになります。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
REGEXP_SPLIT_TO_TABLE は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡された式は、次のデータ タイプを持っている必要があります。
•
•
•
•
inkey = NUMERIC, VARCHAR
source_string = CHAR、VARCHAR、CLOB
regexp_str ing = CHAR, VARCHAR
match_arg = VARCHAR
このサイズを越える場合、または match_arg = 'l'が指定されている場合、この関数
はエラーを返します。
inkey が null の場合は空の文字列が返されます。
x 一致オプションは空白を無視します。デフォルトでは、空白はそれ自体に一致し
ます。
Teradata Database で OREPLACE 呼び出し中に定数が第 2、第 3 パラメータとして
渡されると、第 1 引数の文字型が Unicode として渡され、戻り値の型が VARCHAR
の oreplace_unicode()が Unicode 文字セットで呼び出されます。
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
結果のタイプ
結果の行タイプは以下のようになります。
• outkey = NUMERIC, VARCHAR
• token_ndx = INTEGER
• token = VARCHAR
SQL 関数、演算子、式および述部
1077
第 24 章 正規表現の関数
REGEXP_SPLIT_TO_TABLE
例
SELECT 文の例:
SELECT * from table(regexp_split_to_table
('phonemaker','Apple&Microsoft&Google','&','c')
returns (outkey varchar(30), token_ndx integer, token varchar(100))) as
t1;
次の行があるテーブルを返します。
outkey
token_ndx
------------------------------ ---------------p h o n e
m a k e r
1
p h o n e
m a k e r
2
p h o n e
m a k e r
3
token
----------------------A p p l e
M i c r o s o f t
G o o g l e
結果のタイプ
結果の行タイプは以下のようになります。
• outkey = NUMERIC, VARCHAR
• token_ndx = INTEGER
• token = VARCHAR
1078
SQL 関数、演算子、式および述部
第 25 章
集合演算子
概要
SQL 集合演算子は、各個別問合わせの結果を単一の結果セットに結合することに
よって、2 つ以上の問合わせ結果セットを操作します。
Teradata SQL 集合演算子
Teradata SQL は、次の算術演算子をサポートします。
集合演算子
関数
INTERSECT
個々の SELECT 文により生成された答えのうち共通する結果の行を戻し
ます。
MINUS /
EXCEPT
結果は、最初の SELECT で戻された行から 2 番目の SELECT で戻された
行を引いた行になります。
MINUS は EXCEPT と同じです。
UNION
2 つの SELECT 文の結果を組み合わせします。
集合演算子は問合わせ式の中で使用されます。問合わせ式とは、集合演算子
INTERSECT、MINUS/EXCEPT、UNION によって組み合わせた問合わせの集合を指
します。
query_term の構文
SELECT
statement
(query_expression )
SELECT 文
SELECT 文。
詳細は、< SQL データ操作言語、B035-1146>を参照してください。
query_expression
集合演算子、他の式、および ORDER BY 句を含むまたは含まない式。
SQL 関数、演算子、式および述部
1079
第 25 章 集合演算子
概要
query_factor の構文
query_factor
query_expression
query_factor
UNION
MINUS
ALL
( query_expression )
ordering
EXCEPT
INTERSECT
すべての答えに共通する結果の行を戻す集合演算子。
ALL
任意選択のキーワードであり、重複行が戻されることを許可します。
query_expression の構文
構文
query_factor
query_expression
query_factor
UNION
MINUS
ALL
( query_expression )
ordering
EXCEPT
ordering
,
ORDER BY
expression
ASC
DESC
NULLS FIRST
NULLS LAST
UNION、MINUS、EXCEPT
複数の問合わせまたは副問合わせをどのように組み合わせて、戻す必要のある結果
の行を決定するかを指定する集合演算子。
ALL
重複行を返すことを許可します。
ORDER BY
戻される結果の行を並べ替えるための ORDER BY 句。
expression
結果として戻される行の整列順序を決定するために、ORDER BY 句で使用される式。
ASC
結果が昇順で整列されます。
整列フィールドが文字列の場合、システムは現在のセッションの照合順序の定義に
従って、昇順で整列します。
デフォルトの順序は ASC です。
1080
SQL 関数、演算子、式および述部
第 25 章 集合演算子
集合演算子のルール
DESC
結果が降順で整列されます。
整列フィールドが文字列の場合、システムは現在のセッションの照合順序の定義に
従って、降順で整列します。
NULLS FIRST
NULL 結果が最初にリストされることを指定します。
NULLS LAST
NULL 結果が最後にリストされることを指定します。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠していますが、非 ANSI の Teradata Database 拡
張機能が含まれています。
関連トピック
詳細は、以下を参照してください。
• 詳細は、< SQL データ操作言語、B035-1146>を参照してください。
• 例については、「ALL オプションの使用による重複行の保存」を参照してくださ
い。
集合演算子のルール
重複行
デフォルトでは、重複行は戻されません。
重複行が戻されるようにするには、ALL オプションを指定します。
集合演算子をサポートする操作
集合演算子は、次のような演算の中で使用できます。
• 単純な問合わせ
• 派生テーブル
注: HASH BY 句または LOCAL ORDER BY 句は、集合演算子による派生テーブル
では使用できません。
• SUBQUERY
• INSERT … SELECT 句
SQL 関数、演算子、式および述部
1081
第 25 章 集合演算子
集合演算子のルール
• ビュー定義
集合演算子によって結合された複数の SELECT 文には、SELECT の通常の句オプショ
ンを含めることができます。ただし、WITH 句を除きます。
SELECT AND CONSUME 文
集合演算子は、SELECT AND CONSUME 文には作用しません。
ORDER BY 句のサポート
問合わせ式には、ORDER BY 指定を 1 つだけ、末尾に含めることができます。
集合演算に関与するデータ タイプに対する制限事項
以下の制限事項が、集合演算に関与する CLOB、BLOB、および UDT タイプに対して
適用されます。
データ タ 制約事項
イプ
BLOB
CLOB または BLOB タイプに集合演算子を使用することはできません。
CLOB
UDT
• 集合演算に複数の UDT が関与する場合、それらは同一型でなければなりま
せん。これは、Teradata Database が集合演算に関与する UDT に対して暗黙
型変換を行なわないためです。
この制限事項に対する対処策としては、CREATE CAST を使用して、UDT ど
うしの間でキャストを行なう CAST を定義してから、集合演算内で明示的に
CAST 関数を呼び出します。
• 集合演算に関与する UDT では、順序付けが定義されていなければなりません。
Teradata Database は、ソース タイプが LOB でない DISTINCT 型 UDT の順
序付け機能を生成します。STRUCTURED 型 UDT またはソース タイプが LOB
である DISTINCT 型 UDT の順序付け定義を作成するときや、システム生成の
順序付け機能を置き換えるときは、CREATE ORDERING を使用します。
CREATE CAST と CREATE ORDERING の詳細は、<SQL データ定義言語 - 構文規
則および例、B035-1144>を参照してください。
関連トピック
詳細は、以下を参照してください。
• 例については、「ALL オプションの使用による重複行の保存」を参照してくださ
い。
1082
SQL 関数、演算子、式および述部
第 25 章 集合演算子
集合演算子の優先順位
集合演算子の優先順位
集合演算子の処理の優先順位は、以下のとおりです。
1 INTERSECT
2 UNION および MINUS/EXCEPT
括弧によって別の順序が明示的に指定されていないかぎり、集合演算子は左から右
に評価されます。
例: SELECT 文
次の問合わせについて説明します。
SELECT statement_1
UNION
SELECT statement_2
EXCEPT
SELECT statement_3
INTERSECT
SELECT statement_4;
操作は、次の順序で行なわれます。
1. statement_3 と statement_4 の結果の論理積をとる。
2. statement_1 と statement_2 の結果の論理和をとる。
3. 論理和から、論理積の行を差し引く。
優先順位をカスタマイズするための括弧の使用
優先順位をオーバーライドするには、括弧を使用します。括弧内の操作が最初に実
行されます。
たとえば、次の形式を考えてみましょう。
( ( SELECT statement_1
UNION
SELECT statement_2 )
EXCEPT
( SELECT statement_3
UNION
SELECT statement_4 )
)
EXCEPT
SELECT statement_5
INTERSECT
SELECT statement_6;
SQL 関数、演算子、式および述部
1083
第 25 章 集合演算子
ALL オプションの使用による重複行の保存
上の例の操作上の優先順位を、以下のリストで説明します。
1 SELECT statement_1 と SELECT statement_2 の論理和をとる。
2 SELECT statement_3 と SELECT statement_4 の論理和をとる。
3 2 番目の UNION の結果を、最初の UNION の結果から差し引く。
4 SELECT statement_5 と SELECT statement_6 の論理積をとる。
5 UNION 操作の残りから、INTERSECT の結果を差し引く。
関連トピック
詳細は、以下を参照してください。
• 最初の SELECT 文の文字タイプの長さが、結果セットにどのように影響するかを
示す例については、「集合結果の属性」を参照してください。
• 最初の SELECT 文の数値データ型が、結果セットにどのように影響するかを示す
例については、「例: SELECT 文の順序がデータ型に与える影響」を参照してくだ
さい。
• 例については、「例: SELECT 文の順序がデータ型に及ぼす影響」を参照してくだ
さい。
• 詳細については、「query_expression の構文」を参照してください。
ALL オプションの使用による重複行の保存
ALL オプションを使用しないかぎり、最終結果から重複行が除外されます。ALL オ
プションは、それが適用される結果セットの重複する行を保存します。
例
次の問合わせは、以下を最後として含めて、各結果セットごとに重複行を戻します。
SELECT statement_1
UNION ALL
SELECT statement_2
MINUS ALL
SELECT statement_3
INTERSECT ALL
SELECT statement_4
1084
SQL 関数、演算子、式および述部
第 25 章 集合演算子
集合結果の属性
集合結果の属性
最初の SELECT 文に含まれていたデータ タイプ、標題、書式の句が、最終結果に現
われるデータ タイプ、標題、書式の情報を決定します。
問合わせの中の他のすべての SELECT 文の属性は無視されます。
例
例
SELECT level, param, 'GMKSA' (TITLE 'OWNER')
FROM gmksa
WHERE cycle = '03'
UNION
SELECT level, param, 'GMKSA CONTROL'
FROM gmksa_control
WHERE cycle = '03'
ORDER BY 1, 2;
この問合わせは、次の結果集合を戻します。
***QUERY COMPLETED. 5 ROWS FOUND. 3 COLUMNS RETURNED.
LEVEL PARAM OWNER
----- ----- ----00
A
GMKSA
00
T
GMKSA
85
X
GMKSA
SF
A
GMKSA
SF
T
GMKSA
最初の SELECT は CHAR(5)である GMKSA を指定しているので、そのデータ タイプ
は 2 番目の SELECT でも有効になります。結果として、最初の 5 文字が同じである
ため、GMKSA_CONTROL 登録項は除外されます。
この問合わせは ALL オプションを指定していないので、重複した行は除外されます。
例
次の問合わせでは、SELECT の順序が反対です。
SELECT level, param 'GMKSA CONTROL' (TITLE 'OWNER')
FROM gmksa_control
WHERE cycle = '03'
UNION
SELECT level, param, 'GMKSA'
FROM gmksa
SQL 関数、演算子、式および述部
1085
第 25 章 集合演算子
集合結果の属性
WHERE cycle = '03'
ORDER BY 1, 2;
この問合わせは、次の結果を戻します。
***QUERY COMPLETED.10 ROWS FOUND. 3 COLUMNS RETURNED.
LEVEL
PARAM
OWNER
--------------------00
A
GMKSA
00
A
GMKSA CONTROL
00
T
GMKSA
00
T
GMKSA CONTROL
85
X
GMKSA
85
X
GMKSA CONTROL
SF
A
GMKSA
SF
A
GMKSA CONTROL
SF
T
GMKSA
SF
T
GMKSA CONTROL
この場合、最初の SELECT が'GMKSA CONTROL'を指しているので、行は重複とはみ
なされず、結果集合に組み込まれます。
例
この例は、不完全な形式の問合わせの結果が切り捨てられる可能性を示しています。
SELECT level, param, 'GMKSA
' (TITLE 'OWNER')
FROM gmksa
WHERE cycle = '03'
UNION
SELECT level, param,'GMKSA CONTROL'
FROM gmksa_control
WHERE cycle = '03'
ORDER BY 1, 2;
この問合わせは、次の結果を戻します。
***QUERY COMPLETED.10 ROWS FOUND. 3 COLUMNS RETURNED.
LEVEL
PARAM
OWNER
-------------------00
A
GMKSA
00
A
GMKSA CONTRO
00
T
GMKSA
00
T
GMKSA CONTRO
85
X
GMKSA
85
X
GMKSA CONTRO
SF
A
GMKSA
SF
A
GMKSA CONTRO
1086
SQL 関数、演算子、式および述部
第 25 章 集合演算子
派生テーブルでの集合演算子
SF
SF
T
T
GMKSA
GMKSA CONTRO
この問合わせは、予想したとおりの行を戻しました。ただし、最初の SELECT での
名前の指定方法のために、切り捨てが行なわれています。
問合わせの文字セットを決定する方法の例
最初の SELECT 文に含まれる式の文字セットによって、問合わせ全体の文字セット
が決まります。次の例の場合、<char_expression_1> の文字セットが問合わせ全体
の文字セットとして使用されます。
SELECT <char_expression_1> FROM <table_1>
UNION
SELECT <char_expression_2> FROM <table_2>;
<char_expression_1>の文字セットに含まれていない文字が<char_expression_2> に
含まれている場合は、エラーになることがあります。
例えば、<char_expression_1> が CHARACTER SET LATIN であるのに、
<char_expression_2> が CHARACTER SET UNICODE である場合、
<char_expression_2> を UNICODE から LATIN にコード変換しようとすると、
<char_expression_2>にマルチバイト文字がある場合には、エラーになります。
派生テーブルでの集合演算子
派生テーブルは、次の例で示すように、集合演算子をサポートします。
例
SELECT x1
FROM table_1,
(SELECT x2
FROM table_2
UNION
SELECT x3
FROM table_3
) derived_table;
SELECT x1,y1
FROM table_1,
(SELECT *
FROM table_2) derived_table(column_1, column_2)
WHERE column_2 = 1 ;
SQL 関数、演算子、式および述部
1087
第 25 章 集合演算子
SUBQUERY での集合演算子
制約事項
HASH BY 句または LOCAL ORDER BY 句は、集合演算子による派生テーブルでは使
用できません。次の例はエラーを返します。
例
テーブル関数"add2int"は、入力として 2 つの整数値を取り、それら両方の値と合計
を返します。
CREATE TABLE t1 (a1 INTEGER, b1 INTEGER);
CREATE TABLE t2 (a2 INTEGER, b2 INTEGER);
REPLACE FUNCTION add2int
(a INTEGER,
b INTEGER)
RETURNS TABLE
(addend1 INTEGER,
addend2 INTEGER,
mysum INTEGER)
SPECIFIC add2int
LANGUAGE C
NO SQL
PARAMETER STYLE SQL
NOT DETERMINISTIC
CALLED ON NULL INPUT
EXTERNAL NAME 'CS!add3int!add2int.c';
/* Query Q1 */
WITH dt(a1, b1) AS
( SELECT a1, b1
FROM t1
UNION ALL
SELECT a2, b2
FROM t2
)
SELECT *
FROM TABLE (add2int(dt.a1, dt.b1)
HASH BY b1
LOCAL ORDER BY b1) tf;
SUBQUERY での集合演算子
集合演算子は副問合わせ内で使用することができます。次に、その正しい使い方の
例を示します。
1088
SQL 関数、演算子、式および述部
第 25 章 集合演算子
SUBQUERY での集合演算子
例
例
SELECT x1
FROM table_1
WHERE (x1,y1) IN
(SELECT * FROM table_2
UNION
SELECT * FROM table_3);
例
SELECT *
FROM table_1
WHERE table_1.x1 IN
(SELECT x2
FROM table_2
UNION
(SELECT x3
FROM table_3
UNION
SELECT x4
FROM table_4));
例
SELECT *
FROM table_1
WHERE x1 IN
(SELECT SUM(x2)
FROM table_2
UNION
SELECT x3
FROM table_3);
例
SELECT *
FROM table_1
WHERE x1 IN
(SELECT MAX(x2)
FROM table_2
UNION
SELECT MIN(x3)
FROM table_3);
SQL 関数、演算子、式および述部
1089
第 25 章 集合演算子
INSERT … SELECT 文での集合演算子
例
SELECT *
FROM table_1
WHERE X1 IN
(SELECT x2 FROM table_2
UNION
SELECT x3 FROM table_3
UNION
SELECT x4 FROM table_4);
例
SELECT x1
FROM table_1
WHERE x1 IN ANY
(SELECT x2 FROM table_2
INTERSECT
SELECT x3 FROM table_3
MINUS
SELECT x4 FROM table_4);
例
UPDATE table_1
SET x1=1
WHERE table_1.x1 IN
(SELECT x2
FROM table_2
UNION
SELECT x3
FROM table_3
UNION
SELECT x4
FROM table_4);
INSERT … SELECT 文での集合演算子
集合演算子は INSERT … SELECT 文で許可されています。次に、その正しい使い方
の例を示します。
1090
SQL 関数、演算子、式および述部
第 25 章 集合演算子
ビュー定義における集合演算子
例: 集合演算子を使った単純な INSERT … SELECT
INSERT table1 (x1,y1)
SELECT *
FROM table_2
UNION
SELECT x3,y3
FROM table_3;
例: 集合演算子を使用するビューからの INSERT … SELECT
REPLACE VIEW v AS
SELECT *
FROM table_1
UNION
SELECT *
FROM table_2;
INSERT table_3(x3,y3)
SELECT *
FROM v;
例: 集合演算子を使用する派生テーブルからの INSERT … SELECT
INSERT table_1
SELECT *
FROM
(SELECT x2,y2
FROM table_2
UNION
SELECT *
FROM table_3 DerivedTable
);
ビュー定義における集合演算子
集合演算子をビュー定義の中で使用することができます。
たとえば、次の REPLACE VIEW 文は、ビュー定義の中で UNION を使用しています。
REPLACE VIEW view_1 AS
SELECT x1,y1
FROM table_1
UNION
SQL 関数、演算子、式および述部
1091
第 25 章 集合演算子
ビュー定義における集合演算子
SELECT x2,y2
FROM table_2;
GROUP BY 句のサポート
GROUP BY は、集合演算子と共にビュー内で使用することができます。
制約事項
次の制限は、集合演算子を指定するビュー定義に適用されます。
• UPDATE、DELETE、および INSERT は、適切ではありません。次の例は、成功し
ません。
REPLACE VIEW V AS
SELECT X
FROM TABLE_1
UNION
SELECT Y FROM
TABLE_1;
UPDATE V
SET X=0;
この文のシーケンスを実行しようとすると、次のエラー メッセージが表示されま
す。
***Failure 3823 VIEW 'v' may not be used for Help Index/
Constraint/Statistics, Update, Delete or Insert.
• WITH CHECK OPTION は、適切ではありません。次の例は、成功しません。
REPLACE VIEW ERRV( c ) AS
SELECT *
FROM TABLE_1
UNION
SELECT *
FROM TABLE_2
WHERE TABLE_2.X=2 WITH CHECK OPTION;
この文を実行しようとすると、次のエラー メッセージが表示されます。
***Failure 3847 Illegal use of a WITH clause.
• 列レベルの権限は許可されません。次の例は、成功しません。
GRANT UPDATE ( c ) ON TABLE_VIEW TO USER_NAME;
この文を実行しようとすると、次のエラー メッセージが表示されます。
1092
SQL 関数、演算子、式および述部
第 25 章 集合演算子
ビュー定義における集合演算子
***Failure 3499: GRANT cannot be used on views with set operators.
• 集合演算子を使用するビュー定義では ORDER BY 句を指定できませんが、ビュー
で適用される SELECT 文では ORDER BY を使用できます。
例
例1
REPLACE VIEW v AS
SELECT x1
FROM TABLE_1
UNION
SELECT x2
FROM TABLE_2
UNION;
SELECT x3
FROM TABLE_3;
SELECT * FROM v;
例2
REPLACE VIEW view_2 AS
SELECT *
FROM view_1
UNION
SELECT *
FROM table_3
UNION
SELECT *
FROM table_4;
SELECT *
FROM view_2
ORDER BY 1,2;
例3
REPLACE VIEW v AS
SELECT x1
FROM table_1
WHERE x1 IN
(SELECT x2
FROM table_2
UNION
SELECT x3
SQL 関数、演算子、式および述部
1093
第 25 章 集合演算子
集合演算子によって結合された問合わせ
FROM table_3
);
SELECT * FROM v;
関連トピック
詳細は、以下を参照してください。
• ORDER BY を使用できるビューに適用される SELECT 文については、「GROUP BY
および ORDER BY 句」を参照してください。
• ビュー内で集合演算子と併用できる GROUP BY については、「GROUP BY および
ORDER BY 句」を参照してください。
集合演算子によって結合された問合わせ
集合演算子を含む SELECT 文には、他では適用されない一定の規則と制限が適用さ
れます。
SELECT 文内の式の数
すべての SELECT 文には、同じ数の式がなければなりません。
最初の SELECT 文に式が 3 つある場合、後続のすべての SELECT 文にも式が 3 つな
ければなりません。
存在しない式のためのプレースホルダーとして、SELECT 文の中で NULL の式を使用
することができます。
次の例では、2 番目の式が null です。
SELECT EmpNo, NULL (CHAR(5))
FROM Employee;
WITH 句
WITH 句は、集合演算子によって結合された SELECT 文に使用することはできません。
GROUP BY および ORDER BY 句
GROUP BY 句は、問合わせ式の個々の SELECT 文で使用できますが、その SELECT
文にだけ適用され、結果セットには適用されません。
ORDER BY 句は、問合わせ式の最後の SELECT 文にだけ使用することができ、結果
セットの順序を指定します。
1094
SQL 関数、演算子、式および述部
第 25 章 集合演算子
集合演算子によって結合された問合わせ
ORDER BY 句には、数値リテラルだけを含めることができます。
たとえば、結果セット内の最初の列で順序付けるには、ORDER BY 1 と指定します。
集合演算子を含むビュー定義では GROUP BY を使用できますが、ORDER BY は使用
できません。集合演算子と共にビュー定義に適用された SELECT 文では、GROUP BY
と ORDER BY を使用できます。ビュー定義の中でのこれらの演算子の正しい使い方
を、次の例に示します。
REPLACE VIEW v AS
SELECT x1,y1
FROM table1
UNION
SELECT x2,y2
FROM table2;
SELECT *
FROM v
ORDER BY 1;
SELECT SUM(x1), y1
FROM v
GROUP BY 2;
GROUP BY 演算子を UNION された SELECT にそれぞれ適用することもできます。
次の例は、その方法を示しています。
REPLACE VIEW v(column_1,column_2) AS
SELECT MIN(x1),y1
FROM table_1
GROUP BY 2
UNION ALL
SELECT MIN(x2),y2
FROM table_2
GROUP BY 2
UNION ALL
SELECT x3,y3 FROM table_3;
SELECT SUM(v.column_1) (NAMED sum_c1),column_2
GROUP BY 2
ORDER BY 2;
SELECT *
FROM table_1
WHERE (x1,y1) IN
(SELECT SUM(x2), y2
FROM table_2
SQL 関数、演算子、式および述部
1095
第 25 章 集合演算子
集合演算子によって結合された問合わせ
GROUP BY 2
UNION
SELECT SUM(x3), y3
FROM table_3
GROUP BY 2
);
SELECT 文内のテーブル名
同じテーブルを参照する SELECT 文の場合でも、データを参照するテーブルを各
SELECT 文ごとに指定しなければなりません。
データ タイプの互換性
各 SELECT 文の中の対応するフィールドのデータ型には互換性が必要です。たとえ
ば、最初の SELECT 文の最初のフィールドが文字のデータ型の場合、後続の各 SELECT
文の最初のフィールドも、文字のデータ型でなければなりません。
対応する数値型は同じである必要はありませんが、互換性がなければなりません。
たとえば、1 つの SELECT 文の中のフィールドを INTEGER として定義し、別の
SELECT 文の対応するフィールドを SMALLINT として定義できます。
最初の SELECT 文のデータ タイプによって、結果セットの対応する列のデータ タイ
プが決まります。
以下の表は、データ タイプの互換性の詳細をまとめたものです。
データ タイプ
詳細
文字
最初の SELECT 文の文字型では、結果セットの文字列の長さが決
定されます。そのため、最初の SELECT 文の文字型の長さが後続
の SELECT 文の対応する文字型の長さより短い場合に、結果セッ
トの文字列で切り捨てが行なわれることがあります。
最初の SELECT 文に含まれる式の文字セットによって、問合わせ
全体の文字セットが決まります。
数値
1096
最初の SELECT 文の数値タイプにより、結果セットの数値タイプ
のサイズが決定されます。後続の SELECT 文の対応するすべての
数値フィールドが、最初の SELECT 文の数値データ タイプに変換
されます。このため、最初の SELECT 文の数値タイプのサイズが
後続の SELECT 文の対応する数値タイプのサイズより小さい場合
は、数値のオーバーフロー エラーが発生することがあります。ま
た、後続の文によって返される値は、より小さいデータ タイプに
は適合しません。
SQL 関数、演算子、式および述部
第 25 章 集合演算子
INTERSECT 演算子
データ タイプ
詳細
TIME
TIMESTAMP
PERIOD(TIME)
PERIOD(TIMESTAMP)
最初の SELECT 文の TIME、TIMESTAMP、PERIOD(TIME)、およ
び PERIOD(TIMESTAMP)型により、結果セット内の対応する行の
精度が決定されます。後続の SELECT 文の対応するすべてのフィー
ルドが、最初の SELECT 文のデータ型に暗黙的に変換されます。
対応するフィールドにタイムゾーンがなく 、最初の SELECT 文の
データ型にタイムゾーンがある場合、タイムゾーンは、現在のセッ
ションのタイムゾーンの変位に設定されます。対応するフィール
ドの精度が最初の SELECT 文のデータ型の精度より低い場合は、
必要に応じて小数桁にゼロが追加されます。後続の SELECT 文の
対応するフィールドの精度が、最初の SELECT 文のデータ型の精
度より高い場合は、エラーが報告されます。
関連トピック
詳細は、以下を参照してください。
• 最初の SELECT 文の文字タイプの長さが、結果セットにどのように影響するかを
示す例については、「集合結果の属性」を参照してください。
• 最初の SELECT 文の数値データ型が、結果セットにどのように影響するかを示す
例については、「例 6: SELECT 文の順序がデータ型に与える影響」を参照してく
ださい。
• 最初の SELECT 文に含まれる式の文字セットによって、問合わせ全体の文字セッ
トが決まります。詳細については、「問合わせの文字セットを決定する方法の
例」を参照してください。
INTERSECT 演算子
目的
両方の問合わせの結果に共通する行だけを戻します。
構文
query_expression_1
INTERSECT
query_expression_2
ALL
構文要素
query_expression_1
query_expression_2 と INTERSECT される完全な SELECT 文を指定します。
詳細については、「query_factor の構文」を参照してください。
SQL 関数、演算子、式および述部
1097
第 25 章 集合演算子
INTERSECT 演算子
ALL
重複行を返すことを許可します。
query_expression_2
query_expression_1.と INTERSECT される完全な SELECT 文を指定します。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
INTERSECT の規則
INTERSECT の使用の際に、以下の規則が適用されます。
• 単純な問合わせで INTERSECT を使用する以外に、以下の操作において INTERSECT
を使用できます。
• 派生テーブル
HASH BY 句または LOCAL ORDER BY 句は、集合演算子による派生テーブルで
は使用できません。
• SUBQUERY
• INSERT … SELECT 文
• ビュー定義
• INTERSECT によって結合される各問合わせが実行されて、行の集合から成る 1 つ
の結果が作成されます。INTERSECT 演算では、各 SELECT 文の各テーブルに同数
の列が含まれなければなりません(正式には、同じ程度でなければなりません)。
また、それらの列のデータ タイプに互換性がなければなりません。
• 以下のものの中では INTERSECT を使用できません。
• SELECT AND CONSUME 文
• WITH RECURSIVE 句
• CREATE RECURSIVE VIEW 文
集合結果の属性
論理積における最初の SELECT 文に含まれていたデータ タイプ、標題、書式の句が、
最終結果に現われるデータ タイプ、標題、書式の情報を決定します。
問合わせの中の他のすべての SELECT 文の属性は無視されます。
NULL のデータ タイプ
論理積演算で明示的に NULL を指定した場合、そのデータ タイプは INTEGER にな
ります。UNION 演算子を使用するこの指針の例が、「5: UNION のデータ型に対す
る明示 NULL の影響」に示されています。
1098
SQL 関数、演算子、式および述部
第 25 章 集合演算子
MINUS/EXCEPT 演算子
一方、NULL として定義された列データは、値およびデータ タイプを持たず、スカ
ラー式内の他の NULL と同様に評価されます。
重複行の取り扱い
ALL オプションを使用しないかぎり、最終結果から重複行が除外されます。
ALL オプションを指定した場合、重複行は残されます。ALL オプションは、複文の
問合わせで使用される INTERSECT 演算子の数だけ、指定することができます。
例
たとえば、2 つのテーブルが次の行を含んでいるとします。
SPart テーブル
SLocation テーブル
SuppNo
PartNo
SuppNo
SuppLoc
100
P2
100
London
101
P1
101
London
102
P1
102
Toronto
103
P2
103
Tokyo
次に、PartNo が P1 である部品を供給する業者で、SuppLoc が London である業者
の SuppNo を選択するには、次の要求を使用します。
SELECT SuppNo FROM SLocation
WHERE SuppLoc = 'London'
INTERSECT
SELECT SuppNo FROM SPart
WHERE PartNo = 'P1';
この要求の結果は、次のとおりです。
SuppNo
-----101
MINUS/EXCEPT 演算子
目的
query_expression_1 には表示されるが、query_expression_2 には表示されない結果
行を返します。
SQL 関数、演算子、式および述部
1099
第 25 章 集合演算子
MINUS/EXCEPT 演算子
構文
query_expression_1
MINUS
EXCEPT
query_expression_2
ALL
構文要素
query_expression_1
query_expression_2 によって MINUS される結果テーブルをもつ完全な SELECT 文
を指定します。
ALL
重複行を返すことを許可します。
query_expression_2
query_expression_1 から MINUS する完全な SELECT 文を指定します。
ANSI への準拠
この文は、ANSI SQL:2011 に準拠していますが、非 ANSI の Teradata Database 拡張
機能が含まれています。
使用上の注意
単純な問合わせ以外では、以下の操作において MINUS または EXCEPT を使用するこ
とができます。
• 派生テーブル
注: HASH BY 句または LOCAL ORDER BY 句は、集合演算子による派生テーブル
では使用できません。
• SUBQUERY
• INSERT … SELECT 文
• ビュー定義
以下の操作の中では MINUS および EXCEPT を使用できません。
• SELECT AND CONSUME 文
• WITH RECURSIVE 句
• CREATE RECURSIVE VIEW 文
MINUS または EXCEPT によって結合される各問合わせが実行され、行の集合から成
る 1 つの結果が作成されます。MINUS または EXCEPT 演算では、各 SELECT 文の各
テーブルに同数の列が含まれなければなりません(正式には、同じ程度でなければな
りません)。また、それらの列のデータ タイプに互換性がなければなりません。これ
で、すべての結果セットが単一の結果セットに結合されます。また、その組み合わ
1100
SQL 関数、演算子、式および述部
第 25 章 集合演算子
UNION 演算子
せされた結果セットは、MINUS または EXCEPT 演算の中の最初の SELECT 文に指定
された列のデータ型を持ちます。
MINUS/EXCEPT と NULL
EXCEPT 演算で明示的に NULL を指定した場合、そのデータ タイプは INTEGER に
なります。UNION 演算子を使用するこの指針の例が、「5: UNION のデータ型に対
する明示 NULL の影響」に示されています。
一方、NULL として定義された列データは、値およびデータ タイプを持たず、スカ
ラー式内の他の NULL と同様に評価されます。
重複行
ALL オプションを使用しないかぎり、最終結果から重複行が除外されます。
ALL オプションを指定した場合、重複行は残されます。ALL オプションは、複文の
問合わせで使用される MINUS 演算子の数だけ、指定することができます。
UNION 演算子
目的
2 つ以上の SELECT 結果のテーブルを、単一の結果に組み合わせします。
構文
query_expression_1
UNION
query_expression_2
ALL
構文要素
query_expression_1
query_expression_2 によって MINUS される結果テーブルをもつ完全な SELECT 文
を指定します。
詳細については、「query_expression の構文」を参照してください。
ALL
重複行は保存されます。
query_expression_2
query_expression_1 から MINUS する完全な SELECT 文を指定します。
SQL 関数、演算子、式および述部
1101
第 25 章 集合演算子
UNION 演算子
ANSI への準拠
この文は、ANSI SQL:2011 に準拠しています。
有効な UNION 演算
単純な問合わせ以外では、次の操作において UNION を使用することができます。
• 派生テーブル
注: HASH BY 句または LOCAL ORDER BY 句は、集合演算子による派生テーブル
では使用できません。
• SUBQUERY
• INSERT … SELECT 文
• 非再帰の CREATE VIEW 文
再帰的問合わせを定義する WITH RECURSIVE 句または CREATE RECURSIVE VIEW
文の中で有効な集合演算子は、UNION ALL のみです。
サポートされない演算子
以下のものの中では UNION を使用できません。
• SELECT AND CONSUME 文
• WITH RECURSIVE 句(ALL オプションが指定されていない場合)
• CREATE RECURSIVE VIEW 文(ALL オプションが指定されていない場合)
UNION 演算の説明
UNION によって結合されている各問合わせが実行されて、行の集合から成る 1 つの
結果が作成されます。UNION 演算では、各 SELECT 文の各テーブルに同数の列が含
まれていなければなりません(正式には、同じ程度でなければなりません)。また、そ
れらの列のデータ タイプに互換性がなければなりません。これで、すべての結果セッ
トが単一の結果セットに組み合わせされます。結合後の結果セットのデータ型は、
UNION 中の最初の SELECT 文に指定された列のデータ型になります。
UNION と NULL
UNION 演算で明示的に NULL を指定した場合、そのデータ タイプは INTEGER にな
ります。例については、「例 5: UNION のデータ型に対する明示 NULL の影響」を
参照してください。
一方、NULL として定義された列データは、値およびデータ タイプを持たず、スカ
ラー式内の他の NULL と同様に評価されます。
1102
SQL 関数、演算子、式および述部
第 25 章 集合演算子
UNION 演算子
重複行
ALL オプションを使用しないかぎり、重複行は、各結果セットと最終結果セットか
ら除外されます。
ALL オプションを使用した場合には、適用された結果セットに重複行が残されます。
ALL オプションを問合わせ内の各 UNION 演算子に指定すれば、最終結果にすべて
の重複行を残すことができます。
予期しない行の長さのエラーの理由: UNION での行の整列
Teradata Database では、UNION 演算で重複を検査するために整列操作を実行する
前に、整列キーが作成され、整列する行に付加されます。この一時データ構造の長
さがシステム制限の 64 KB バイトを超えると操作は失敗し、要求元にエラーが戻さ
れます。表示されるメッセージは、状況に応じて以下のいずれかとなります。
• A data row is too long(データ行が長すぎます)。
• Maximum row length exceeded in database_object_name
(database_object_name において行の最大長を超えました)。
これらのメッセージについては、<メッセージ、B035-1096>を参照してください。
例
例1
プロジェクト OE1-0001 に割り当てられた従業員の名前と、そのプロジェクト名、
それに費やされた時間数、プロジェクトに割り当てられていない従業員の名前を選
択するには、次の問合わせを使用します。
SELECT Name, Proj_Id, Hours
FROM Employee,Charges
WHERE Employee.Empno = Charges.Empno
AND Proj_Id IN ('OE1-0001')
UNION
SELECT Name, NULL (CHAR (8)), NULL (DECIMAL (4,2))
FROM Employee
WHERE Empno NOT IN
(SELECT Empno
FROM Charges);
この問合わせは、次の行を戻します。
Name
Project Id
Hours
Aguilar J
?
?
Brandle B
?
?
SQL 関数、演算子、式および述部
1103
第 25 章 集合演算子
UNION 演算子
Name
Project Id
Hours
Chin M
?
Clements D
?
?
Marston A
?
?
Phan A
?
?
Regan R
?
?
Russell S
?
?
Inglis C
0E1-0001
30.0
Inglis C
0E1-001
30.5
Leidner P
0E1-001
10.5
Leidner P
0E1-001
23.0
Moffit H
0E1-001
12.0
Moffit H
0E1-001
35.5
Kemper R
Smith T
Watson L
この例では、2 番目の SELECT 文の列 2 と列 3 で、null の式が使用されています。
この null の式は位置のマーカーとして使用されているので、この問合わせの両方の
SELECT 文が同じ数の式を持つことになります。
例2
部門番号 500 と 600 のすべての従業員の部門番号と名前を知るには、UNION 演算
子を次のように使用します。
SELECT DeptNo,
FROM Employee
WHERE DeptNo =
UNION
SELECT DeptNo,
FROM Employee
WHERE DeptNo =
Name
500
Name
600 ;
この問合わせは、次の行を戻します。
1104
DeptNo
Name
500
Carter J
SQL 関数、演算子、式および述部
第 25 章 集合演算子
UNION 演算子
DeptNo
Name
500
Inglis C
500
Marston A
500
Omura H
500
Reed C
500
Smith T
500
Watson L
600
Aguilar J
600
Kemper R
600
Newman P
600
Regan R
この同じ結果は、次のような単純な問合わせでも生成できますが、
SELECT Name, DeptNo
FROM Employee
WHERE (DeptNo = 500)
OR (DeptNo = 600);
UNION 演算子を使用して問合わせを定式化することの利点として、DeptNo 列が
Employee テーブルの基本索引である場合、UNION 演算子を使用することによって
基本選択が基本キー操作になることが保証される、という点があります。OR 演算
を使用する問合わせが基本索引を使用する保証はありません。
例3
さらに、複数のテーブルから取得した値のリストをまとめる場合も、UNION 演算子
が役に立ちます。
たとえば、部門番号 500 と 600 が独自の Employee テーブルを持つ場合、次の問
合わせを使用して、2 つの異なるテーブルからデータを選択し、そのデータを単一
のリストにまとめることができます。
SELECT Name, DeptNo
FROM Employee_dept_500
UNION
SELECT Name, DeptNo
FROM Employee_dept_600 ;
例4
プロジェクトに携わっている従業員一人当たりの工数を求めると想定します。さら
に、プロジェクトに携わっていない従業員の名前も結果に含めるとします。
SQL 関数、演算子、式および述部
1105
第 25 章 集合演算子
UNION 演算子
そのためには、次の例のような合併の操作を実行しなければなりません。
SELECT Name, Proj_Id, Hours
FROM Employee, Charges
WHERE Employee.EmpNo = Charges.EmpNo
UNION
SELECT Name, Null (CHAR(8)), Null (DECIMAL(4,2)),
FROM Employee
WHERE EmpNo NOT IN
(SELECT EmpNo
FROM Charges
)
UNION
SELECT Null (VARCHAR(12)), Proj_Id, Hours
FROM Charges
WHERE EmpNo NOT IN
(SELECT EmpNo
FROM Employee
);
文の最初の部分で、Employee テーブルと Charges テーブルを EmpNo の列で結合し
ます。2 番目の部分で、Employee テーブルにリストされているが、Charges テーブ
ルにはリストされていない従業員を求めます。3 番目の部分で、Charges テーブルに
はリストされているが、Employee テーブルにはリストされていない従業員を求めま
す。これにより、要求された情報がすべて応答に含まれます。
UNION 演算子と外部結合
「例 4」は、外部結合を示しているわけではありません。この操作は、結合条件で一
致がある結合テーブルのすべての行、および一致のない"左"結合テーブルまたは"右"
結合テーブル、あるいは両方のテーブルからの行を返します。さらに、一致しない
行は NULL で拡張されます。
ただし、内部結合と UNION 演算子を使用して外部結合を実行することができます
が、2 つの内部結合を合併したものは外部結合ではありません。
2 つの内部結合と UNION 演算子を使用して外部結合を実行する例を次に示します。
2 番目の内部結合における NULL 値の使用法に注意する必要があります。
SELECT Offering.CourseNo, Offerings.Location, Enrollment.EmpNo
FROM Offerings, Enrollment
WHERE Offerings.CourseNo = Enrollment.CourseNo
UNION
SELECT Offerings.CourseNo, Offerings.Location, NULL
FROM Offerings, Enrollment
WHERE Offerings.CourseNo <> Enrollment.CourseNo;
1106
SQL 関数、演算子、式および述部
第 25 章 集合演算子
UNION 演算子
上記の UNION 演算は、上に示した左外部結合の例と同じ次のような結果を戻します。
O.CourseNo
O.Location
E.EmpNo
C100
El Segundo
235
C100
El Segundo
668
C200
Dayton
?
C400
El Segundo
?
例 5: UNION のデータ型に対する明示 NULL の影響
集合演算子の結果によって、操作中に最初の SELECT 文で定義される列のデータ型
が評価されます。最初の SELECT 文にある列が明示 NULL として定義される場合、
結果のデータ タイプは直感的には認識されません。
次に、直感的には同一結果を評価すると思われるが、そうではない 2 つの例を示し
ます。
最初に、明示 NULL が列値として選択されます。
SELECT 'p', NULL
FROM TableVM
UNION
SELECT 'q', 145.87
FROM TableVM;
BTEQ は以下の結果を戻します。
'p'
--p
q
Null
----------?
145
Null 列の第 2 行に対する予期値は、予期した値、つまり 10 進値 145.87 とは異な
る可能性があります。
合併の 2 つの SELECT の順序が逆になると、
SELECT 'q', 145.87
FROM TableVM
UNION
SELECT 'p', NULL
FROM TableVM;
BTEQ は以下の結果を戻します。
'q'
---
145.87
-----------
SQL 関数、演算子、式および述部
1107
第 25 章 集合演算子
UNION 演算子
p
q
?
145.87
q の値は、 真のデータ タイプ(DECIMAL)として報告されます。このとき切り捨ては
行なわれません。なぜ、この違いがあるのでしょう。
最初の合併の例では、明示 NULL は最初の SELECT 文の第 2 列に指定されます。第
2SELECT 文の第 2 列は、DECIMAL 数として指定されますが、整数に評価します。
これは、このコンテキスト内で、NULL は値を持ちませんが、データ型 INTEGER を
持ち、その型が合併の結果に保存されるからです。
第 2 の合併の例では、値 145.87 のデータ タイプ(DECIMAL)が結果を指定します。
次の SELECT 文を実行して、NULL および 145.87 の変換されないデータ タイプを
確認することができます。
SELECT TYPE(NULL), TYPE(145.87)
BTEQ は以下の結果を戻します。
Type(Null)
----------------INTEGER
Type(145.87)
---------------------DECIMAL(5,2)
例 6: SELECT 文の順序がデータ型に及ぼす影響
UNION の結果は常に、最初の SELECT の選択値のデータ型を使って表現されます。
これはつまり、SELECT A UNION SELECT B は必ずしも、SELECT B UNION SELECT
A と同じ結果を戻すとは限らないということです。ただし、どちらのケースでも同
じ結果が戻されるよう、明示的に出力データ タイプを変換する場合は別です。
次の複雑な UNION を使った問合わせについて考えてみましょう。
SELECT MIN(X8.i1)
FROM t8 X8
LEFT JOIN t1 X1 ON X8.i1=X1.i1
AND X8.i1 IN
(SELECT COUNT(*)
FROM t8 X8
LEFT JOIN t1 X1 ON X8.i1=X1.i1
AND X8.i1 = ANY
(SELECT COUNT(*)
FROM t7 X7
WHERE X7.i1 = ANY
(SELECT AVG(X1.i1)
FROM t1 X1)))
UNION
SELECT AVG(X4.i1)
FROM t4 X4
1108
SQL 関数、演算子、式および述部
第 25 章 集合演算子
UNION 演算子
WHERE X4.i1 = ANY
(SELECT (X8.i1)
FROM t1 X1
RIGHT JOIN t8 X8 ON X8.i1=X1.i1
AND X8.i1 = IN
(SELECT MAX(X8.i1)
FROM t8 X8
LEFT JOIN t1 X1 ON X8.i1=X1.i1
AND
(SELECT (X4.i1)
FROM t6 X6
RIGHT JOIN t4 X4 ON X6.i1=i1))));
結果は以下のように報告されます。
Minimum(i1)
-----------2
0
直感的には、UNION の両側の問合わせの順序を入れ替えても、同じ結果を生成する
はずだと思えるかもしれません。最初の SELECT の選択値のデータ タイプが異なる
場合があるので、必ずしもそのようにはなりません。同じデータベースにおける次
の問合わせがそのことを例示しています。
SELECT AVG(X4.i1)
FROM t4 X4
WHERE X4.i1 = ANY
(SELECT (X8.i1)
FROM t1 X1
RIGHT JOIN t8 X8 ON X8.i1 = X1.i1
AND X8.i1 = ANY
(SELECT MAX(X8.i1)
FROM t8 X8
LEFT JOIN t1 X1 ON X8.i1 = X1.i1
AND
(SELECT (X4.i1)
FROM t6 X6
RIGHT JOIN t4 X4 ON X6.i1 = i
)
)
)
UNION
SELECT MIN(X8.i1)
FROM t8 X8
LEFT JOIN t1 X1 ON X8.i1 = X1.i1
SQL 関数、演算子、式および述部
1109
第 25 章 集合演算子
UNION 演算子
AND X8.i1 IN
(SELECT COUNT(*)
FROM t8 X8
LEFT JOIN t1 X1 ON X8.i1 = X1.i1
AND X8.i1 = ANY
(SELECT COUNT(*)
FROM t7 X7
WHERE X7.i1 = ANY
(SELECT AVG(X1.i1)
FROM t1 X1
)
);
結果は以下のように報告されます。
Average(i1)
-----------2
1
実際の平均は< 0.5 です。UNION の中の SELECT の順序を逆にすると違いが生じる
のはなぜでしょうか?一見矛盾した結果が生じる理由が、次の表に説明されています。
最初の SELECT が指定する関数
結果のデータ タイプ
結果として戻される値
AVG
REAL
1
MIN
INTEGER
0 に切り捨てられる
関連トピック
詳細は、以下を参照してください。
• 例については、「例 6: SELECT 文の順序がデータ型に及ぼす影響」を参照してく
ださい。
1110
SQL 関数、演算子、式および述部
第 26 章
文字列演算子と関数
概要
この章では、文字列演算子と文字列関数について説明します。
文字列関数について
SQL には、文字列に対して変換、連結、および他の操作を行なうための連結演算子
と各種文字列関数があります。
この章で説明されている関数は、主に文字列の処理用に設計されています。その多
くはバイト、数値リテラル、およびリテラルの各データ列も処理できるため、この
章で「文字列」という用語を用いる場合、これら 3 つのデータ型ファミリーも指し
ている場合が少なくありません。
文字列関数の操作対象になるデータ タイプ
次の表は、文字列として処理可能なすべてのデータ タイプを列挙しています。これ
らのすべてのタイプがすべての関数に受け入れられるわけではないことに注意する
必要があります。処理可能なタイプについては、各関数を参照してください。
データ タイプ グループ
文字
バイト
数値
• CHARACTER
• BYTE
• BYTEINT
• VARCHAR
• VARBYTE
• DECIMAL
• CLOB
• BLOB
• FLOAT
• INTEGER
• NUMERIC
• SMALLINT
Teradata SQL 文字列関数に相当する ANSI の文字列関数
Teradata SQL 文字列関数のいくつかは、ANSI SQL:2011 規格の拡張機能です。
ANSI との互換性を維持するために、ANSI の等価関数があれば、Teradata SQL 文字
列関数ではなく、それを使用してください。
SQL 関数、演算子、式および述部
1111
第 26 章 文字列演算子と関数
文字列関数へのサーバー文字セットの影響
変更する Teradata 文字列関数
新規アプリケーションで使用する ANSI 文字列
関数
INDEX
POSITION
MINDEX†
SUBSTR
SUBSTRING
MSUBSTR†
† これらの関数の記述はなくなりました。これらの関数の使用は推奨されません。KANJI1
のサポートが停止された後はサポートされなくなるためです。
以下の Teradata 関数には、ANSI の等価関数がありません。
•
•
•
•
•
CHAR2HEXINT
SOUNDEX
TRANSLATE_CHK
UPPER
VARGRAPHIC
文字列に対して操作を行なうその他の関数
SQL には、この章では取り上げていない文字列関数および演算子があります。
詳細情報
参照資料
文字列に関する記述情報を戻す、次の属性
関数
属性関数の概要。
• BYTE
• CHARACTER_LENGTH/
CHAR_LENGTH
• OCTET_LENGTH
比較演算子
比較演算子と関数の概要
LIKE 述部
論理述部
文字列関数へのサーバー文字セットの影響
文字データに対して実行される文字列関数は、以下に挙げる規則に従います。
LATIN での大文字変換
LATIN サーバー文字セットの場合の大文字への変換方法は、ISO 8859 Latin1 に基づ
きます。
1112
SQL 関数、演算子、式および述部
第 26 章 文字列演算子と関数
文字列関数へのサーバー文字セットの影響
論理文字と物理文字
UNICODE、GRAPHIC、KANJISJIS の各サーバー文字セットの場合、関数は論理文字
ベースで動作します。ただし、ANSI モードと Teradata モードの切り替えに対応し
ている関数は例外です。
KANJISJIS の格納スペースは物理ベースで割り振られ、ANSI との互換性はありませ
んが、このタイプに対する文字列操作はすべて ANSI の仕様の文字ベースで行なわ
れます。
変換不能な KANJI1 文字
注:
Teradata の国際化計画に従って、KANJI1 のサポートはサポート外になりました。
このサポートは、近い将来に廃止される予定です。KANJI1 はデフォルトの文字セッ
トとして許可されません。システムはデフォルトの KANJI1 文字セットを UNICODE
文字セットに変更します。KANJI1 の新規オブジェクトの作成は、高度に制限され
ています。KANJI1 を使用する問合わせやアプリケーションの多くは、従来通り動
作しますが、KANJI1 を使用するサイトはできるだけ早く別の文字セットに変換す
る必要があります。詳細については、<国際文字セットのサポート、B035-1125>の
KANJI1 文字セットを参照してください。
セッションの文字セットが UTF8 または UTF16 の場合、文字列関数は KANJI1 サー
バー文字セットの文字すべてに作用するとは限りません。これは、KANJI1 サーバー
文字セットには、マルチバイト文字と一部の 1 バイト文字に関してあいまいなとこ
ろがあるからです。
推奨事項: KANJI1 サーバー文字セットが必要でない限り、UNICODE サーバー文字
セットを UTF8 および UTF16 セッション文字セットと併用するようにすれば、最良
の結果が得られます。
次に示す KanjiEBCDIC の 1 バイト文字から KANJI1 への変換は、次に示す Unicode
文字名にマップされます。
16 進数値
文字
Unicode 文字名
0x10
¢
CENT SIGN
0x11
£
POUND SIGN
0x12
¬
NOT SIGN
0x13
\
REVERSE SOLIDUS
0x14
~
TILDE
ただし、KanjiSJIS 文字セットでは、これらの 16 進数値は、制御文字にマップされ
ます。
SQL 関数、演算子、式および述部
1113
第 26 章 文字列演算子と関数
連結演算子
サーバー文字セットの暗黙変換
複数の引数で実行される関数では、その引数に異なるサーバー文字セットがある場
合は暗黙変換規則が適用されます。
連結演算子
目的
文字列式を連結します。
構文
string_expression_1
string_expression_2
string_expression_n
構文要素
string_expression_1
バイト、数値、または文字列あるいは文字列式。
ANSI への準拠
感嘆符のペア(!!)は、ANSI SQL:2011 規格の Teradata 拡張機能です。連結演算子と
して感嘆符は使用しないでください。
実線の縦線のペア(||)と点線の縦線のペアは、ANSI SQL:2011 に準拠した連結演算子
です。
引数のタイプと規則
次のタイプの文字列および文字列式に対して連結演算子を使用します。
• バイト
引数のいずれかがバイト タイプの場合は、他の引数もすべてバイト タイプでな
ければなりません。
• 数値
数値のための書式を使用して、数値の引数が文字列に変換されます。数値から文
字データ型への暗黙的変換についての詳細は、「数値から文字への暗黙の変換」
を参照してください。
• 文字
1114
SQL 関数、演算子、式および述部
第 26 章 文字列演算子と関数
連結演算子
引数がどちらも文字タイプであってもサーバー文字セットが異なる場合は、文字
列の暗黙変換が行なわれます。詳細については、「文字から文字への暗黙の変
換」を参照してください。
• 事前定義された文字タイプへの暗黙 CAST を持つ UDT。
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS
ASSIGNMENT 節を指定します。CREATE CAST の詳細は、<SQL データ定義言語
- 構文規則および例、B035-1144>を参照してください。
連結演算子を含め、システム演算子および関数用の UDT の暗黙の型変換は、ANSI
SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レコー
ドの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定します。詳細
は、<SQL データ定義言語 - 構文規則および例、B035-1144>を参照してください。
UDT の暗黙的な型の変換の詳細については、「データ型の変換」を参照してくだ
さい。
結果のタイプと属性
連結演算子の結果は、左から右の方向に引数を連結することによって出来上がる文
字列です。
arg1 || arg2 のデフォルトの結果の型と属性は、次のとおりです。
• 引数がバイト列(バイナリ)である場合、結果はバイト列(バイナリ)になります。
• 引数が数値、文字列、または暗黙で文字列にキャストされる UDT である場合、
結果は文字列になります。
いずれかの引数が NULL の場合、結果は NULL になります。
引数のデータ タイプと属性によって、連結演算子の結果タイプが固定長か可変長文
字列かが決まります。結果タイプは次の表に示すようになります。n は、すべての
引数の長さの合計です。
引数
データ タイプまたは属性
結果のデータ タイプま
たは属性
一方
VARBYTE
VARBYTE(n)
VARCHAR
VARCHAR(n)
数値
暗黙で VARCHAR にキャストされる UDT
両方
SQL 関数、演算子、式および述部
CLOB
CLOB(n)
BLOB
BLOB(n)
BYTE
BYTE(n)
CHARACTER (同じサーバー文字セット)
CHARACTER(n)
1115
第 26 章 文字列演算子と関数
連結演算子
引数
データ タイプまたは属性
結果のデータ タイプま
たは属性
暗黙で CHARACTER(同じサーバー文字セット)
にキャストされる UDT
CHARACTER (異なるサーバー文字セット)
VARCHAR(n)
暗黙で CHARACTER(異なるサーバー文字セッ
ト)にキャストされる UDT
数値
いずれかの引数が CASESPECIFIC 属性を指定する文字列の場合、結果も
CASESPECIFIC 属性を指定します。
例
例: 結果を読みやすくするために連結を使用する
結果の見出しを書式設定して読みやすくするために、リテラル、スペース、TITLE
句を演算定義の中に組み込むことができます。
たとえば、以下の定義は、サイド タイトル、均等にスペースを入れた結果文字列、
ブランクの見出しを戻します。
SELECT ('Sex ' || sex ||', Marital Status ' || mstat)(TITLE ' ')
FROM Employee ;
Sex
Sex
Sex
Sex
Sex
Sex
Sex
M,
F,
M,
F,
F,
M,
F,
...
Marital
Marital
Marital
Marital
Marital
Marital
Marital
Status
Status
Status
Status
Status
Status
Status
S
M
M
M
M
M
W
例: 名と姓の連結
names というテーブルに、以下のように VARCHAR として定義したラスト ネーム列
とファースト ネーム列が含まれているとします。
lname
-----------Ryan
Villegas
Kanieski
Brown
1116
fname
-----------Loretta
Arnando
Carol
Alan
SQL 関数、演算子、式および述部
第 26 章 文字列演算子と関数
連結演算子
文字列連結とスペース区切り文字を使って、ファースト ネームとラスト ネームを
組み合わせしてみましょう。
SELECT fname ||' '|| lname
FROM names
ORDER BY lname ;
結果は以下のようになります。
((fname||' ')||lname)
--------------------Alan Brown
Carol Kanieski
Loretta Ryan
Arnando Villegas
例: 姓と名の連結
SELECT と区切り文字を変更して、ラスト ネーム、ファースト ネームの順番で名前
を表示してみましょう。
SELECT lname||', '||fname
FROM names
ORDER BY lname;
結果は以下のようになります。
((lname||', ')||fname)
---------------------Brown, Alan
Kanieski, Carol
Ryan, Loretta
Villegas, Arnando
例 4: バイト文字列の連結
この例では、バイト文字列を連結する方法を示します。次のテーブル定義について
考察してみます。
CREATE TABLE
(column_1
,column_2
,column_3
tsttbla
BYTE(2)
VARBYTE(10)
BLOB(128K) );
テーブル tsttbla に次の値が挿入されます。
INSERT tsttbla ('4142'XB, '7A7B7C'XB, '1A1B1C2B2C'XB);
次の SELECT 文は、column_2 と column_1 と column_3 を連結します。
SQL 関数、演算子、式および述部
1117
第 26 章 文字列演算子と関数
連結演算子
SELECT (column_2 || column_1 || column_3) (FORMAT 'X(20)')
FROM tsttbla ;
結果は以下のようになります。
((column_2||column_1)||column_3)
-------------------------------7A7B7C41421A1B1C2B2C
結果のデータ タイプは BLOB です。
日本語文字セットの例
以下の表は、Teradata Database でサポートされているそれぞれの Kanji 文字セット
について、文字列式の連結結果を示したものです。
以下の例では、文字列式が、< SQL データ型とリテラル、B035-1143>の「SQL デー
タ定義」という章で定義されているルールに準拠していることを前提としています。
例: KanjiEBCDIC
string_expression_1 || string_expression_2
string_expression_1
string_expression_2
結果
< ABC >
< DEF >G
< ABCDEF >G
< ABC >
<>
< ABC >
< ABC >a
< DEF >
< ABC >a< DEF >
例: KanjiEUC
string_expression_1 || string_expression_2
string_expression_1
string_expression_2
結果
ABC m
DEF g
ABC mDEF g
ss3 A ss2 B m
ss3 C
ss3 A ss2 B m ss3 C
例: KanjiShift-JIS
string_expression_1 || string_expression_2
1118
string_expression_1
string_expression_2
結果
mnABC X
B
mnABC X B
mnABC X
g
mnABC X g
SQL 関数、演算子、式および述部
第 26 章 文字列演算子と関数
連結演算子
サーバー文字セットが異なる文字列の連結
CHARACTER SET 属性で異なるサーバー文字セットを指定している文字列の連結の
場合は、特に注意が必要です。
暗黙変換規則が適用されます。
文字列が固定長文字列の場合、結果は可変長になり、その長さは連結される文字列
の長さの合計に等しくなります。
この点は、文字列の長さがバイトで定義されているか文字数で定義されているかに
かかわらず当てはまります。したがって、n バイト固定長 KANJISJIS 文字列と m 文
字固定長 UNICODE 文字列を連結すると、VARCHAR(m+n) CHARACTER SET
UNICODE 結果が生成されます。
次のテーブル定義を考えます。
CREATE TABLE tab1
(cunicode CHARACTER(4)
,clatin
CHARACTER(3)
,csjis
CHARACTER(3)
CHARACTER SET UNICODE
CHARACTER SET LATIN
CHARACTER SET KANJISJIS);
テーブル tab1 に次の値が挿入されます。
INSERT tab1 ('abc', 'abc', 'abc');
以下の表は、こうした連結特性をまとめたものです。
連結
結果
結果のタイプ
cunicode || clatin
'abcΔ abc'
VARCHAR(7) CHARACTER SET UNICODE
clatin || csjis
'abcabc'
VARCHAR(6) CHARACTER SET UNICODE
cunicode || csjis
'abcΔ abc'
VARCHAR(7) CHARACTER SET UNICODE
KanjiEBCDIC を除くすべての KANJI1 文字列の連結は、上記の説明のように動作し
ます。ただし、KanjiEBCDIC の場合は、結果式内の隣接するシフトアウト(<)文字と
シフトイン(>)文字が削除されます。この場合、結果文字列には、必要に応じて<半
角スペース>文字が末尾に埋め込まれます。
関連トピック
暗黙変換規則の詳細については、文字から文字への暗黙変換を参照してください。
SQL 関数、演算子、式および述部
1119
第 26 章 文字列演算子と関数
ASCII
ASCII
目的
string_expr の最初の文字の 10 進数表現を、NUMBER 値として返します。この 10
進数表現は、入力文字列の文字セットを反映します。
構文
ASCII
( string_expr )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
string_expr
文字列または文字列式。
この構文要素が NULL の場合、NULL が返されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
ASCII は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡される式には、次のいずれかのデータ タイプが含まれている必要があ
ります。
• CHAR
• VARCHAR
• CLOB
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
1120
SQL 関数、演算子、式および述部
第 26 章 文字列演算子と関数
CHAR2HEXINT
結果のタイプ
結果のデータ タイプは NUMBER です。ASCII は、入力引数の文字セットでの 10 進
数表現を返します。たとえば、この関数に Unicode 文字列を渡すと、その Unicode
文字の 10 進数表現が返されます。
例
以下の問合わせは結果として 121 を返します。
SELECT ASCII('y');
関連トピック
詳細は、以下を参照してください。
• <SQL 外部ルーチン プログラミング、B035-1147>の「互換データ型」。
• 埋め込みサービス関数をアクティブ化して呼び出すには、「埋め込みサービス シ
ステム関数」を参照してください。
CHAR2HEXINT
目的
文字列の 16 進数表現を戻します。
構文
CHAR2HEXINT
( character_string_expression )
構文要素
character_string_expression
16 進数表現を戻す文字列または文字列式。
引数のタイプ
文字列または文字列式に対して CHAR2HEXINT を使用します。
Teradata Database はデフォルトで、UDT と、事前定義文字列タイプの間でキャス
トを行なう暗黙 CAST を持つ UDT 引数に対して、暗黙のタイプ変換を行ないます。
UDT 用の暗黙 CAST を定義するには、CREATE CAST 文を使用し、AS ASSIGNMENT
節を指定します。
SQL 関数、演算子、式および述部
1121
第 26 章 文字列演算子と関数
CHAR2HEXINT
CHAR2HEXINT を含め、システム演算子および関数用の UDT の暗黙タイプ変換は、
ANSI SQL 規格の Teradata 拡張機能です。
CLOB では CHAR2HEXINT はサポートされていません。
結果のタイプと属性
CHAR2HEXINT(character_string_expression)のデフォルトの属性は、次のとおりで
す。
データ タイプ
見出し
CHARACTER
Char2HexInt(character_string_expression)
結果の長さは、character_string_expression の長さの 2 倍になります。
結果のサーバー文字セットは LATIN です。
character_string_expression 引数が NULL の場合、結果は NULL になります。
CHAR2HEXINT とリテラル文字列
CHAR2HEXINT を文字列リテラルに対して適用して、その 16 進数相当の値を判別
することができます。
文字リテラルは VARCHAR(n) CHARACTER SET UNICODE として扱われます。n は定
数の長さです。
次に示す文と結果は、リテラル文字列に対する CHAR2HEXINT の操作を示したもの
です。
SELECT CHAR2HEXINT('123');
Char2HexInt('123')
----------------------003100320033
例
例
sysinit 時にシステムの日本語サポートが使用可能になっていたとします 。
CREATE TABLE tab1
(clatin
,cunicode
,csjis
,cgraphic
,ckanji1
1122
CHAR(3)
CHAR(3)
CHAR(3)
CHAR(3)
CHAR(3)
CHARACTER
CHARACTER
CHARACTER
CHARACTER
CHARACTER
SET
SET
SET
SET
SET
LATIN
UNICODE
KANJISJIS
GRAPHIC
KANJI1);
SQL 関数、演算子、式および述部
第 26 章 文字列演算子と関数
CHAR2HEXINT
INSERT INTO tab1('abc','abc','abc',_GRAPHIC 'ABC
','abc');
この例にある太字の大文字 LATIN 文字は、全角の LATIN 文字を表わします。
CHAR2HEXINT は、tab1 に挿入された文字列について、次の結果を戻します。
関数
返す結果
CHAR2HEXINT(clatin)
616263
CHAR2HEXINT(cunicode)
006100620063'
CHAR2HEXINT(csjis)
616263
CHAR2HEXINT(cgraphic)
FF41FF42FF43
CHAR2HEXINT(ckanji1)
616263
例
すべてのテーブル名の内部 16 進数表現を調べる場合は、CHAR2HEXINT を使用し
て次の SELECT 文を実行します。
SELECT CHAR2HEXINT(TRIM(t.tablename))(FORMAT 'X(30)')
(TITLE 'Internal Hex Representation of TableName')
,t.tablename (TITLE 'TableName')
FROM dbc.tables T
WHERE t.tablekind = 'T'
ORDER BY t.tablename;
この SELECT 文の部分的な結果は、以下のレポートのようになります。
Internal Hex Representation of TableName
---------------------------------------416363657373526967687473
4163634C6F6752756C6554626C
4163634C6F6754626C
4163636F756E7473
4163637467
416C6C
436F70496E666F54626C
TableName
---------------AccessRights
AccLogRuleTbl
AccLogTbl
Accounts
Acctg
All
CopInfoTbl
関連トピック
• CREATE CAST の詳細は、<SQL データ定義言語 - 構文規則および例、B035-1144>
を参照してください。
• CHAR2HEXINT 拡張機能を無効にする方法については、<ユーティリティ 、
B035-1102>を参照してください。
SQL 関数、演算子、式および述部
1123
第 26 章 文字列演算子と関数
CHR
• UDT の暗黙的な型の変換の詳細については、「データ型の変換」を参照してくだ
さい。
CHR
目的
指定された数値コード値の Latin ASCII 文字を返します。
構文
CHR
( numeric_expr )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
numeric_expr
numeric_expr はゼロ以上でなければなりません。numeric_expr が 255 よりも大き
い場合は、0 から 255 の値を返す numeric_expr mod 256 の演算が実行されます。
この構文要素が NULL の場合、NULL が返されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
CHR は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡された式は、NUMBER データ タイプを持っている必要があります。
UDF に適用される暗黙のデータ タイプ変換規則を使用して NUMBER に変換できる、
BYTEINT、SMALLINT、INTEGER、または BIGINT などのデータ タイプの引数も渡
すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
1124
SQL 関数、演算子、式および述部
第 26 章 文字列演算子と関数
CSV
結果のタイプ
結果のデータ タイプは CHAR(1) CHARACTER SET LATIN です。
例
以下の問合わせは結果として'B'を返します。
SELECT CHR(66);
関連トピック
詳細は、以下を参照してください。
• <SQL 外部ルーチン プログラミング、B035-1147>の「互換データ型」。
• 埋め込みサービス関数をアクティブ化して呼び出すには、「埋め込みサービス シ
ステム関数」を参照してください。
CSV
目的
CSV (カンマ区切り値データのアンローディング)は、ユーザー定義の区切り文字で
分離した入力行の列値をテキスト形式で返します。
構文
CSV ( NEW VARIANT_TYPE (
, 8
value
) , delimit_string_value , quote_string_value )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
NEW VARIANT_TYPEvalue
数値または文字式。
NEW VARIANT_TYPE は最大 8 行の列値をサポートします。
各行の列値には、サポートされるデータ タイプの列が最大 128 列保持されている
可能性があります。
SQL 関数、演算子、式および述部
1125
第 26 章 文字列演算子と関数
CSV
delimit_string_value
文字式。
カンマはデフォルトの区切り文字です。
quote_string_value
文字式。
'"'というように引用符文字を指定した場合、文字列データ型として定義されている
列は、引用符に囲まれて返されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
CSV は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡された式は、次のデータ タイプを持っている必要があります。
• NEW VARIANT_TYPE value = BYTEINT、SMALLINT、BIGINT、INTEGER、
DECIMAL、FLOAT、DATE、TIME、TIME WITH TIME ZONE、TIMESTAMP、
TIMESTAMP WITH TIME ZONE、INTERVAL、CHAR、VARCHAR
注: value は CLOB または GRAPHIC にはなりません。
• delimit_string_value = VARCHAR
• quote_string_value = VARCHAR
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
結果のタイプ
CSV は、データ タイプが VARCHAR の値を、LATIN または UNICODE のどちらかの
文字セットで返すテーブル関数です。
1126
SQL 関数、演算子、式および述部
第 26 章 文字列演算子と関数
CSVLD
例
例
以下の問合わせを実行します。
SELECT * FROM TABLE(CSV(NEW VARIANT_TYPE(dt.c1, dt.c2, dt.c3), ',', '"')
RETURNS (op varchar(64000) character set LATIN)) as t1;
CSV は、列値をカンマで分離し、文字列データ タイプの列を引用符で囲んだ文字列
を返します。
SELECT * FROM TABLE (CSV(NEW VARIANT_TYPE(dt.c1, dt.c2, dt.c3), ',', '')
RETURNS (op varchar(32000) character set UNICODE)) as t1;
CSV は列値をカンマで分離し、文字列データ タイプの列を引用符文字で囲んでいな
い文字列を返します。
例
以下の問合わせを実行します。
SELECT * FROM TABLE (CSV(NEW VARIANT_TYPE(dt.c1, dt.c2, dt.c3), ',', '')
RETURNS (op varchar(32000) character set UNICODE)) as t1;
CSV は列値をカンマで分離し、文字列データ タイプの列を引用符文字で囲んでいな
い文字列を返します。
関連トピック
詳細は、以下を参照してください。
• <SQL 外部ルーチン プログラミング、B035-1147>の「互換データ型」。
• 埋め込みサービス関数をアクティブ化して呼び出すには、「埋め込みサービス シ
ステム関数」を参照してください。
CSVLD
目的
CSVLD (カンマ区切り値データのローディング)は、CSV テーブル関数で生成された
カンマ区切りの文字列を受け取り、その文字列を構文解析して VARCHAR 列を返し
ます。
構文
CSVLD ( data_string_value, delim_string_value, quote_string_value )
TD_SYSFNLIB.
SQL 関数、演算子、式および述部
1127
第 26 章 文字列演算子と関数
CSVLD
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
data_string_value
文字列の引数。
delim_string_value
文字式。
カンマはデフォルトの区切り文字です。
quote_string_value
文字式。
'"'というように引用符文字を指定した場合、文字列データ型として定義されている
列は、引用符に囲まれて返されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
CSVLD は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡される式には、NUMBER データ タイプが含まれている必要があります。
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
結果のタイプ
CSVLD は、最大 1024 の VARCHAR 列を LATIN または UNICODE のどちらかの文字
セットで返すテーブル関数です。
この関数で指定される出力列の数は、入力文字列のカンマで区切られた値の数と必
ず一致します。
1128
SQL 関数、演算子、式および述部
第 26 章 文字列演算子と関数
EDITDISTANCE
例
以下の問合わせを実行します。
SELECT * FROM TABLE (CSVLD(load_date.data, ',', '"')
RETURNS (p1 varchar(100), p2 varchar(100))) as T1;
CSVLD はカンマ区切りの文字列を構文解析し、2 つの VARCHAR 列を返します。
関連トピック
詳細は、以下を参照してください。
• <SQL 外部ルーチン プログラミング、B035-1147>の「互換データ型」。
• 埋め込みサービス関数をアクティブ化して呼び出すには、「埋め込みサービス シ
ステム関数」を参照してください。
EDITDISTANCE
目的
string1 を string2 に変換するために必要な編集操作(挿入、削除、置換および転置)
の最小回数を返します。
構文
EDITDISTANCE
( string1, string2
TD_SYSFNLIB.
)
, ci, cd, cs, ct
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
string1
文字列または文字列式。
string2
文字列または文字列式。
ci
この構文要素を負の値にすることはできません。
指定しなかった場合、デフォルト値の 1 が使用されます。
SQL 関数、演算子、式および述部
1129
第 26 章 文字列演算子と関数
EDITDISTANCE
cd
この構文要素を負の値にすることはできません。
指定しなかった場合、デフォルト値の 1 が使用されます。
cs
この構文要素を負の値にすることはできません。
指定しなかった場合、デフォルト値の 1 が使用されます。
ct
この構文要素を負の値にすることはできません。
指定しなかった場合、デフォルト値の 1 が使用されます。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
EDITDISTANCE は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡された式は、次のデータ タイプを持っている必要があります。
•
•
•
•
•
•
string1 = CHAR、VARCHAR、または CLOB
string2 = CHAR、VARCHAR、または CLOB
ci = INTEGER
cd = INTEGER
cs = INTEGER
ct = INTEGER
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
結果のタイプ
結果のデータ タイプは INTEGER です。
1130
SQL 関数、演算子、式および述部
第 26 章 文字列演算子と関数
EDITDISTANCE
使用上の注意
EDITDISTANCE は、2 つの文字列間の類似性を測定します。削除、挿入、置換また
は転置の回数が少ないということは、類似性が高いということを意味します。挿入
回数、削除回数、置換回数および転置回数は、見積もり演算用に変更を加えた
Damerau-Levenshtein 距離アルゴリズムに基づいたものになります。
string1 または string2 のどちらかが NULL の場合、この関数は NULL を返します。
例
例
以下の問合わせは結果として 9 を返します。
SELECT EDITDISTANCE('Jim D. Swain', 'John Smith');
以下の問合わせは結果として 0 を返します。これは、文字列が同じだからです。
SELECT EDITDISTANCE('John Smith', 'John Smith');
以下の問合わせは結果として 9 を返します。
SELECT EDITDISTANCE('Jim D. Swain', 'John Smith', 2, 1, 1, 2);
以下の問合わせは結果として 11 を返します。
SELECT EDITDISTANCE('John Smith', 'Jim D. Swain', 2, 1, 1, 2);
例
以下の問合わせは結果として 0 を返します。これは、文字列が同じだからです。
SELECT EDITDISTANCE('John Smith', 'John Smith');
例
以下の問合わせは結果として 9 を返します。
SELECT EDITDISTANCE('Jim D. Swain', 'John Smith', 2, 1, 1, 2);
例
以下の問合わせは結果として 11 を返します。
SELECT EDITDISTANCE('John Smith', 'Jim D. Swain', 2, 1, 1, 2);
関連トピック
埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービス シ
ステム関数」を参照してください。
SQL 関数、演算子、式および述部
1131
第 26 章 文字列演算子と関数
INDEX
INDEX
目的
string_expression_1 内で string_expression_2 が始まる位置を戻します。
構文
INDEX
( string_expression_1 ,string_expression_2 )
構文要素
string_expression_1
検索対象の完全文字列。
string_expression_2
完全文字列内での位置を検索する副文字列。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
ANSI SQL:2011 に準拠させるには、INDEX の代わりに POSITION を使用します。
引数のタイプと規則
INDEX は、次のタイプの引数に対して実行します。
• 文字
• バイト
一方の文字列式のタイプが BYTE である場合、両方の文字列式ともタイプが BYTE
でなければなりません。
• 数値
いずれかの文字列式が数値の場合、その式は CHARACTER タイプに暗黙変換され
ます。
• UDT と以下のいずれかの事前定義タイプの間でキャストを行なう暗黙 CAST を持
つ UDT
• 数値
• 文字
• DATE
• バイト
UDT 用の暗黙 CAST を定義するには、CREATE CAST を使用し、AS
ASSIGNMENT を指定します。CREATE CAST の詳細は、<SQL データ定義言語
- 構文規則および例、B035-1144>を参照してください。
1132
SQL 関数、演算子、式および述部
第 26 章 文字列演算子と関数
INDEX
INDEX を含め、システム演算子および関数用の UDT の暗黙の型変換は、ANSI
SQL 規格の Teradata 拡張機能です。この拡張を無効にするには、DBS 制御レ
コードの DisableUDTImplCastForSysFuncOp フィールドを TRUE に設定しま
す。詳細は、<ユーティリティ 、B035-1102>を参照してください。
INDEX は、CLOB および BLOB をサポートしません。
結果のタイプと属性
INDEX(arg1, arg2)のデフォルトの結果の型と属性は、次のとおりです。
データ タイプ
見出し
INTEGER
Index(arg1, arg2)
期待値
INDEX が戻す値には、次の規則が適用されます。
• string_expression_2 が string_expression_1 で検出されない場合、結果はゼロに
なります。
• string_expression_2 が null の場合、結果は null になります。
• 引数が文字タイプの場合は、引数のサーバー文字セットが KANJI1 でセッショ
ン クライアント文字セットが KanjiEBCDIC のとき以外は、INDEX はバイト位置
ではなく論理文字位置を戻します。
文字タイプの引数の規則
引数が文字タイプの場合、照合は論理文字に対して行なわれます。1 バイト文字は
1 バイト文字と照合され、マルチバイト文字はマルチバイト文字と照合されます。
照合を実行するには、両方の式の論理文字表現が同じでなければなりません。
引数のサーバー文字セットが同じものでない場合、INDEX は暗黙文字変換を行ない
ます。
CASESPECIFIC 属性は、文字が一致するものとしてみなせるかどうかを左右します。
セッション
モード
文字列およびリテラルの大文字小文字の区別のデフォルト
ANSI
CASESPECIFIC
TERADATA
NOT CASESPECIFIC
例外は GRAPHIC 型の文字データで、この場合は必ず CASESPECIFIC になり
ます。
大文字小文字の区別のデフォルトをオーバーライドするには、CREATE TABLE また
は ALTER TABLE の中で文字の列に対して CASESPECIFIC または NOT CASESPECIFIC
句を適用することができます。
SQL 関数、演算子、式および述部
1133
第 26 章 文字列演算子と関数
INDEX
あるいは、CASESPECIFIC または NOT CASESPECIFIC 句を INDEX 文字列引数に適用
することができます。
条件
結果
どちらかの引数の属 シンプルな Latin 文字は、文字が同じで、大文字小文字の区別も同じ
性が CASESPECIFIC 場合にのみ、一致しているとみなされます。
の場合(デフォルトま
たは明示指定によっ
て)
両方の引数の属性が
NOT CASESPECIFIC
の場合(デフォルトま
たは明示指定によっ
て)
操作を開始する前に、一部の文字が大文字に変換されます。
文字が小文字のシンプルな Latin 文字である場合は、操作が始まる前
に、大文字に変換されます。
文字が Latin 以外の 1 バイト文字、マルチバイト文字、または 1 バ
イト文字データとマルチバイト文字データとの間の移行を示すバイ
トである場合は、大文字に変換されません。
文字タイプ引数を使用している場合、INDEX による文字の照合を大文字小文字を区
別して行なうには、最低 1 つの引数に CASESPECIFIC 句を指定します。たとえば、
SELECT Name
FROM Employee
WHERE INDEX(Name, 'X' (CASESPECIFIC)) = 1;
INDEX による文字の照合を大文字小文字の区別を無視して行なうには、両方の引数
に NOT CASESPECIFIC 句を指定します。
KANJI1 サーバー文字セットの規則
注:
Teradata の国際化計画に従って、KANJI1 のサポートはサポート外になりました。こ
のサポートは、近い将来に廃止される予定です。KANJI1 はデフォルトの文字セット
として許可されません。システムはデフォルトの KANJI1 文字セットを UNICODE 文
字セットに変更します。KANJI1 の新規オブジェクトの作成は、高度に制限されてい
ます。KANJI1 を使用する問合わせやアプリケーションの多くは、従来通り動作しま
すが、KANJI1 を使用するサイトはできるだけ早く別の文字セットに変換する必要が
あります。詳細については、<国際文字セットのサポート、B035-1125>の KANJI1
文字セットを参照してください。
サーバー文字セットが KANJI1 でクライアント文字セットが KanjiEBCDIC の場合、
オフセット カウントにシフトアウト/シフトイン文字が含まれていますが、照合の対
象にはなりません。それらは、1 バイト文字とマルチバイト文字の間の移行を示す
文字としてのみ処理されます。
ゼロでない場合の結果の位置は、以下のように出力されます。
1134
SQL 関数、演算子、式および述部
第 26 章 文字列演算子と関数
INDEX
文字セット
結果
KanjiEBCDIC
string_expression_1 内での論理文字オフセット(オフセット カウ
ント内の シフトイン/シフトアウトを含む)の最初のバイトの位置。
KanjiEBCDIC 以外
string_expression_1 内の論理文字オフセット。
INDEX と POSITION の関係
INDEX と POSITION の動作は同一ですが、クライアント文字セットが KanjiEBCDIC
でサーバー文字セットが KANJI1 であり、かつ引数にマルチバイト文字が含まれる
場合の文字タイプ引数に対しては例外です。
例
例: 単純な INDEX 式の使用
以下の表は、シンプルな INDEX 式とそれぞれの結果をまとめたものです。
式
結果
INDEX('catalog','log')
5
INDEX('catalog','dog')
0
INDEX('41424344'XB,'43'XB)
3
次の例は、string_1 のサーバー文字セットと string_2 のサーバー文字セットが異な
る場合の INDEX(string_1, string_2)の動作を示したものです。この場合は両方の引
数が UNICODE に変換され(必要な場合)、文字は論理的に照合されます。
string_1
結果
string_2
文字セット
データ
文字セット
データ
UNICODE
92
abc
LATIN
abc
4
UNICODE
abc
UNICODE
c
3
KANJISJIS
92
04
UNICODE
0
4
次の例は、両方の引数のサーバー文字セットが KANJI1 でクライアント文字セット
が KanjiEBCDIC の場合の、INDEX(string_1, string_2)の動作を示したものです。
KanjiEBCDIC の場合、結果は物理単位として戻されるので、その環境の INDEX DB2
に準拠するようになります。
SQL 関数、演算子、式および述部
1135
第 26 章 文字列演算子と関数
INDEX
string_1 の内容
string_2 の内容
結果
MN<AB >
<B >
6
MN<AB >
<A >
4
MN<AB >P
P
9
MX N<AB >P
<B >
7
次の例は、両方の引数のサーバー文字セットが KANJI1 でクライアント文字セット
が KanjiEUC の場合の、INDEX(string_1, string_2)の動作を示したものです。
string_1 の内容
string_2 の内容
結果
a b ss3 A
ss3 A
3
a b ss2 B
ss2 B
3
CS1_DATA
A
6
a b ss2 D ss3 E ss2 F
ss2 F
5
a b C ss2 D ss3 E ss2 F
ss2 F
6
CS1_D mATA
A
7
次の例は、両方の引数のサーバー文字セットが KANJI1 でクライアント文字セット
が KanjiShift-JIS の場合の、INDEX(string_1, string_2)の動作を示したものです。
string_1 の内容
string_2 の内容
結果
mnABC X
B
4
mnABC X
X
6
この例では、Employee テーブルの Name 列に入っている文字列値内の' ' (スペース
文字)に INDEX を適用します。
SELECT name
FROM employee
WHERE INDEX(name, ' ') > 6 ;
INDEX は Name フィールドを調べて、6 番目を超えた文字位置(7 番目以降の位置)に
スペースが存在するすべての名前を戻します。
以下の例では、プロジェクト説明の中に Batch という語が入っているプロジェクト
のリストを表示し、その語の開始位置をリストアップします。
SELECT proj_id, INDEX(description, 'Batch')
FROM project
WHERE INDEX(description, 'Batch') > 0 ;
システムは以下の報告を戻します 。
1136
SQL 関数、演算子、式および述部
第 26 章 文字列演算子と関数
INDEX
proj_id
Index (description, 'Batch')
------------- ---------------------------OE2-0003
5
AP2-0003
13
OE1-0003
5
AP1-0003
13
AR1-0003
10
AR2-0003
10
連結、SUBSTRING、および INDEX を使った、もう少し複雑な構造の文も有益でしょ
う。Employee テーブルに次の値が入っているとします。
empno
---------10021
10007
10018
10011
10019
name
----------Smith T
Aguilar J
Russell S
Chin M
Newman P
以下の問合わせを使用して、employee テーブルから選択した name 列の名前の形式
を変更し、報告の中の句読点の表記を変更できます。
SELECT empno,
SUBSTRING(name FROM INDEX(name,' ')+1 FOR 1)||
'. '||
SUBSTRING(name FROM 1 FOR INDEX(name, ' ')-1)
(TITLE 'Emp Name')
FROM employee ;
システムは以下の報告を戻します 。
empno
---------10021
10007
10018
10011
10019
Emp Name
-------------T. Smith
J. Aguilar
S. Russell
M. Chin
P. Newman
例
次の例は、string_1 のサーバー文字セットと string_2 のサーバー文字セットが異な
る場合の INDEX(string_1, string_2)の動作を示したものです。この場合は両方の引
数が UNICODE に変換され(必要な場合)、文字は論理的に照合されます。
string_1
文字セット
SQL 関数、演算子、式および述部
結果
string_2
データ
文字セット
データ
1137
第 26 章 文字列演算子と関数
INDEX
string_1
結果
string_2
UNICODE
92 abc
LATIN
abc
4
UNICODE
abc
UNICODE
c
3
KANJISJIS
92
UNICODE
0
4
04
例: INDEX と KANJI1 および KanjiEBCDIC の併用
次の例は、両方の引数のサーバー文字セットが KANJI1 でクライアント文字セット
が KanjiEBCDIC の場合の、INDEX(string_1, string_2)の動作を示したものです。
KanjiEBCDIC の場合、結果は物理単位として戻されるので、その環境の INDEX DB2
に準拠するようになります。
string_1 の内容
string_2 の内容
結果
MN<AB>
<B>
6
MN<AB>
<A>
4
MN<AB>P
P
9
MX N<AB>P
<B>
7
例: INDEX と KANJI1 および KanjiEUC の併用
次の例は、両方の引数のサーバー文字セットが KANJI1 でクライアント文字セット
が KanjiEUC の場合の、INDEX(string_1, string_2)の動作を示したものです。
string_1 の内容
string_2 の内容
結果
a b ss3 A
ss3 A
3
a b ss2 B
ss2 B
3
CS1_DATA
A
6
a b ss2 D ss3 E ss2 F
ss2 F
5
a b C ss2 D ss3 E ss2 F
ss2 F
6
CS1_D mATA
A
7
例: INDEX と KANJI1 および KanjiShift-JIS の併用
次の例は、両方の引数のサーバー文字セットが KANJI1 でクライアント文字セット
が KanjiShift-JIS の場合の、INDEX(string_1, string_2)の動作を示したものです。
1138
string_1 の内容
string_2 の内容
結果
mnABC X
B
4
mnABC X
X
6
SQL 関数、演算子、式および述部
第 26 章 文字列演算子と関数
INDEX
例: SPACE 文字への INDEX の適用
この例では、Employee テーブルの Name 列に入っている文字列値内の' ' (スペース
文字)に INDEX を適用します。
SELECT name
FROM employee
WHERE INDEX(name, ' ') > 6 ;
INDEX は Name フィールドを調べて、6 番目を超えた文字位置(7 番目以降の位置)
にスペースが存在するすべての名前を戻します。
例: プロジェクトの説明での"Batch"の使用
以下の例では、プロジェクト説明の中に Batch という語が入っているプロジェクト
のリストを表示し、その語の開始位置をリストアップします。
SELECT proj_id, INDEX(description, 'Batch')
FROM project
WHERE INDEX(description, 'Batch') > 0 ;
システムは以下の報告を戻します 。
proj_id
Index (description, 'Batch')
------------- ---------------------------OE2-0003
5
AP2-0003
13
OE1-0003
5
AP1-0003
13
AR1-0003
10
AR2-0003
10
例: 連結、SUBSTRING、および INDEX の使用
連結、SUBSTRING、および INDEX を使った、もう少し複雑な構造の文も有益でしょ
う。Employee テーブルに次の値が入っているとします。
empno
---------10021
10007
10018
10011
10019
name
----------Smith T
Aguilar J
Russell S
Chin M
Newman P
以下の問合わせを使用して、employee テーブルから選択した name 列の名前の形式
を変更し、報告の中の句読点の表記を変更できます。
SELECT empno,
SUBSTRING(name FROM INDEX(name,' ')+1 FOR 1)||
SQL 関数、演算子、式および述部
1139
第 26 章 文字列演算子と関数
INITCAP
'. '||
SUBSTRING(name FROM 1 FOR INDEX(name, ' ')-1)
(TITLE 'Emp Name')
FROM employee ;
システムは以下の報告を戻します 。
empno
---------10021
10007
10018
10011
10019
Emp Name
-------------T. Smith
J. Aguilar
S. Russell
M. Chin
P. Newman
関連トピック
• 暗黙の型変換の詳細については、「データ型の変換」を参照してください。
• これらの 2 つの関数が同じデータに対して異なる結果を返す例については、
「POSITION と INDEX の相違点」を参照してください。
• 詳細については、「KANJI1 サーバー文字セットのルール」を参照してください。
• 暗黙的な文字変換のルールの説明については、「文字から文字への暗黙変換」を
参照してください。
INITCAP
目的
文字列引数を変更して、各単語の最初の文字が大文字、残りの文字が小文字の文字
列を返します。各単語は、空白または英数字以外の文字で区切られます。
構文
INITCAP
( string )
TD_SYSFNLIB.
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
「文字列」
文字列または列式
この構文要素が NULL の場合、NULL が返されます。
1140
SQL 関数、演算子、式および述部
第 26 章 文字列演算子と関数
INITCAP
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
INITCAP は埋め込みサービス システム関数です 。
引数のタイプと規則
この関数に渡される式には、次のいずれかのデータ タイプが含まれている必要があ
ります。
CHAR、VARCHAR、または CLOB
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
結果のタイプ
結果のデータ タイプと文字セットは、入力文字列のものと同じです。たとえば、入
力文字列のデータ タイプが VARCHAR CHARACTER SET UNICODE の場合、結果の
データ タイプは VARCHAR CHARACTER SET UNICODE になります。
例
以下の問合わせは結果として'Hello World'を返します。
SELECT INITCAP('hello WORLD');
関連トピック
詳細は、以下を参照してください。
• <SQL 外部ルーチン プログラミング、B035-1147>の「互換データ型」。
• 埋め込みサービス関数をアクティブ化して呼び出すには、「埋め込みサービス シ
ステム関数」を参照してください。
SQL 関数、演算子、式および述部
1141
第 26 章 文字列演算子と関数
INSTR
INSTR
目的
source_string 引数から search_string の出現位置を検索します。
構文
INSTR
( source_string, search_string
TD_SYSFNLIB.
)
, position
, occurence
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
source_string
文字列または文字列式。
search_string
この関数で source_string から検索する文字列。
position
source_string のこの位置から検索が開始されるように指定します。
position が指定されていない場合、検索は source_string の最初から開始されます。
position が負の場合、この関数は source_string の終端から逆方向にカウントと検索
を実行します。position の値を 0 にすることはできません。
occurrence
source_string から見つける search_string の出現位置を指定します。
occurrence が指定されていない場合、この関数は最初の出現位置を検索します。
occurrence が 1 より大きい場合、この関数は直前の出現位置の 2 番目の文字から始
めて追加の出現位置を検索します。occurrence の値をゼロ以下にすることはできま
せん。
ANSI への準拠
この文は、ANSI SQL:2011 規格に対する Teradata 拡張機能です。
呼出し
INSTR は埋め込みサービス システム関数です 。
1142
SQL 関数、演算子、式および述部
第 26 章 文字列演算子と関数
INSTR
引数のタイプと規則
この関数に渡された式は、次のデータ タイプを持っている必要があります。
•
•
•
•
source_string = CHAR、VARCHAR、または CLOB
search_string = CHAR、VARCHAR、または CLOB
position = INTEGER、BIGINT、または NUMBER
occurrence = INTEGER、BIGINT、または NUMBER
UDF に適用される暗黙のデータ タイプ変換規則を使用して上記のタイプに変換でき
る、データ タイプの引数も渡すことができます。
注: UDF の暗黙の型変換規則は、Teradata Database で通常使用される暗黙の型変換
規則よりも制限されています。UDF の暗黙の変換規則に従って、必要なデータ タイ
プに変換できない引数は、明示的にキャストする必要があります。
詳細については、<SQL 外部ルーチン プログラミング 、B035-1147>の「互換デー
タ型」を参照してください。
一致が見つかると、この関数は source_string 内での一致位置(1 から始まる)を返し
ます。一致が見つからない場合は、0 を返します。いずれかの入力引数が NULL の
場合、この関数は NULL を返します。
結果のタイプ
結果のデータ タイプは NUMBER です。
例
例
次の問合わせは、'chip'に含まれる'ch'の位置を示す 20 を結果として返します。こ
れは、検索対象文字列の 2 番目の文字から検索を始めて、2 番目の'ch'の出現位置に
なります。
SELECT INSTR('choose a chocolate chip cookie','ch',2,2);
例
次の問合わせは、結果として 2 を返します。この結果は、検索対象文字列の先頭か
ら検索を開始して、最初に出現した'N'の位置を示します。
SELECT INSTR('INSTR FUNCTION','N');
関連トピック
埋め込みサービス関数の有効化と呼び出しについて、詳細は「埋め込みサービス シ
ステム関数」を参照してください。
SQL 関数、演算子、式および述部
1143
第 26 章 文字列演算子と関数
LEFT
LEFT
目的
入力文字列を指定の文字数に切り捨てます。
LEFT 関数は、'LEFT'または'TD_LEFT'の別名で呼び出すことができます。
引数には、2 つのパラメータが含まれます。
• 第 1 パラメータ
副文字列が作成される入力文字列。CHAR、VARCHAR、および CLOB はサポート
されますが、他の型を明示的にキャストする必要があります。入力は、NULL ま
たは空の文字列にすることができます。
• 第 2 パラメータ
文字列の左側から必要な文字数を指定する正の整数。文字数が元の文字列の文字
数を超えた場合、元の文字列が返されます。
構文
LEFT
(source_string, length)
TD_SYSFNLIB.
サポートされている文字セット
以下の文字セットが LEFT 関数でサポートされます。
• Unicode
• Latin
• Kanji SJIS
• Graphic
構文要素
TD_SYSFNLIB
関数が格納されているデータベースの名前。
source_string
文字列または文字列式。
この構文要素が NULL の場合、NULL が返されます。
length
返される文字の長さを指定する整数。
1144
SQL 関数、演算子、式および述部
第 26 章 文字列演算子と関数
LENGTH
使用上の注意
ODBC を使用するクライアントで関数 LEFT を使用して問合わせを実行するときは、
ODBC 解析を無効にします。無効にしない場合、問合わせが ODBC によって SUBSTR
関数呼び出しに変更される場合があります。
結果のタイプ
副文字列が返されます。戻りタイプは CHAR を除く入力タイプに設定されます。
CHAR 入力は、VARCHAR の結果タイプです。
結果の文字セットは、Unicode および Latin の source_string 文字セットと同じで
す。結果の文字セッ