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

本文介绍如何利用元数据信息在JDBC代码中获取数据库和参数信息,以提高代码的灵活性。主要应用于Hibernate框架,它需要兼容多种数据库。通过实例展示了如何根据SQL语句的参数数量和类型,动态填充参数,实现更灵活的数据查询。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值