private void initParas(String sql, List<Object> paras) throws SQLException { stmt = cont.prepareStatement(sql); if (paras != null && paras.size() > 0) { int index = 1; for (int i = 0; i < paras.size(); i++) { stmt.setObject(index++, paras.get(i)); } } }
时间: 2024-04-03 08:35:57 浏览: 124
这段代码是一个Java类中的私有方法,用于初始化一个预编译的SQL语句的参数。它接受两个参数:一个SQL语句和一个包含参数值的列表。在方法中,首先使用`cont.prepareStatement(sql)`方法创建一个`PreparedStatement`对象`stmt`,该对象表示已经编译好的SQL语句。然后,如果参数列表不为空,就使用`setObject`方法将参数列表中的值逐个设置到`stmt`对象的占位符中。最后,预编译的语句和参数都已经被初始化完成。
预编译语句是一种SQL语句的优化技术,它可以将SQL语句预先编译为一个可执行的指令序列,并且在执行时只需要传递参数,而不需要重新编译整个语句,从而提高了程序的执行效率。同时,使用预编译语句还可以有效避免SQL注入攻击。
相关问题
public Map<String, Object> queryOneRow(String sql, List<Object> paras) { Map<String, Object> oneRow = new HashMap<String, Object>(); try { intConnect(); initParas(sql, paras); ResultSet result = stmt.executeQuery(); List<Map<String, Object>> resultList = convertResultSetToMapList(result); if (resultList.size() > 0) { oneRow = resultList.get(0); } } catch (Exception e) { // TODO: handle exception e.printStackTrace(); System.out.println("???queryOneRow????????"+sql+"??"); } finally{ close(); } return oneRow; }
这段代码是用来查询数据库中的一行数据,并将结果以Map形式返回。其中,参数sql表示查询语句,paras表示查询语句中的参数。该方法会将参数设置到PreparedStatement中,并执行查询操作。如果查询结果不为空,则将结果转换为Map形式并返回;否则返回空的Map。该方法使用了try-catch-finally结构,确保在任何情况下都会关闭数据库连接。
public List<Map<String, Object>> query(String sql, List<Object> paras){ List<Map<String, Object>> resultList = new ArrayList<Map<String, Object>>(); try { intConnect(); initParas(sql, paras); ResultSet result = stmt.executeQuery(); resultList = convertResultSetToMapList(result); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); System.out.println("???query????????"+sql+"??"); } finally{ close(); } return resultList; }
这段代码是用来查询数据库中的多行数据,并将结果集以List<Map<String, Object>>的形式返回。其中,参数sql表示查询语句,paras表示查询语句中的参数。该方法会将参数设置到PreparedStatement中,并执行查询操作。如果查询结果不为空,则将结果转换为List<Map<String, Object>>形式并返回;否则返回空的List。该方法使用了try-catch-finally结构,确保在任何情况下都会关闭数据库连接。
阅读全文