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 */ 016 package org.opengion.plugin.column; 017 018 // import java.text.DateFormat; 019 // import java.text.SimpleDateFormat; 020 // import java.util.Calendar; 021 // import java.util.Locale; 022 023 import org.opengion.fukurou.model.NativeType; 024 import org.opengion.fukurou.util.ErrorMessage; 025 import org.opengion.fukurou.util.StringUtil; 026 import org.opengion.fukurou.util.HybsDateUtil; 027 import org.opengion.hayabusa.common.HybsSystemException; 028 import org.opengion.hayabusa.db.AbstractDBType; 029 import org.opengion.hayabusa.db.DBTypeCheckUtil; 030 031 /** 032 * æ–?—å?ã®é–‹å§‹æ—¥ä»˜å±žæ?ã‚’è¦å®šã™ã‚‹åŠè§’æ–‡å—å?を扱ã?‚ºã®ã€ã‚«ãƒ©ãƒ?±žæ?を定義ã—ã¾ã™ã? 033 * 登録時ã«0000XXXXã¯00000101ã€?999XXXXã¯99991231ã€ãれ以外ã?YYYYMM01ã¨å¤‰æ›ã—ã¾ã™ã? 034 * 035 * YYYYMM01 ã¾ãŸã?ã€?0000XXXX , 9999XXXX を許å¯ã—ã¾ã™ã? 036 * ã¾ãŸã?入力データã¨ã—ã¦, YYYYMM å½¢å¼?ã¯ã€è¨±å¯ã—ã¾ã›ã‚“。ã‚らã‹ã˜ã‚, 037 * valueSet( String ) ã§ãƒ??タを変æ›ã—ã¦ãŠãå¿?¦ãŒã‚りã¾ã™ã? 038 * ãŸã ã—ã?日付ã¨ã—ã¦ã®æ•´åˆæ?ãƒã‚§ãƒ?‚¯ã¯è¡Œã„ã¾ã›ã‚“ã€? 039 * 040 * タイプãƒã‚§ãƒ?‚¯ã¨ã—ã¦ã€ä»¥ä¸‹ã?æ¡ä»¶ã‚’判定ã—ã¾ã™ã? 041 * ・æ–?—å?é•·ã¯ã€ç›´æŽ¥è¨ˆç®—ã§æ–?—æ•°ã¨ã®æ¯”è¼? 042 * ・日付使用æ–?—ãƒã‚§ãƒ?‚¯ã€?'0' > c || '9' < c)以外ã?エラー 043 * ・æ–?—パラメータ㮠æ£è¦è¡¨ç¾ãƒã‚§ãƒ?‚¯ 044 * 045 * @og.rev 5.4.3.6 (2012/01/19) ã‚³ãƒ¡ãƒ³ãƒˆä¿®æ£ 046 * @og.group ãƒ??タ属æ? 047 * 048 * @version 4.0 049 * @author Kazuhiko Hasegawa 050 * @since JDK5.0, 051 */ 052 public class DBType_YM01 extends AbstractDBType { 053 //* ã“ã?プãƒã‚°ãƒ©ãƒ??VERSIONæ–?—å?ã‚’è¨å®šã—ã¾ã™ã? {@value} */ 054 private static final String VERSION = "5.6.6.0 (2013/07/05)" ; 055 056 private static final String DEF_VALUE = "00000000" ; // ãƒ??ã‚¿ã®ãƒ?ƒ•ォルトå? 057 058 /** 059 * ãƒ?ƒ•ォルトコンストラクター 060 * 061 * @og.rev 4.0.0.0 (2005/01/31) type å»?¢ 062 */ 063 public DBType_YM01() { 064 super( DEF_VALUE ); 065 } 066 067 /** 068 * NATIVEã®åž‹ã?è˜åˆ¥ã‚³ãƒ¼ãƒ‰ã‚’è¿”ã—ã¾ã™ã? 069 * 070 * @og.rev 3.8.5.3 (2006/08/07) æ–°è¦ä½œæ? 071 * @og.rev 4.1.1.2 (2008/02/28) Enumåž?fukurou.model.NativeType)ã«å¤‰æ›´ 072 * 073 * @return NATIVEã®åž‹ã?è˜åˆ¥ã‚³ãƒ¼ãƒ?DBType ã§è¦å®? 074 * @see org.opengion.fukurou.model.NativeType 075 */ 076 @Override 077 public NativeType getNativeType() { 078 return NativeType.CALENDAR; 079 } 080 081 /** 082 * åŠè§’スペã?スã§å›ºå®šé•·(åŠè§’æ›ç®—ã?æ•°)ã«å¤‰æ›ã—ãŸæ–?—å?ã‚’è¿”ã—ã¾ã™ã? 083 * ãªãŠã?エラーãƒã‚§ãƒ?‚¯ã¯è¡Œã‚れã¾ã›ã‚“ã€? 084 * 実行å‰ã«ã€å¿?š valueCheck( String value ,int len ) ãŒè¡Œã‚れるå¿?¦ãŒã‚りã¾ã™ã? 085 * 086 * @og.rev 3.5.4.5 (2004/01/23) エンコード指定ã«å¤‰æ›´ã—ã¾ã™ã? 087 * 088 * @param value ?¦?©?¬?¬åŸ‹ã‚ã™ã‚‹æ–?—å? 089 * @param sizeX 整数部åˆ??æ–?—å?ã®é•·ã? 090 * @param sizeY 少数部åˆ??æ–?—å?ã®é•·ã? 091 * @param encode 固定長ã§å¤‰æ›ã™ã‚‹æ–?—エンコーãƒ? 092 * 093 * @return ?¦?©?¬?¬åŸ‹ã‚ã—ãŸæ–°ã—ã„æ–?—å? 094 */ 095 @Override 096 public String valueFill( final String value ,final int sizeX ,final int sizeY,final String encode ) { 097 if( value != null && value.length() >= sizeX ) { 098 return value.substring( 0, sizeX ); 099 } 100 101 String errMsg = "æŒ?®šæ–‡å—ãŒä¸æ£ã§ã™ã?value=[" + value + "] length=[" + sizeX + "]"; 102 throw new HybsSystemException( errMsg ); 103 } 104 105 /** 106 * Stringå¼•æ•°ã®æ–?—å?を+1ã—ãŸæ–‡å—å?ã‚’è¿”ã—ã¾ã™ã? 107 * ã“ã“ã§ã¯ã€YYYYMM å½¢å¼ã?ãƒ??ã‚¿ã«ã€?¼‹ï¼?ã™ã‚‹ã®ã§ã€æœˆã‚’+1ã—ã¾ã™ã? 108 * 109 * 0000XX ã¨ã€?999XX ã¯ã€å¼•æ•°ã®å€¤ãã?ã¾ã¾ã‚’è¿”ã—ã¾ã™ã? 110 * 引数ã?null ã®å ´åˆã¨ã€ã‚¼ãƒæ–?—å?("")ã®å ´åˆã?,物ç?š„åˆæœŸè¨å®šå?(String getDefault()) 111 * ã®å€¤ã‚’è¿”ã—ã¾ã™ã? 112 * ãれ以外ã?å ´åˆã?ã€æ—¥ä»˜è¨ˆç®—を行ã„ã€æœˆã‚’åŠ ç®—ã—ã¾ã™ã?よã£ã¦ã€å¹´æœˆãƒ•ォーマット㫠113 * åˆã‚ãªã?ƒ‡ãƒ¼ã‚¿ã‚’指定ã—ãŸå?åˆã?ã€ã‚¨ãƒ©ãƒ¼ã«ãªã‚Šã¾ã™ã?ã§ã€ã”注æ„ãã?•ã?? 114 * 115 * @og.rev 3.6.0.0 (2004/09/17) 月ã?åŠ?®—ãƒã‚¸ãƒ?‚¯ã®èª¤ã‚Šä¿®æ£ã€?roll â‡?add) 116 * @og.rev 5.5.7.2 (2012/10/09) HybsDateUtil を利用ã™ã‚‹ã‚ˆã†ã«ä¿®æ£ã—ã¾ã™ã? 117 * 118 * @param value Stringå¼•æ•°ã®æ–?—å? 119 * 120 * @return Stringå¼•æ•°ã®æ–?—å?を+1ã—ãŸæ–‡å—å? 121 */ 122 @Override 123 public String valueAdd( final String value ) { 124 if( value == null || value.length() == 0 ) { return getDefault(); } 125 if( value.startsWith( "0000" ) || value.startsWith( "9999" ) ) { return value; } 126 127 return HybsDateUtil.getMonthPlus( value , 1 ) + "01"; // 5.5.7.2 (2012/10/09) HybsDateUtil を利用 128 129 // Calendar cal = Calendar.getInstance(); 130 // 131 // int year = Integer.parseInt( value.substring( 0,4 ) ); 132 // int month = Integer.parseInt( value.substring( 4,6 ) ) - 1; 133 // int date = Integer.parseInt( value.substring( 6,8 ) ); 134 // 135 // cal.set( year,month,date ); 136 // cal.add( Calendar.MONTH, 1 ); // 月を?‘ãƒ¶æœˆåŠ ç®—ã—ã¾ã™ã? 137 // 138 // DateFormat formatter = new SimpleDateFormat( "yyyyMMdd",Locale.JAPAN ); 139 // return formatter.format( cal.getTime() ); 140 } 141 142 /** 143 * å…¥åŠ›ãƒ‡ãƒ¼ã‚¿ã®æ•´åˆæ?ã‚’åˆã‚ã›ãŸçµæžœã‚’è¿”ã—ã¾ã™ã? 144 * ã“ã“ã§ã¯ã€æ—¥ä»˜ãƒ‡ãƒ¼ã‚¿ã«å«ã¾ã‚Œã‚‹ãƒ•ォーマット文å—å?を削除ã—ã?æ•°å—ã ã‘ã? 145 * æ–?—å?を作æ?ã—ã?YYYYMM å½¢å¼ã?å…ˆé??–æ–‡å???"01" ã®ãƒ??タを作æ?ã—ã¾ã™ã? 146 * ã“ã?メソãƒ?ƒ‰ã§ã¯ã€æ—¥ä»˜æ¬??ã€å¿?š "01" ã«ãªã‚Šã¾ã™ã? 147 * 実登録ãƒ??ã‚¿ã®ä½œæ?ã¯ã€DBType オブジェクトを利用ã—ã¾ã™ã?ã§, 148 * ã“れ㨠Editor ã¨ãŒã‚¢ãƒ³ãƒžãƒƒãƒã?å ´åˆã?ã€ã†ã¾ããƒ‡ãƒ¼ã‚¿å¤‰æ› 149 * ã•れãªã?¯èƒ½æ€§ãŒã‚りã¾ã™ã?ã§ã€æ³¨æ„願ã„ã¾ã™ã? 150 * 151 * @og.rev 3.3.3.0 (2003/07/09) å‰å¾Œã?スペã?スをå–り除ã?¦ãŠãã€? 152 * @og.rev 4.3.3.4 (2008/12/01) 0000 or 9999 時ã?ãƒã‚°ä¿®æ£ 153 * @og.rev 5.5.7.2 (2012/10/09) HybsDateUtil を利用ã™ã‚‹ã‚ˆã†ã«ä¿®æ£ã—ã¾ã™ã? 154 * @og.rev 5.6.6.0 (2013/07/05) parseDate を改é€?—ã€æ—¥ä»˜ã?æ¡æ•°æŒ?®šã‚’厳å¯?«åˆ¤å®šã—ã¾ã™ã? 155 * 156 * @param value (ä¸?ˆ¬ã«ç·¨é›?ƒ‡ãƒ¼ã‚¿ã¨ã—ã¦ç™»éŒ²ã•れãŸãƒ‡ãƒ¼ã‚¿) 157 * 158 * @return ä¿®æ£å¾Œã?æ–?—å?(ä¸?ˆ¬ã«ãƒ??タベã?スã«ç™»éŒ²ã™ã‚‹ãƒ??ã‚¿) 159 */ 160 @Override 161 public String valueSet( final String value ) { 162 if( value == null || value.length() == 0 ) { return getDefault(); } 163 164 return HybsDateUtil.parseDate( value , 6 ) + "01"; // ä¸è¦ãªè¨˜å·ç‰ã‚’削除ã—ã?æ¡æ•°ã‚’ãã‚ãˆã‚‹ã? 165 166 // if( value == null ) { return null; } 167 // String rtn = StringUtil.rTrim( value ); // 3.3.3.1 (2003/07/18) 168 // if( rtn.length() >= 6 ) { 169 // rtn = rtn.substring( 0,6 ); 170 // // if( rtn.startsWith( "0000" ) ) { rtn = "000001"; } 171 // // else if( rtn.startsWith( "9999" ) ) { rtn = "999912"; } 172 // if( rtn.startsWith( "0000" ) ) { rtn = "00000101"; } 173 // else if( rtn.startsWith( "9999" ) ) { rtn = "99991231"; } 174 // else { rtn += "01"; } 175 // } 176 // return rtn; 177 } 178 179 /** 180 * ãƒ??ã‚¿ãŒç™»éŒ²å¯èƒ½ã‹ã©ã?‹ã‚’ãƒã‚§ãƒ?‚¯ã—ã¾ã™ã? 181 * ãƒ??ã‚¿ãŒã‚¨ãƒ©ãƒ¼ã®å ´åˆã?ã€ãã®ã‚¨ãƒ©ãƒ¼å†?®¹ã‚’è¿”ã—ã¾ã™ã? 182 * valueSet( String ) ã™ã‚‹ä»¥å‰ã?æ–?—ã«ã¤ã?¦ã¯,æ•´åˆæ?ã¯ä¿è¨¼ã—ã¦ã?¾ã›ã‚“ã€? 183 * 184 * @og.rev 3.6.0.0 (2004/09/22) dbType パラメータを引数ã«è¿½åŠ? 185 * @og.rev 5.2.2.0 (2010/11/01) 厳å¯?«ãƒã‚§ãƒ?‚¯(isStrict=true)ã™ã‚‹ãƒ•ラグを追åŠ? 186 * @og.rev 5.6.0.3 (2012/01/24) 日付ãƒã‚§ãƒ?‚¯ã®æ•´åˆæ?ã¾ã§å«ã‚ãŸãƒã‚§ãƒ?‚¯ã‚’å?れるã€? 187 * 188 * @param key ã‚¿ã‚°ã®ã‚ー(カラãƒ?D) 189 * @param value ãƒã‚§ãƒ?‚¯ã™ã‚‹å€¤ 190 * @param sizeX 整数部åˆ??æ–?—å?ã®é•·ã? 191 * @param sizeY 少数部åˆ??æ–?—å?ã®é•·ã? 192 * @param typeParam dbType パラメータ 193 * @param isStrict 厳å¯?«ãƒã‚§ãƒ?‚¯ã™ã‚‹ã‹ã©ã?‹[true:ã™ã‚‹/false:標準的] 194 * 195 * @return エラーå†?®¹ 196 */ 197 // public ErrorMessage valueCheck( final String key ,final String value , 198 // final int sizeX ,final int sizeY ,final String param ) { 199 @Override 200 public ErrorMessage valueCheck( final String key ,final String value , 201 final int sizeX ,final int sizeY ,final String typeParam ,final boolean isStrict) { 202 203 ErrorMessage msg = new ErrorMessage(); 204 if( value == null || value.length() == 0 ) { return msg; } 205 206 int len = (sizeY == 0) ? sizeX : sizeX + sizeY + 1; 207 // 5.2.2.0 (2010/11/01) 厳å¯?«ãƒã‚§ãƒ?‚¯(isStrict=true)ã™ã‚‹ãƒ•ラグを追åŠ? 208 if( isStrict ) { 209 if( len != value.length() ) { 210 // æ–?—å?ã®é•·ã•ãŒæŒ?®šã?é•·ã•ã¨ç•°ãªã‚Šã¾ã™ã? 211 msg.addMessage( 0,ErrorMessage.NG,"ERR0011", key,value, String.valueOf( value.length() ), String.valueOf( len ) ); 212 } 213 } 214 else { 215 if( len < value.length() ) { 216 // æ–?—å?ã®é•·ã•ãŒæŒ?®šã?é•·ã•よりも長ã?§ã™ã? 217 msg.addMessage( 0,ErrorMessage.NG,"ERR0006",key,value, 218 String.valueOf( value.length() ),String.valueOf( len ) ); 219 } 220 } 221 222 // StringBuilder val = new StringBuilder(); 223 // boolean isError = false; 224 // for( int i=0; i<value.length(); i++ ) { 225 // char ch = value.charAt( i ); 226 // if( ('0' > ch || '9' < ch) ) { 227 // val.append( "<span class=\"NG\">" ).append( ch ).append( "</span>" ); 228 // isError = true; 229 // } 230 // else { 231 // val.append( ch ); 232 // } 233 // } 234 // if( isError ) { 235 // // æŒ?®šã?æ–?—以外ã?æ–?—ãŒä½¿ã‚れã¦ã?¾ã™ã? 236 // msg.addMessage( 0,ErrorMessage.NG,"ERR0009", key,val.toString() ); 237 // } 238 239 // 5.6.0.3 (2012/01/24) æ–?—ã?ç¯?›²ãƒã‚§ãƒ?‚¯ 240 String check = DBTypeCheckUtil.rangeCheck( value, '0', '9' ); 241 if( check != null ) { 242 // æŒ?®šã?æ–?—以外ã?æ–?—ãŒä½¿ã‚れã¦ã?¾ã™ã? 243 msg.addMessage( 0,ErrorMessage.NG,"ERR0009", key,check ); 244 } 245 246 // 5.6.0.3 (2012/01/24) 日付文å—ã?æ•´åˆæ?ãƒã‚§ãƒ?‚¯ 247 // "0000","9999" ã§å§‹ã¾ã‚‹æ—¥ä»˜ã?未æ¡ä»¶è¨±å¯ã€? 248 check = DBTypeCheckUtil.ymdFormatCheck( value ); 249 if( check != null ) { 250 // æŒ?®šã?æ–?—以外ã?æ–?—ãŒä½¿ã‚れã¦ã?¾ã™ã? 251 msg.addMessage( 0,ErrorMessage.NG,"ERR0009", key,check ); 252 } 253 254 // 3.6.0.0 (2004/09/22) dbType パラメータを使用ã—ãŸãƒžãƒƒãƒãƒã‚§ãƒ?‚¯ 255 check = DBTypeCheckUtil.matcheCheck( value,typeParam ); 256 if( check != null ) { 257 // æŒ?®šã?æ–?—以外ã?æ–?—ãŒä½¿ã‚れã¦ã?¾ã™ã? 258 msg.addMessage( 0,ErrorMessage.NG,"ERR0009", key,check ); 259 } 260 261 return msg; 262 } 263 }