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    }