为了提高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
语句里面的参数一一对应,这个也不是什么苛刻的要求,所以还是不错的