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.calendar; 017 018import org.opengion.hayabusa.resource.CalendarQuery; 019import org.opengion.fukurou.util.StringUtil; 020 021/** 022 * カレンダDB(GF13)の検索QUERYを定義したクラスです。 023 * 024 * QUERY は、このオブジェクトを、toString() して求めることとします。 025 * 本来は、これらのクラスの共通インターフェースを作成して、getQuery() などのメソッドを 026 * 介して取得すべきですが、Object の共通クラスを利用することとします。 027 * 028 * @og.rev 3.6.0.0 (2004/09/17) 新規作成 029 * @og.group リソース管理 030 * 031 * @version 4.0 032 * @author Kazuhiko Hasegawa 033 * @since JDK5.0, 034 */ 035public final class CalendarQuery_GF13 implements CalendarQuery { 036 /** このプログラムのVERSION文字列を設定します。 {@value} */ 037 private static final String VERSION = "6.9.9.3 (2018/09/25)" ; 038 039 /** カレンダDBの読み込みのクエリー(GF13) {@value} */ 040 public static final String QUERY = 041 "select YYYYMM,DY1,DY2,DY3,DY4,DY5,DY6,DY7,DY8,DY9,DY10," 042 + "DY11,DY12,DY13,DY14,DY15,DY16,DY17,DY18,DY19,DY20," 043 + "DY21,DY22,DY23,DY24,DY25,DY26,DY27,DY28,DY29,DY30,DY31" 044 + " from GF13 where CDJGS=? and FGJ='1'" 045 + " order by YYYYMM" ; 046 047 /** CDJGS:事業所コード の初期値:{@value} */ 048 public static final String DEFAULT_CDJGS = "SYS"; 049 050 /** 051 * デフォルトコンストラクター 052 * 053 * @og.rev 6.4.2.0 (2016/01/29) PMD refactoring. Each class should declare at least one constructor. 054 */ 055 public CalendarQuery_GF13() { super(); } // これも、自動的に呼ばれるが、空のメソッドを作成すると警告されるので、明示的にしておきます。 056 057 /** 058 * 4つの引数を受け取り、整合性チェックを行います。 059 * 引数は、各クラスによって使用するカラム名(意味)が異なります。 060 * また、すべての引数をチェックするのではなく、クラス毎に、チェックする 061 * カラムの数は、異なります。 062 * 063 * @og.rev 6.9.9.3 (2018/09/25) 可変引数に変更します(PMD Rather than using a lot of String arguments, consider using a container object for those values.)。 064 * 065 * @param args データベース検索時の引数( CDJGS:事業所コード のみ) 066// * @param arg1 データベース検索時の第1引数(CDJGS:事業所コード) 067// * @param arg2 データベース検索時の第2引数(未使用) 068// * @param arg3 データベース検索時の第3引数(未使用) 069// * @param arg4 データベース検索時の第4引数(未使用) 070 * 071 * @return 入力パラメータに応じた配列文字列(CDJGS:事業所コード) 072 * @og.rtnNotNull 073 */ 074// public String[] checkArgment( final String arg1,final String arg2,final String arg3,final String arg4 ) { 075// final String cdjgs = StringUtil.nval( arg1,DEFAULT_CDJGS ); 076 @Override // CalendarQuery 077 public String[] checkArgment( final String... args ) { 078 final String cdjgs = args == null || args.length == 0 ? DEFAULT_CDJGS : StringUtil.nval( args[0],DEFAULT_CDJGS ); 079 return new String[] { cdjgs } ; 080 } 081 082 /** 083 * データベース検索の為の Select 文を返します。 084 * 引数リストとともに、使用します。 085 * 086 * @return データベース検索の為の Select 文 087 * @og.rtnNotNull 088 */ 089 @Override // CalendarQuery 090 public String getQuery() { 091 return QUERY; 092 } 093 094 /** 095 * データベースの持ち方を指定します。 096 * 持ち方がフラット(横持ち=1~31の日付をカラムで持つ)の場合、trueを返します。 097 * 縦持ち(日付単位で、行情報として持つ)場合は、false です。 098 * 099 * @return DBの持ち方がフラット(横持ち=1~31の日付をカラムで持つ)の場合、true 100 * 101 */ 102 @Override // CalendarQuery 103 public boolean isFlatTable() { 104 return true; 105 } 106}