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.util.Calendar; 019 // import java.util.Locale; 020 // import java.text.DateFormat; 021 // import java.text.SimpleDateFormat; 022 023 import org.opengion.fukurou.util.ErrorMessage; 024 import org.opengion.fukurou.util.HybsDateUtil; 025 import org.opengion.hayabusa.db.DBTypeCheckUtil; 026 027 /** 028 * æ–?—å?ã®æ—¥ä»˜å±žæ?(å¹´/æœ?ã®åŠè§’ã?日付を扱ã?‚ºã®ã€ã‚«ãƒ©ãƒ?±žæ?を定義ã—ã¾ã™ã? 029 * 030 * yyyyMM ã«å¯¾å¿œã—ã¦ã?‚‹å¿?¦ãŒã‚りã¾ã™ã? 031 * "000000" ã¨ã€?999999" ã¯ã€å¸¸ã«è¨±å¯ã«ãªã‚Šã¾ã™ã? 032 * ãŸã ã—ã?日付ã?æ•´åˆæ?ãƒã‚§ãƒ?‚¯ã¯è¡Œã„ã¾ã›ã‚“ãŒã?valueAdd( String value )ã«ã‚ˆã‚‹ 033 * æ—¥ä»?æœ?ã®åŠ?®—時ã«ã¯ã€?000XX 㨠9999XX ã¯ã€åŠ ç®—ã•れãšã€ãれ以外ã?ã€? 034 * æ£å¼ãªæ—¥ä»˜ã§åŠ?®—ã•れã¾ã™ã? 035 * 036 * タイプãƒã‚§ãƒ?‚¯ã¨ã—ã¦ã€ä»¥ä¸‹ã?æ¡ä»¶ã‚’判定ã—ã¾ã™ã? 037 * ・æ–?—å?é•·ã¯ã€ç›´æŽ¥è¨ˆç®—ã§æ–?—æ•°ã¨ã®æ¯”è¼? 038 * ・日付使用æ–?—ãƒã‚§ãƒ?‚¯ã€?'0' > c || '9' < c)以外ã?エラー 039 * ・æ–?—パラメータ㮠æ£è¦è¡¨ç¾ãƒã‚§ãƒ?‚¯ 040 * 041 * @og.rev 3.6.0.0 (2004/09/17) æ–°è¦ä½œæ? 042 * @og.group ãƒ??タ属æ? 043 * 044 * @version 4.0 045 * @author Kazuhiko Hasegawa 046 * @since JDK5.0, 047 */ 048 public class DBType_YM extends DBType_YMD { 049 //* ã“ã?プãƒã‚°ãƒ©ãƒ??VERSIONæ–?—å?ã‚’è¨å®šã—ã¾ã™ã? {@value} */ 050 private static final String VERSION = "5.6.6.0 (2013/07/05)" ; 051 052 /** 053 * Stringå¼•æ•°ã®æ–?—å?を+1ã—ãŸæ–‡å—å?ã‚’è¿”ã—ã¾ã™ã? 054 * ã“ã“ã§ã¯ã€yyyyMM å½¢å¼ã?ãƒ??ã‚¿ã«ã€?¼‹ï¼?ã™ã‚‹ã®ã§ã€æœˆã‚’+1ã—ã¾ã™ã? 055 * 056 * 0000XX ã¨ã€?999XX ã¯ã€å¼•æ•°ã®å€¤ãã?ã¾ã¾ã‚’è¿”ã—ã¾ã™ã? 057 * 引数ã?null ã®å ´åˆã¨ã€ã‚¼ãƒæ–?—å?("")ã®å ´åˆã?,物ç?š„åˆæœŸè¨å®šå?(String getDefault()) 058 * ã®å€¤ã‚’è¿”ã—ã¾ã™ã? 059 * ãれ以外ã?å ´åˆã?ã€æ—¥ä»˜è¨ˆç®—を行ã„ã€æœˆã‚’åŠ ç®—ã—ã¾ã™ã?よã£ã¦ã€å¹´æœˆãƒ•ォーマット㫠060 * åˆã‚ãªã?ƒ‡ãƒ¼ã‚¿ã‚’指定ã—ãŸå?åˆã?ã€ã‚¨ãƒ©ãƒ¼ã«ãªã‚Šã¾ã™ã?ã§ã€ã”注æ„ãã?•ã?? 061 * 062 * @og.rev 5.5.7.2 (2012/10/09) HybsDateUtil を利用ã™ã‚‹ã‚ˆã†ã«ä¿®æ£ã—ã¾ã™ã? 063 * 064 * @param value Stringå¼•æ•°ã®æ–?—å? 065 * 066 * @return Stringå¼•æ•°ã®æ–?—å?を+1ã—ãŸæ–‡å—å? 067 */ 068 @Override 069 public String valueAdd( final String value ) { 070 if( value == null || value.length() == 0 ) { return getDefault(); } 071 if( value.startsWith( "0000" ) || value.startsWith( "9999" ) ) { return value; } // 特別ãªå€¤ 072 073 return HybsDateUtil.getMonthPlus( value , 1 ); // 5.5.7.2 (2012/10/09) HybsDateUtil を利用 074 075 // Calendar cal = Calendar.getInstance(); 076 // 077 // int year = Integer.parseInt( value.substring( 0,4 ) ); 078 // int month = Integer.parseInt( value.substring( 4,6 ) ) - 1; 079 // 080 // cal.set( year,month,1 ); 081 // cal.add( Calendar.MONTH , 1 ); // 月を?‘月åŠ?®—ã—ã¾ã™ã? 082 // 083 // DateFormat formatter = new SimpleDateFormat( "yyyyMM",Locale.JAPAN ); 084 // return formatter.format( cal.getTime() ); 085 } 086 087 /** 088 * Stringå¼•æ•°ã®æ–?—å?ã«ã€ç¬¬?’å¼•æ•°ã«æŒ?®šã?æ–?—å?(æ•°å—ã?日付ç?ã‚’åŠ ç®—ã—ã¦è¿”ã—ã¾ã™ã? 089 * 090 * ã“ã“ã§ã¯ã€yyyyMM å½¢å¼ã?ãƒ??ã‚¿ã«ã€æœˆã‚’åŠ ç®—ã—ã¾ã™ã? 091 * 0000XX ã¨ã€?999XX ã¯ã€å¼•æ•°ã®å€¤ãã?ã¾ã¾ã‚’è¿”ã—ã¾ã™ã? 092 * 引数ã?null ã®å ´åˆã¨ã€ã‚¼ãƒæ–?—å?("")ã®å ´åˆã?,物ç?š„åˆæœŸè¨å®šå?(String getDefault()) 093 * ã®å€¤ã‚’è¿”ã—ã¾ã™ã? 094 * ãれ以外ã?å ´åˆã?ã€æ—¥ä»˜è¨ˆç®—を行ã„ã€æœˆã‚’åŠ ç®—ã—ã¾ã™ã?よã£ã¦ã€å¹´æœˆãƒ•ォーマット㫠095 * åˆã‚ãªã?ƒ‡ãƒ¼ã‚¿ã‚’指定ã—ãŸå?åˆã?ã€ã‚¨ãƒ©ãƒ¼ã«ãªã‚Šã¾ã™ã?ã§ã€ã”注æ„ãã?•ã?? 096 * 097 * @og.rev 5.6.0.3 (2012/01/24) ADD ã«ã€å¼•æ•°ã®å€¤ã‚’åŠ ç®—ã™ã‚‹æ©Ÿè?を追åŠ?—ã¾ã™ã? 098 * 099 * @param value String引数 100 * @param add åŠ?®—ã™ã‚‹æœˆæ–?—å? 101 * 102 * @return å¼•æ•°ã®æ–?—å?ã«æœˆã‚’åŠ?®—ã—ã¾ã™ã? 103 */ 104 @Override 105 public String valueAdd( final String value,final String add ) { 106 if( value == null || value.length() == 0 ) { return getDefault(); } 107 if( value.startsWith( "0000" ) || value.startsWith( "9999" ) ) { return value; } // 特別ãªå€¤ 108 109 int addSu = 1; 110 if( add != null && !add.isEmpty() ) { 111 addSu = Integer.parseInt( add ); 112 } 113 114 return HybsDateUtil.getMonthPlus( value , addSu ); 115 } 116 117 /** 118 * エãƒ?‚£ã‚¿ãƒ¼ã§ç·¨é›?•れãŸãƒ??タを登録ã™ã‚‹å ´åˆã«ã€ãƒ‡ãƒ¼ã‚¿ãã?ã‚‚ã?ã‚? 119 * 変æ›ã—ã¦ã€å®Ÿç™»éŒ²ãƒ??タを作æ?ã—ã¾ã™ã? 120 * 例ãˆã°,大æ–?—ã?ã¿ã®ãƒ•ィールドãªã‚‰ã?大æ–?—化ã—ã¾ã™ã? 121 * 実登録ãƒ??ã‚¿ã®ä½œæ?ã¯ã€DBType オブジェクトを利用ã—ã¾ã™ã?ã§, 122 * ã“れ㨠Editor ã¨ãŒã‚¢ãƒ³ãƒžãƒƒãƒã?å ´åˆã?ã€ã†ã¾ããƒ‡ãƒ¼ã‚¿å¤‰æ› 123 * ã•れãªã?¯èƒ½æ€§ãŒã‚りã¾ã™ã?ã§ã€æ³¨æ„願ã„ã¾ã™ã? 124 * 125 * @og.rev 5.5.7.2 (2012/10/09) HybsDateUtil を利用ã™ã‚‹ã‚ˆã†ã«ä¿®æ£ã—ã¾ã™ã? 126 * @og.rev 5.6.6.0 (2013/07/05) parseDate を改é€?—ã€æ—¥ä»˜ã?æ¡æ•°æŒ?®šã‚’厳å¯?«åˆ¤å®šã—ã¾ã™ã? 127 * 128 * @param value (ä¸?ˆ¬ã«ç·¨é›?ƒ‡ãƒ¼ã‚¿ã¨ã—ã¦ç™»éŒ²ã•れãŸãƒ‡ãƒ¼ã‚¿) 129 * @return ä¿®æ£å¾Œã?æ–?—å?(ä¸?ˆ¬ã«ãƒ??タベã?スã«ç™»éŒ²ã™ã‚‹ãƒ??ã‚¿) 130 */ 131 @Override 132 public String valueSet( final String value ) { 133 if( value == null || value.length() == 0 ) { return getDefault(); } 134 135 return HybsDateUtil.parseDate( value , 6 ); // ä¸è¦ãªè¨˜å·ç‰ã‚’削除ã—ã?æ¡æ•°ã‚’ãã‚ãˆã‚‹ã? 136 137 // String rtn = ( value == null ) ? "" : value.trim(); 138 // 139 // if( rtn.length() == 4 ) { rtn = "20" + rtn ; } 140 // else if( rtn.length() > 6 ) { rtn = rtn.substring(0,6) ; } 141 // else if( rtn.startsWith( "0000" ) ) { rtn = "000001"; } 142 // else if( rtn.startsWith( "9999" ) ) { rtn = "999912"; } 143 // 144 // return rtn; 145 } 146 147 /** 148 * ãƒ??ã‚¿ãŒç™»éŒ²å¯èƒ½ã‹ã©ã?‹ã‚’ãƒã‚§ãƒ?‚¯ã—ã¾ã™ã? 149 * ãƒ??ã‚¿ãŒã‚¨ãƒ©ãƒ¼ã®å ´åˆã?ã€ãã®ã‚¨ãƒ©ãƒ¼å†?®¹ã‚’è¿”ã—ã¾ã™ã? 150 * "000000" ã¨ã€?999999" ã¯ã€å¸¸ã«è¨±å¯ã«ãªã‚Šã¾ã™ã? 151 * 152 * @og.rev 5.6.0.3 (2012/01/24) 日付ãƒã‚§ãƒ?‚¯ã®æ•´åˆæ?ã¾ã§å«ã‚ãŸãƒã‚§ãƒ?‚¯ã‚’å?れるã€? 153 * 154 * @param key ã‚ー 155 * @param value 値 156 * @param sizeX 整数部åˆ??æ–?—å?ã®é•·ã? 157 * @param sizeY 少数部åˆ??æ–?—å?ã®é•·ã? 158 * @param typeParam dbType パラメータ 159 * @param isStrict 厳å¯?«ãƒã‚§ãƒ?‚¯ã™ã‚‹ã‹ã©ã?‹[true:ã™ã‚‹/false:標準的] 160 * 161 * @return エラーå†?®¹ 162 */ 163 @Override 164 public ErrorMessage valueCheck( final String key ,final String value , 165 final int sizeX ,final int sizeY ,final String typeParam ,final boolean isStrict) { 166 167 ErrorMessage msg = new ErrorMessage(); 168 if( value == null || value.length() == 0 ) { return msg; } 169 170 int len = (sizeY == 0) ? sizeX : sizeX + sizeY + 1; 171 // 厳å¯?«ä¸??ã—ãªã?¨ã‚¨ãƒ©ãƒ¼ã¨ã™ã‚‹ã€? 172 if( len != value.length() ) { 173 // æ–?—å?ã®é•·ã•ãŒæŒ?®šã?é•·ã•ã¨ç•°ãªã‚Šã¾ã™ã? 174 msg.addMessage( 0,ErrorMessage.NG,"ERR0011", key,value, 175 String.valueOf( value.length() ), String.valueOf( len ) ); 176 } 177 178 // 5.6.0.3 (2012/01/24) æ–?—ã?ç¯?›²ãƒã‚§ãƒ?‚¯ 179 String check = DBTypeCheckUtil.rangeCheck( value, '0', '9' ); 180 if( check != null ) { 181 // æŒ?®šã?æ–?—以外ã?æ–?—ãŒä½¿ã‚れã¦ã?¾ã™ã? 182 msg.addMessage( 0,ErrorMessage.NG,"ERR0009", key,check ); 183 } 184 185 // 5.6.0.3 (2012/01/24) 日付文å—ã?æ•´åˆæ?ãƒã‚§ãƒ?‚¯ 186 // "0000","9999" ã§å§‹ã¾ã‚‹æ—¥ä»˜ã?未æ¡ä»¶è¨±å¯ã€? 187 check = DBTypeCheckUtil.ymdFormatCheck( value ); 188 if( check != null ) { 189 // æŒ?®šã?æ–?—以外ã?æ–?—ãŒä½¿ã‚れã¦ã?¾ã™ã? 190 msg.addMessage( 0,ErrorMessage.NG,"ERR0009", key,check ); 191 } 192 193 // 3.6.0.0 (2004/09/22) dbType パラメータを使用ã—ãŸãƒžãƒƒãƒãƒã‚§ãƒ?‚¯ 194 check = DBTypeCheckUtil.matcheCheck( value,typeParam ); 195 if( check != null ) { 196 // æŒ?®šã?æ–?—以外ã?æ–?—ãŒä½¿ã‚れã¦ã?¾ã™ã? 197 msg.addMessage( 0,ErrorMessage.NG,"ERR0009", key,check ); 198 } 199 200 return msg; 201 } 202 }