JDBC学习之路(九)参数的元数据信息

为了提高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

语句里面的参数一一对应,这个也不是什么苛刻的要求,所以还是不错的

你可能感兴趣的:(sql,Hibernate,数据库,jdbc,String,object)