jdbc的学习之 路(四)

本文介绍了一种使用JDBC进行数据库操作的模板方法,包括DML和DQL操作的重构,以及如何通过IResultSetHandle接口规范结果集处理,提供了一个通用的BeanInfoHandler实现。

对于dml操作

除了sql语句不一样其他都一样的

进行重构

对于get和getall也是一样

package com_xyit_shadow_Dao.imp;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;
import com_xyit_shadow_Dao.IResultSetHandle;
import util.Jdbcutil;

public class JdbcTemplate {
	/*
	 * 本类为jdbc的模板
	 * 方法为dml和dql的操作*/
	/*
	 * 更新操作*/
	@SuppressWarnings("finally")
	public static long update(String sql,Object... params) {
	   Connection conn=null;
		PreparedStatement ps=null;
		ResultSet rs = null;
		Long id = null;
		try {
				conn=Jdbcutil.getconn();
				ps=conn.prepareStatement(sql,Statement.RETURN_GENERATED_KEYS);
				for (int i = 0; i < params.length; i++) {
					ps.setObject(i+1, params[i]);
				}
				ps.executeUpdate();	
				rs=ps.getGeneratedKeys();					
				if(rs.next()) {				
					id=rs.getLong(1);
			}else {
				id=(Long) params[params.length-1];			
			}
		} catch (SQLException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}finally {
			Jdbcutil.close(conn, ps, rs);
			return id;
		}
	}
	@SuppressWarnings("finally")
	public static <T>List<T> get(String sql,IResultSetHandle<T> IRS,Object... params){
		List<T> ts=new ArrayList<>();
		Connection conn=null;
		PreparedStatement ps=null;
		ResultSet rs=null;
		try {
			conn=Jdbcutil.getconn();
			ps=conn.prepareStatement(sql);
			for (int i = 0; i < params.length; i++) {
				ps.setObject(i+1, params[i]);
			}
			rs=ps.executeQuery();
			ts=IRS.handle(rs);
		} catch (Exception e) {
			// TODO: handle exception
		}finally {
			Jdbcutil.close(conn, ps, rs);
			return ts;
		}
		
		}
}

对于结果集的处理也可以提取出模板

创建IResultSetHandler接口来规范结果集的方法

package com_xyit_shadow_Dao;

import java.sql.ResultSet;
import java.util.List;

public interface IResultSetHandle<T> {
	//处理结果集的接口
	 List<T> handle(ResultSet rs)throws Exception;
}

一个通用模板 beaninfoHandler

package com_xyit_shadow_Dao.imp;

import java.beans.BeanInfo;
import java.beans.Introspector;
import java.beans.PropertyDescriptor;
import java.lang.reflect.Method;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;
import com_xyit_shadow_Dao.IResultSetHandle;

public class BeanHandler<T> implements IResultSetHandle<T>{
	private Class<T> classtype;	
	public BeanHandler(Class<T> classtype) {
		this.classtype = classtype;
	}

	public List<T> handle(ResultSet rs) throws Exception {
		List<T> list=new ArrayList<>();
		while(rs.next()) {
		BeanInfo beanInfo=Introspector.getBeanInfo(classtype,Object.class);
		PropertyDescriptor[] pds=beanInfo.getPropertyDescriptors();
		T user=classtype.newInstance();
		list.add(user);
		for (PropertyDescriptor pd : pds) {			
			Method setter=pd.getWriteMethod();
			String name=pd.getName();
			Object val=rs.getObject(name);	
			setter.invoke(user,val);		
		}
		}
		return list;
		
	}


}

 

带开环升压转换器和逆变器的太阳能光伏系统 太阳能光伏系统驱动开环升压转换器和SPWM逆变器提供波形稳定、设计简单的交流电的模型 Simulink模型展示了一个完整的基于太阳能光伏的直流到交流电力转换系统,该系统由简单、透明、易于理解的模块构建而成。该系统从配置为提供真实直流输出电压的光伏阵列开始,然后由开环DC-DC升压转换器进行处理。升压转换器将光伏电压提高到适合为单相全桥逆变器供电的稳定直流链电平。 逆变器使用正弦PWM(SPWM)开关来产生干净的交流输出波形,使该模型成为研究直流-交流转换基本操作的理想选择。该设计避免了闭环和MPPT的复杂性,使用户能够专注于光伏接口、升压转换和逆变器开关的核心概念。 此模型包含的主要功能: •太阳能光伏阵列在标准条件下产生~200V电压 •具有固定占空比操作的开环升压转换器 •直流链电容器,用于平滑和稳定转换器输出 •单相全桥SPWM逆变器 •交流负载,用于观察实际输出行为 •显示光伏电压、升压输出、直流链电压、逆变器交流波形和负载电流的组织良好的范围 •完全可编辑的结构,适合分析、实验和扩展 该模型旨在为太阳能直流-交流转换提供一个干净高效的仿真框架。布局简单明了,允许用户快速了解信号流,检查各个阶段,并根据需要修改参数。 系统架构有意保持模块化,因此可以轻松扩展,例如通过添加MPPT、动态负载行为、闭环升压控制或并网逆变器概念。该模型为进一步开发或整合到更大的可再生能源模拟中奠定了坚实的基础。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值