开源组件:(4)用元数据和BeanUtils写一个简单的ORM映射BaseDAO.java
admin
2023-06-09 15:02:03
0

1、JDBC元数据

在jdbc中可以使用: 数据库元数据、参数元数据、结果集元数据


(1)数据库元数据

通过Connection对象的getMetaData() 方法可以得到DatabaseMetaData对象。DatabaseMetaData对象包含了数据库的元信息。


DatabaseMetaData java.sql.Connection.getMetaData() 

Retrieves a DatabaseMetaData object that contains metadata about the database. The metadata includes information about the database's tables, its supported SQL grammar, its stored procedures, the capabilities of this connection, and so on.



java.sql.DatabaseMetaData

(1)这个接口由驱动程序厂商实现,通过这个接口可以得到数据库的capabilities

This interface is implemented by driver vendors to let users know the capabilities of a Database 

(2)不同的DBMS提供不同的特性,实现特性的方式也不同,数据类型也不同

Different relational DBMSs often support different features, implement features in different ways, and use different data types.


getURL():返回一个String类对象,代表数据库的URL。

getUserName():返回连接当前数据库管理系统的用户名。

getDatabaseProductName():返回数据库的产品名称。

getDatabaseProductVersion():返回数据库的版本号。

getDriverName():返回驱动驱动程序的名称。

getDriverVersion():返回驱动程序的版本号。

isReadOnly():返回一个boolean值,指示数据库是否只允许读操作。



(2)参数元数据

java.sql.ParameterMetaData

An object that can be used to get information about the types and properties for each parameter marker in a PreparedStatement object.


通过ParameterMetaData对象的getParameterCount()方法可以获得PreparedStatement对象中的参数个数。

int java.sql.ParameterMetaData.getParameterCount() 

Retrieves the number of parameters in the PreparedStatement object.



(3)结果集元数据

通过ResultSet对象的getMetaData()方法得到ResultSetMetaData对象。

ResultSetMetaData java.sql.ResultSet.getMetaData()

Retrieves the number, types and properties of this ResultSet object's columns.



java.sql.ResultSetMetaData

An object that can be used to get information about the types and properties of the columns in a ResultSet object. 



1.1、数据库元数据

package com.rk.metadata;

import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.SQLException;

import com.rk.utils.JDBCUtil;

//1. 数据库元数据
public class Demo01
{
	public static void main(String[] args) throws SQLException
	{
		// 获取连接
		Connection conn = JDBCUtil.getConnection();
		// 获取数据库元数据
		DatabaseMetaData metaData = conn.getMetaData();// alt + shift + L  快速获取方法返回值
		
		System.out.println("DatabaseProductName:" + metaData.getDatabaseProductName());//返回数据库的产品名称。
		System.out.println("DatabaseProductVersion:" + metaData.getDatabaseProductVersion());//返回数据库的版本号
		System.out.println("DriverName:" + metaData.getDriverName());//返回驱动驱动程序的名称
		System.out.println("getDriverVersion:" + metaData.getDriverVersion());//返回驱动程序的版本号
		System.out.println("URL:" + metaData.getURL());//返回一个String类对象,代表数据库的URL
		System.out.println("UserName:" + metaData.getUserName());//返回连接当前数据库管理系统的用户名
		System.out.println("ReadOnly:" + metaData.isReadOnly());//返回一个boolean值,指示数据库是否只允许读操作
		
		JDBCUtil.closeQuietly(conn);
	}
}


1.2、参数元数据

package com.rk.metadata;

import java.sql.Connection;
import java.sql.ParameterMetaData;
import java.sql.PreparedStatement;
import java.sql.SQLException;

import com.rk.utils.JDBCUtil;

//2. 参数元数据
public class Demo02
{
	public static void main(String[] args) throws SQLException
	{
		// 获取连接
		Connection conn = JDBCUtil.getConnection();
		// SQL
		String sql = "SELECT * FROM T_Dogs WHERE Name=? and Age>?";
		
		PreparedStatement pstmt = conn.prepareStatement(sql);
		// 参数元数据
		ParameterMetaData parameterMetaData = pstmt.getParameterMetaData();
		// 获取参数的个数
		int count = parameterMetaData.getParameterCount();
		System.out.println("count:" + count);
		
		JDBCUtil.closeQuietly(pstmt);
		JDBCUtil.closeQuietly(conn);
	}
}


1.3、结果集元数据

package com.rk.metadata;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;

import com.rk.utils.JDBCUtil;

//3. 结果集元数据
public class Demo03
{
	public static void main(String[] args) throws SQLException
	{
		// 获取连接
		Connection conn = JDBCUtil.getConnection();
		String sql = "SELECT * FROM T_Dogs";
		PreparedStatement pstmt = conn.prepareStatement(sql);
		ResultSet rs = pstmt.executeQuery();
		
		// 得到结果集元数据(目标:通过结果集元数据,得到列的名称)
		ResultSetMetaData rs_metaData = rs.getMetaData();
		
		// 迭代每一行结果
		while(rs.next())
		{
			// 1. 获取列的个数
			int count = rs_metaData.getColumnCount();
			
			// 2. 遍历,获取每一列的列的名称
			for(int i=0;i


2、BaseDAO.java

BaseDAO.java

package com.rk.dao;

import java.sql.Connection;
import java.sql.ParameterMetaData;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.util.LinkedList;
import java.util.List;

import org.apache.commons.beanutils.BeanUtils;

import com.rk.utils.JDBCUtil;

public class BaseDAO
{
	/**
	 * 更新的通用方法
	 */
	public void update(String sql,Object... paramValues)
	{
		Connection conn = null;
		PreparedStatement pstmt = null;
		try
		{
			// 获取连接
			conn = JDBCUtil.getConnection();
			// 创建执行命令的stmt对象
			pstmt = conn.prepareStatement(sql);
			// 参数元数据: 得到占位符参数的个数
			ParameterMetaData metaData = pstmt.getParameterMetaData();
			int count = metaData.getParameterCount();
			
			// 设置占位符参数的值
			if(paramValues != null && paramValues.length>0)
			{
				// 循环给参数赋值
				for(int i=0;i List query(String sql,Class clazz, Object... paramValues)
	{
		Connection conn = null;
		PreparedStatement pstmt = null;
		ResultSet rs = null;
		try
		{
			// 返回的集合
			List list = new LinkedList();
			
			// 1. 获取连接
			conn = JDBCUtil.getConnection();
			// 2. 创建stmt对象
			pstmt = conn.prepareStatement(sql);
			// 3. 获取占位符参数的个数, 并设置每个参数的值
			ParameterMetaData pmd = pstmt.getParameterMetaData();
			int parameterCount = pmd.getParameterCount();
			if(paramValues != null && paramValues.length>0)
			{
				for(int i=0;i 获取列的个数
			int columnCount = rsmd.getColumnCount();
			
			// 6. 遍历rs
			while(rs.next())
			{
				// 要封装的对象
				T t = clazz.newInstance();
				// 7. 遍历每一行的每一列, 封装数据
				for(int i=0;i

DogDAO.java

package com.rk.dao;

import java.util.List;

import com.rk.entity.DogInfo;

public class DogDAO extends BaseDAO
{
	public void save(DogInfo dog)
	{
		String sql = "INSERT INTO T_Dogs(Name,Age,BirthDay) VALUES(?,?,?)";
		super.update(sql,dog.getName(),dog.getAge(),dog.getBirthDay());
	}
	
	public List findAll()
	{
		String sql = "SELECT * FROM T_Dogs";
		return super.query(sql, DogInfo.class);
	}
	
	public DogInfo findById(int id)
	{
		String sql = "SELECT * FROM T_Dogs WHERE Id=? ";
		List list = super.query(sql, DogInfo.class, id);
		return (list != null && list.size()>0)?list.get(0):null;
	}
	
	public void update(DogInfo dog)
	{
		String sql = "UPDATE T_Dogs SET Name=?,Age=?,BirthDay=? WHERE Id=?";
		super.update(sql, dog.getName(),dog.getAge(),dog.getBirthDay(),dog.getId());
	}
	
	public void delete(int id)
	{
		String sql = "DELETE FROM T_Dogs WHERE Id=?";
		super.update(sql, id);
	}
}

Demo04.java

package com.rk.metadata;

import java.util.Date;
import java.util.List;

import com.rk.dao.DogDAO;
import com.rk.entity.DogInfo;

public class Demo04
{
	public static void main(String[] args)
	{
		//保存
//		DogInfo d = new DogInfo();
//		d.setName("汪汪");
//		d.setAge(2);
//		d.setBirthDay(new Date());
//		
//		DogDAO dao = new DogDAO();
//		dao.save(d);
		
		
		//查找所有
//		DogDAO dao = new DogDAO();
//		List list = dao.findAll();
//		for(DogInfo dog : list)
//		{
//			System.out.println(dog);
//		}
		
		//查找特定id记录
//		DogDAO dao = new DogDAO();
//		DogInfo d = dao.findById(1);
//		System.out.println(d);
		
		//更新
//		DogInfo d = new DogInfo();
//		d.setId(1);
//		d.setName("旺财");
//		d.setAge(3);
//		d.setBirthDay(new Date());
//		DogDAO dao = new DogDAO();
//		dao.update(d);
		
		//删除
		DogDAO dao = new DogDAO();
		dao.delete(1);
	}
}


相关内容

热门资讯

神舟二十三号飞船有多项创新 我国2026年度载人发射任务首战告捷——神舟二十三号飞船有多项创新本报记者 刘诗瑶 李君强《人民日报...
人民日报刊文:警惕日本军国主义... 警惕日本军国主义卷土重来(国际论坛)斯特凡·卢比奇《人民日报》(2026年05月25日 第 03 版...
一线调研|从太空到3000米深... 来源:券商中国 当一颗卫星以每秒7公里的速度驶入太空,或者一台机器人潜入3000米深的海底,它们在传...
第8次会师!神舟二十三号航天员... 新华社酒泉5月25日电(记者李国利、高蕊)神舟二十三号航天员乘组25日顺利进驻“天宫”,中国航天员完...
伊朗方面称现阶段伊尚未就核问题... △伊朗首都德黑兰(资料图)总台记者当地时间5月24日获悉,伊朗方面表示,以色列媒体此前关于伊朗在开始...
小米YU7 GT、小米17 M... 5月21日,小米连续发布全新小米YU7家族,新增小米YU7 GT、YU7 标准版两大车型。同场发布的...
持续深耕AI4S创新创业生态 ... 首期科学智能百团百项“科创训练营”近日在沪举办,来自近30个AI4S(AI for Science)...
特朗普:美伊协议“尚未完全谈妥... 新华社华盛顿5月24日电(记者颜亮 徐剑梅)美国总统特朗普24日说,美国和伊朗的协议“尚未完全谈妥”...
大幅升级改造!神舟二十三号飞船... 神舟二十三号飞船出征在即,作为新批次飞船的第二艘飞船,它有哪些改进?承担什么样的任务? 人机界面升...
原创 这... 在自然界,有一些动物通过模仿有毒的、有害的其它动物,来提高生存能力,也有一些动物通过模仿周围的环境来...