方言変換のためのApache Calciteコード

方言変換のためのApache Calciteコード

意味

Calcite は、Sql を SqlNode に解析し、次に SqlNode を特定のデータベースの方言に変換することで、Sql を統一できます。

成し遂げる

Calcite で方言変換を実装するための主なクラスは SqlDialect 基本クラスであり、その特定の変数の意味は次のとおりです。

パブリッククラスSqlDialect {

BUILT_IN_OPERATORS_LIST: サポートされている組み込み関数または演算子 (例: abs など)

// 識別子をリストします。 文字列 identifierQuoteString: 識別子の開始記号 文字列 identifierEndQuoteString: 識別子の終了記号 文字列 identifierEscapedQuote: (これが何をしているのかまだわかりません。文字列内のエスケープ文字のようなものでしょうか?)

// 定数識別子 文字列 literalQuoteString: 定数開始記号 文字列 literalEndQuoteString: 定数終了記号 文字列 literalEscapedQuote: (これが何をしているのかまだわかりません。文字列内のエスケープ文字のようなものでしょうか?)

DatabaseProduct databaseProduct: 所属するデータベース製品NullCollat​​ion nullCollat​​ion: ソートクエリを実行したときに null 値が返される順序RelDataTypeSystem dataTypeSystem: データ型 // 解析に関連Casing unquotedCasing: 大文字と小文字の変換Casing quotedCasing: 大文字と小文字の変換boolean caseSensitive: 大文字と小文字を区別するかどうか (列名が関数名を示す、など)
}
// メソッド領域 (異なるデータ ソースは、異なる詳細に基づいてカスタム レプリケーション メソッドを実装します)
許可する
パーサーを構成する
パーサーを構成する
非ASCII文字を含む
作成する
デフォルトNull方向
空のコンテキスト
クロスジョインの結合タイプをエミュレートする
NullDirectionをエミュレートする
エミュレートNullDirectionWithIsNull
カレンダーポリシーを取得する
キャストスペックを取得する
適合性を取得する
データベース製品を取得する
getNullCollat​​ion
製品を取得
引用符付き大文字小文字の取得
引用を取得
単一行テーブル名の取得
取得タイプシステム
引用符なし大文字小文字の取得
暗黙のテーブルエイリアスを持つ
識別子引用が必要
大文字と小文字を区別する
引用識別子
引用識別子
引用識別子
引用文字列リテラル
引用文字列リテラル
引用文字列リテラルUnicode
引用タイムスタンプリテラル
アイテムからのエイリアスが必要
単一値表現の書き換え
集計関数をサポート
エイリアス値をサポート
CharSet をサポート
データ型をサポート
サポート機能
GroupByWithCube をサポート
GroupByWithRollup をサポート
暗黙の型変換をサポート
ネストされた集約をサポート
OffsetFetch をサポート
ウィンドウ関数をサポート
パース解除呼び出し
日付時刻リテラルの解析
非解析フェッチAnsi
解析解除FetchUsingLimit
解析制限を解除
非解析オフセット
非解析オフセットフェッチ
unparseSqlDatetimeArithmetic
非解析SQL間隔リテラル
非解析SQL間隔修飾子
上位Nを解析解除
引用文字列リテラル

使用方法デモ

/** 「cast(column as type)」の型のSqlNodeを返します。
  * 型名、精度などによりデータベースによって異なります。
  *
  * <p>このメソッドがnullを返す場合、キャストは省略されます。デフォルトでは
  * 実装では、これはNULL型の場合であり、したがって
  * {@code CAST(NULL AS <nulltype>)} は {@code NULL} としてレンダリングされます。 */
  パブリック SqlNode getCastSpec(RelDataType タイプ)

  このメソッドは、特定のデータ ソースのデータ型に応じてデータを変換するために使用できます。次に例を示します。

  @Override パブリック SqlNode getCastSpec(RelDataType タイプ) {
    スイッチ (type.getSqlTypeName()) {
    VARCHARの場合:
      // MySQL には VARCHAR 型はなく、CHAR 型のみです。
      int vcMaxPrecision = this.getTypeSystem().getMaxPrecision(SqlTypeName.CHAR);
      int 精度 = type.getPrecision();
      (vcMaxPrecision > 0 && 精度 > vcMaxPrecision) の場合 {
        精度 = vcMaxPrecision;
      }
      新しいSqlDataTypeSpecを返します(
          新しい SqlBasicTypeNameSpec(SqlTypeName.CHAR、精度、SqlParserPos.ZERO)、
          SqlParserPos.ZERO);
    }
    super.getCastSpec(type) を返します。
  }

  SQL の Cast ステートメントを使用して、特定の型にキャストできます。

  最終的な文字列クエリ = "select cast(\"product_id\" as varchar(50)), \"product_id\" "
       + "\"製品\"から";
   最終的な文字列は "SELECT CAST(`product_id` AS CHAR(50)), `product_id`\n" です
       + "`foodmart`.`product` から";
// 解析された SqlNode
sqlNode.toSqlString(CalciteSqlDialect.DEFAULT).getSql();

Apache Calcite で方言変換を実装するためのコードに関するこの記事はこれで終わりです。Apache Calcite の方言変換の詳細については、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • Vertica 統合 Apache Hudi 大量使用ガイド
  • Alibaba Cloud Server 上での Php+Apache オペレーティング環境のセットアップの詳細な手順
  • Apache Pulsar クラスタの構築と展開の詳細なプロセス
  • SQL 解析用の Apache Calcite (Java コード例)
  • Apache log4j2-RCE 脆弱性の再現と修復の提案 (CVE-2021-44228)
  • Apache Log4j2 が核レベルの脆弱性と迅速な修正を報告
  • Apache Hudi の柔軟なペイロード メカニズムの徹底分析

<<:  モバイル端末の適応により、px は自動的に rem に変換されます。

>>:  js での typeof の使い方を理解するための記事

推薦する

HTML に埋め込まれた Flash HTML ウェブページ コードに Flash ファイルを埋め込むソリューション (パート 2)

上の記事で、SWFObject V1.5 の使い方の紹介は一旦終了です。これから、SWFObject...

CentOS8.1 で Gitlab サーバーを構築するための詳細なチュートリアル

Gitlab と Github の違いについては、あまり説明する必要はありません。一言でまとめると、...

HTML テーブルタグチュートリアル (20): 行の背景色属性 BGCOLOR

BGCOLOR 属性を使用して、行の背景色を設定できます。基本的な構文<TR BGcolor...

画像ファイルの形式とその選択方法

1. どの 3 つの形式ですか?それぞれ、gif、jpg、png です。画像ファイルを最適化すること...

CentOS7仮想マシンで固定IPアドレスを設定する方法

私の開発環境は、VMWare 仮想マシンに CentOS をインストールし、ホスト ファイルにインタ...

JavaScript関数の詳細な説明これを指す問題

目次1.関数内のこの方向1. 通常の機能2. コンストラクター3. オブジェクトメソッド4. イベン...

Windows 7 で MySQL 8.0.16 をインストールして使用する場合、パスワードの変更と Navicat への接続に関する問題が発生する

MySQL のインストール時にいくつかの問題が発生しました。オンラインで見つけた回答は似たようなもの...

dockerエラーの原因分析 終了しました (1) 4分前

Dockerエラー1. 原因を確認するdocker ログ ネクサス2. エラーの原因OpenJDK ...

Windows Server 2008R2、2012、2016、2019 の違い

目次共通バージョンの紹介共通バージョンのダウンロードアドレスとインストール以下に簡単な違いを示します...

JavaScript フロー制御 (分岐)

目次1. プロセス制御2. シーケンシャルプロセス制御3. 分岐フロー制御if文1. 支店構造2. ...

MySQL 5.7.27 winx64 のインストールと設定方法のグラフィックチュートリアル

この記事では、MySQL 5.7.27 winx64のインストールと設定方法を参考までに紹介します。...

Dockerfileを使用して独自のイメージを作成する方法

1. 空のディレクトリを作成する $ cd /home/xm6f/dev $ mkdir myapp...

OCSP を有効にすると、https 証明書の検証効率が向上し、Let's Encrypt SSL 証明書へのアクセスが遅くなる問題が解決されます。

ここ数日、ウェブサイトを初めて開いたときにアクセスが非常に遅いのですが、その後はページが正常に開きま...

DIV、テーブル、XHTML のウェブサイト構築の違いの分析と説明

簡単に言えば、ウェブサイト構築とは、「この人はどんな外見をしているのか」と「この人はどんな内面を持っ...

MySQL 増分バックアップとブレークポイントリカバリスクリプトの例

導入増分バックアップとは、完全バックアップまたは最後の増分バックアップの後、後続の各バックアップでは...