001/* 002 * Copyright (c) 2009 The openGion Project. 003 * 004 * Licensed under the Apache License, Version 2.0 (the "License"); 005 * you may not use this file except in compliance with the License. 006 * You may obtain a copy of the License at 007 * 008 * http://www.apache.org/licenses/LICENSE-2.0 009 * 010 * Unless required by applicable law or agreed to in writing, software 011 * distributed under the License is distributed on an "AS IS" BASIS, 012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, 013 * either express or implied. See the License for the specific language 014 * governing permissions and limitations under the License. 015 */ 016package org.opengion.plugin.table; 017 018/** 019 * TableFilter_SEQUENCE_DERBY は、TableUpda インターフェースを継承した、DBTableModel 処理用の 020 * 実装クラスです。 021 * 022 * ここでは、シーケンス一覧の検索結果より、GF09 のシーケンス定義テーブルから 023 * 必要な情報を取得し、シーケンス作成スクリプトを作成します。 024 * 025 * この処理を実行するには、DBTableModelのカラムとして、 026 * SEQNAME,INCREBY,STARTVAL,MINVAL,MAXVAL,FGCYCLE,SUCACHE 027 * が必要です。 028 * 029 * ※MySQLに対して生成されるスクリプトでは、INCREBY,MINVAL,MAXVAL,FGCYCLE,SUCACHEは無視されます。 030 * なお、MySQLではシーケンスはサポートされていないため、シーケンス名と同じ名前のシーケンス採番テーブルを生成し、 031 * これを1ずつ加算してアップデートすることで、シーケンスをエミュレートします。 032 * 033 * @og.rev 6.4.5.0 (2016/04/08) 新規作成 034 * @og.rev 6.8.1.0 (2017/07/14) JAVADB → DERBY に変更 035 * 036 * @version 6.4.5.0 (2016/04/08) 037 * @author Kazuhiko Hasegawa 038 * @since JDK1.8, 039 */ 040public class TableFilter_SEQUENCE_DERBY extends TableFilter_SEQUENCE { 041 /** このプログラムのVERSION文字列を設定します。 {@value} */ 042 private static final String VERSION = "6.8.1.0 (2017/07/14)" ; 043 044 /** 045 * デフォルトコンストラクター 046 * 047 * @og.rev 6.4.5.0 (2016/04/08) 新規作成 048 * @og.rev 6.8.1.0 (2017/07/14) JAVADB → DERBY に変更 049 */ 050 public TableFilter_SEQUENCE_DERBY() { super(); } // これも、自動的に呼ばれるが、空のメソッドを作成すると警告されるので、明示的にしておきます。 051 052 /** 053 * シーケンス作成の処理を実行します。 054 * 055 * INSERTする度に自動的に増加していく番号で定義するので、通常のシーケンスは作成しません。 056 * ただし、現在値をクリア・変更(採番を再スタート)するためのスクリプトを作成しておきます。 057 * 実行時には、コミットも必要です。 058 * 059 * @og.rev 6.4.5.0 (2016/04/08) 新規作成 060 * 061 * @param clmNo カラム番号配列 062 * @param data 1行分のデータ配列 063 * 064 * @return シーケンス作成 065 * @og.rtnNotNull 066 */ 067 @Override 068 protected String makeLineList( final int[] clmNo,final String[] data ) { 069 return ""; 070 } 071}