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    }