为了提高JDBC代码的灵活性,我们使用元数据信息来获取数据库和参数的信息,从而为后面的代码提供信息,这样
也提高了代码的灵活度。这种技术大部分用在Hibernate框架中,因为这个框架要兼容很多数据库,所以他在启动的时候
或者需要你配置,或者通过元数据信息获取操作的数据库的信息。下面我们利用参数的信息来写一个查询的函数,当
然,这个函数的灵活性要高一些。
package com.bird.jdbc; import java.sql.Connection; import java.sql.ParameterMetaData; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; public class ParameterMetaTest { /** * @param args * @throws SQLException */ public static void main(String[] args) throws SQLException { Object[] t = {"lisi",10}; read("select * from user where name=? and id<?",t); } public static void read(String sql, Object[] params) throws SQLException{ Connection con = null; PreparedStatement ps = null; ResultSet rs = null; try { con = Temple.getConnection(); ps = con.prepareStatement(sql); ParameterMetaData pmd = ps.getParameterMetaData();//获取参数元信息 int count = pmd.getParameterCount();//获取参数个数 if(count != params.length) return; for(int i = 1; i <= count; i++){ ps.setObject(i, params[i-1]); } rs = ps.executeQuery(); while(rs.next()){ System.out.println(rs.getObject("id")+"\t"+rs.getObject("name")+"\t"+ rs.getObject("birthday")+"\t"+rs.getObject("money")); } } finally{ Temple.free(con, ps, rs); } } }
这个函数可以获取SQL语句中一共有几个参数需要补充,说白了就是问号的个数,然后通过Statement获取参数的原
信息,比如一共几个参数,然后这样就可以使用循环来把传递过来的参数放入里面去,当然了,这个参数得和SQL
语句里面的参数一一对应,这个也不是什么苛刻的要求,所以还是不错的