jdbctemplate.java

来自「opennms得相关源码 请大家看看」· Java 代码 · 共 123 行

JAVA
123
字号
//// This file is part of the OpenNMS(R) Application.//// OpenNMS(R) is Copyright (C) 2005 The OpenNMS Group, Inc.  All rights reserved.// OpenNMS(R) is a derivative work, containing both original code, included code and modified// code that was published under the GNU General Public License. Copyrights for modified // and included code are below.//// OpenNMS(R) is a registered trademark of The OpenNMS Group, Inc.//// Original code base Copyright (C) 1999-2001 Oculan Corp.  All rights reserved.//// This program is free software; you can redistribute it and/or modify// it under the terms of the GNU General Public License as published by// the Free Software Foundation; either version 2 of the License, or// (at your option) any later version.//// This program is distributed in the hope that it will be useful,// but WITHOUT ANY WARRANTY; without even the implied warranty of// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the// GNU General Public License for more details.//// You should have received a copy of the GNU General Public License// along with this program; if not, write to the Free Software// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.//// For more information contact:// OpenNMS Licensing       <license@opennms.org>//     http://www.opennms.org///     http://www.opennms.com///package org.opennms.netmgt.utils;import java.sql.Connection;import java.sql.PreparedStatement;import java.sql.SQLException;import org.opennms.netmgt.config.DbConnectionFactory;/** * @author brozow * */abstract public class JDBCTemplate {    private DbConnectionFactory m_db;    private String m_sql;        protected JDBCTemplate(DbConnectionFactory db, String sql) {        m_db = db;        m_sql = sql;    }    public void execute() {         execute(new Object[0]);     }    public void execute(Object o) {         execute(new Object[] { o });     }    public void execute(Object o1, Object o2) {         execute(new Object[] { o1, o2 } );     }        public void execute(Object o1, Object o2, Object o3) {        execute (new Object[] { o1, o2, o3 } );    }        public void execute(Object o1, Object o2, Object o3, Object o4) {        execute (new Object[] { o1, o2, o3, o4 } );    }    public void execute(Object o1, Object o2, Object o3, Object o4, Object o5) {        execute (new Object[] { o1, o2, o3, o4, o5 } );    }    public void execute(Object values[]) {         try {             doExecute(values);         } catch (SQLException e) {             String vals = argsToString(values);             throw new RuntimeException("Problem executing statement: "+m_sql+" with values "+vals, e);         }     }    private String argsToString(Object[] values) {        String vals = "[";         for(int i = 0; i < values.length; i++) {             if (i != 0)                 vals += ", ";             vals += values[i];         }         vals += "]";        return vals;    }    private void doExecute(Object values[]) throws SQLException {                Connection conn = m_db.getConnection();        PreparedStatement stmt = null;         try {                          stmt = conn.prepareStatement(m_sql);             for(int i = 0; i < values.length; i++) {                 stmt.setObject(i+1, values[i]);             }             //ThreadCategory.getInstance(getClass()).debug("SQL: "+m_sql+" with vals "+argsToString(values));             executeStmt(stmt);         } finally {             if (stmt != null)                 stmt.close();                          conn.close();         }    }        abstract void executeStmt(PreparedStatement stmt) throws SQLException;}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?