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