Statistics
| Revision:

svn-gvsig-desktop / trunk / org.gvsig.desktop / org.gvsig.desktop.compat.cdc / org.gvsig.fmap.dal / org.gvsig.fmap.dal.db / org.gvsig.fmap.dal.db.jdbc / src / main / java / org / gvsig / fmap / dal / store / jdbc / exception / JDBCExecutePreparedSQLException.java @ 40596

History | View | Annotate | Download (2.76 KB)

1
/**
2
 * gvSIG. Desktop Geographic Information System.
3
 *
4
 * Copyright (C) 2007-2013 gvSIG Association.
5
 *
6
 * This program is free software; you can redistribute it and/or
7
 * modify it under the terms of the GNU General Public License
8
 * as published by the Free Software Foundation; either version 3
9
 * of the License, or (at your option) any later version.
10
 *
11
 * This program is distributed in the hope that it will be useful,
12
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
 * GNU General Public License for more details.
15
 *
16
 * You should have received a copy of the GNU General Public License
17
 * along with this program; if not, write to the Free Software
18
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 * For any additional information, do not hesitate to contact us
22
 * at info AT gvsig.com, or visit our website www.gvsig.com.
23
 */
24
package org.gvsig.fmap.dal.store.jdbc.exception;
25

    
26
import java.sql.SQLException;
27
import java.util.List;
28

    
29

    
30
/**
31
 * @author jmvivo
32
 *
33
 */
34
public class JDBCExecutePreparedSQLException extends JDBCException {
35

    
36
        /**
37
         *
38
         */
39
        private static final long serialVersionUID = 634889167216570034L;
40

    
41
        private final static String MESSAGE_FORMAT = "An JDBC exception was throw when execute SQL: '%(sql)' with params %(params)";
42
        private final static String MESSAGE_KEY = "_JDBCExecutePreparedSQLException";
43

    
44
        public JDBCExecutePreparedSQLException(String sql, Object[] parameters,
45
                        SQLException cause) {
46
                super(MESSAGE_FORMAT, cause, MESSAGE_KEY, serialVersionUID);
47
                setValue("sql", sql);
48
                String params = "{unknow}";
49
                if (parameters != null) {
50

    
51
                        StringBuilder strb = new StringBuilder();
52
                        strb.append('[');
53
                        for (int i = 0; i < parameters.length - 1; i++) {
54
                                strb.append(getParamValue(parameters[i]));
55
                                strb.append(", ");
56
                        }
57
                        strb.append(getParamValue(parameters[parameters.length - 1]));
58
                        strb.append(']');
59
                        params = strb.toString();
60
                }
61
                setValue("params", params);
62
        }
63

    
64
        public JDBCExecutePreparedSQLException(String sql, List parameters,
65
                        SQLException cause) {
66
                super(MESSAGE_FORMAT, cause, MESSAGE_KEY, serialVersionUID);
67
                setValue("sql", sql);
68
                String params = "{unknow}";
69
                if (parameters != null) {
70

    
71
                        StringBuilder strb = new StringBuilder();
72
                        strb.append('[');
73
                        for (int i = 0; i < parameters.size() - 1; i++) {
74
                                strb.append(getParamValue(parameters.get(i)));
75
                                strb.append(", ");
76
                        }
77
                        strb.append(getParamValue(parameters.get(parameters.size() - 1)));
78
                        strb.append(']');
79
                        params = strb.toString();
80
                }
81
                setValue("params", params);
82
        }
83

    
84
        private String getParamValue(Object param) {
85

    
86
                if (param instanceof String) {
87
                        return "'" + param + "'";
88
                }
89
                if (param == null) {
90
                        return "null";
91
                }
92
                return param.toString();
93
        }
94

    
95
}