com.xiaoleilu.hutool.db.sql.SqlExecutor Maven / Gradle / Ivy
package com.xiaoleilu.hutool.db.sql;
import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import com.xiaoleilu.hutool.db.DbUtil;
import com.xiaoleilu.hutool.db.handler.RsHandler;
/**
* SQL执行器,全部为静态方法,执行查询或非查询的SQL语句
* 此方法为JDBC的简单封装,与数据库类型无关
* @author loolly
*
*/
public class SqlExecutor {
/**
* 执行非查询语句
* 语句包括 插入、更新、删除
* 此方法不会关闭Connection
*
* @param conn 数据库连接对象
* @param sql SQL
* @param params 参数
* @return 影响的行数
* @throws SQLException
*/
public static int execute(Connection conn, String sql, Object... params) throws SQLException {
PreparedStatement ps = null;
try {
ps = conn.prepareStatement(sql);
return executeUpdate(ps, params);
} catch (SQLException e) {
throw e;
} finally {
DbUtil.close(ps);
}
}
/**
* 执行调用存储过程
* 此方法不会关闭Connection
*
* @param conn 数据库连接对象
* @param sql SQL
* @param params 参数
* @return 是否成功
* @throws SQLException
*/
public static boolean call(Connection conn, String sql, Object... params) throws SQLException {
CallableStatement ps = null;
try {
ps = conn.prepareCall(sql);
return execute(ps, params);
} catch (SQLException e) {
throw e;
} finally {
DbUtil.close(ps);
}
}
/**
* 执行非查询语句,返回主键
* 发查询语句包括 插入、更新、删除
* 此方法不会关闭Connection
*
* @param conn 数据库连接对象
* @param sql SQL
* @param params 参数
* @return 主键
* @throws SQLException
*/
public static Long executeForGeneratedKey(Connection conn, String sql, Object... params) throws SQLException {
PreparedStatement ps = null;
try {
ps = conn.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);
executeUpdate(ps, params);
ResultSet rs = ps.getGeneratedKeys();
if(rs != null && rs.next()) {
try {
return rs.getLong(1);
} catch (SQLException e) {
//可能会出现没有主键返回的情况
}
}
return null;
} catch (SQLException e) {
throw e;
} finally {
DbUtil.close(ps);
}
}
/**
* 批量执行非查询语句
* 语句包括 插入、更新、删除
* 此方法不会关闭Connection
*
* @param conn 数据库连接对象
* @param sql SQL
* @param paramsBatch 批量的参数
* @return 每个SQL执行影响的行数
* @throws SQLException
*/
public static int[] executeBatch(Connection conn, String sql, Object[]... paramsBatch) throws SQLException {
PreparedStatement ps = null;
try {
ps = conn.prepareStatement(sql);
for (Object[] params : paramsBatch) {
DbUtil.fillParams(ps, params);
ps.addBatch();
}
return ps.executeBatch();
} catch (SQLException e) {
throw e;
} finally {
DbUtil.close(ps);
}
}
/**
* 执行查询语句
* 此方法不会关闭Connection
*
* @param conn 数据库连接对象
* @param sql 查询语句
* @param rsh 结果集处理对象
* @param params 参数
* @return 结果对象
* @throws SQLException
*/
public static T query(Connection conn, String sql, RsHandler rsh, Object... params) throws SQLException {
PreparedStatement ps = null;
try {
ps = conn.prepareStatement(sql);
return query(ps, rsh, params);
} catch (SQLException e) {
throw e;
} finally {
DbUtil.close(ps);
}
}
//-------------------------------------------------------------------------------------- Execute With PreparedStatement
/**
* 执行非查询语句
* 语句包括 插入、更新、删除
* 此方法不会关闭PreparedStatement
*
* @param ps PreparedStatement对象
* @param params 参数
* @return 影响的行数
* @throws SQLException
*/
public static int executeUpdate(PreparedStatement ps, Object... params) throws SQLException {
DbUtil.fillParams(ps, params);
return ps.executeUpdate();
}
/**
* 执行非查询语句
* 语句包括 插入、更新、删除
* 此方法不会关闭PreparedStatement
*
* @param ps PreparedStatement对象
* @param params 参数
* @return 影响的行数
* @throws SQLException
*/
public static boolean execute(PreparedStatement ps, Object... params) throws SQLException {
DbUtil.fillParams(ps, params);
return ps.execute();
}
/**
* 执行查询语句
* 此方法不会关闭PreparedStatement
*
* @param ps PreparedStatement
* @param rsh 结果集处理对象
* @param params 参数
* @return 结果对象
* @throws SQLException
*/
public static T query(PreparedStatement ps, RsHandler rsh, Object... params) throws SQLException {
ResultSet rs = null;
try {
DbUtil.fillParams(ps, params);
rs = ps.executeQuery();
return rsh.handle(rs);
} catch (SQLException e) {
throw e;
} finally {
DbUtil.close(rs);
}
}
/**
* 执行查询语句并关闭PreparedStatement
*
* @param ps PreparedStatement
* @param rsh 结果集处理对象
* @param params 参数
* @return 结果对象
* @throws SQLException
*/
public static T queryAndClosePs(PreparedStatement ps, RsHandler rsh, Object... params) throws SQLException {
try {
return query(ps, rsh, params);
} catch (SQLException e) {
throw e;
}finally{
DbUtil.close(ps);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy