1_基础版JDBC-DBHelper扩展(事务及大数据操作)

2023-10-28 16:58

本文主要是介绍1_基础版JDBC-DBHelper扩展(事务及大数据操作),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

			JDBC - 基础版DBHelper

/MyProperties.java/

public class MyProperties extends Properties{
private static MyProperties myproperties;
private MyProperties(){
InputStream iis = MyProperties.class.getClassLoader().getResourceAsStream(“db.properties”);
try{
super.load( iis );
}catch( IOException e ){
e.printStackTrace();
}
}

public static MyProperties getInstance(){if( myproperties == null ){myproperties = new MyProperties();}return myproperties;
}

}

/**************************************************************************/

/DBHelper.java/

public class DBHelper{

// 静态块 , 读取一次数据库驱动,
static{try{Class.forName( MyProperties.getInstance().getProperty("driver") );}catch( ClassNotFoundException e ){e.printStackTrace();}
}//获取数据库联接
public Connection getCon() throws SQLException {MyProperties mp = MyProperties.getInstance();Connection con = DriverManager.getConnection( mp.getProperty("url") , mp.getProperty ("username") , mp.getProperty("password") );return con;
}//查询
public List<Map<String , String >> findAll( String sql ,List<Object> params )throws SQLException{Connection con = getCon();PreparedStatement pstmt = con.prepareStatement( sql );setParams( pstmt , params );ResultSet rs = pstmt.executeQuery();ResultSetMetaData rsmd = rs.getMetaData(); //获取关于 ResultSet 对象中列的类型和属性信息的对象List<String> cnlist = new ArrayList<String>();for( int i = 1; i <= rsmd.getColumnCount() ; i++ ){cnlist.add( rsmd.getColumnName( i ) );}List<Map<String , String >> list = new ArrayList<Map<String ,String >>();while( rs.next() ){Map<String , String > map = new HashMap<String , String >();for( String cn :cnlist ){map.put( cn , rs.getString(cn) );}list.add( map );}closeAll(pstmt ,con ,rs );return list;
}//查询聚合函数
public double findDouble( String sql , List<Object> params ) throws SQLException{double result = 0;Connection con = getCon();PreparedStatement pstmt = con.prepareStatement( sql );setParams( pstmt ,params );ResultSet rs = pstmt.executeQuery();while( rs.next() ){rs.getDouble( 1 );}closeAll( pstmt ,con ,rs );return result;
}//封装增删改
public int doUpdate( String sql , List<Object> params ) throws SQLException{Connection con = getCon();PreparedStatement pstmt = con.prepareStatement( sql );setParams( pstmt ,params );int result = pstmt.executeUpdate();closeAll( pstmt ,con ,null );return result;
}//封装带事务的增删改
public void doUpdateTran( List<String> sqls ,List< List<Object> > listparams ){Connection con = getCon();PreparedStatement pstmt = null;con.setAutoCommit( false );  //关闭隐式事务( 一句SQL语句提交一次 )try{if( sqls != null && sqls.size() > 0 ){for( int i = 0; i < sqls.size() ; i++ ){String sql = sqls.get( i );     // 取出每一条sql语句.pstmt = con.prepareStatement( sql );setParams( pstmt , listparams( i ) );pstmt.executeUpdate();}}con.commit();}catch( Exception e ){if( con != null ){con.rollback;   // 回滚}}finally{con.setAutoCommit( true );  //恢复隐式事务closeAll( pstmt ,con ,null );}}//大数据的操作 , 批处理// 集合嵌套集合.
public void doBigDataUpdate( String sql , List<List<Object>> params ) throws SQLException{Connection con = getCon();con.setAutoCommit( false );   PreparedStatement pstmt = null;try{pstmt = con.prepareStatement( sql );for( int i = 0; i < params.size() ; i++ ){List<Object> paramsList = params.get( i );setParams( pstmt , paramsList );pstmt.addBatch();   //添加一次预定义参数if( i % 1000 == 0 ){pstmt.executeBatch(); //批量执行预定义sql ,这个返回值里面存的是每条语句执行的结果}}pstmt.executeBatch();   // 多余的余数在执行.con.commit();}catch( Exception e){e.printStackTrace();con.rollback();    // 异常 ====>>>> 回滚。}finally{con.setAutoCommit( true );closeAll( pstmt ,con ,null );}
}//设置参数 占位符
private void setParams( PreparedStatement pstmt , List<Object> params ) throws SQLException{if( params != null && params.size() > 0 ){for( int i = 1;  i <= params.size() ; i++ ){pstmt.setObject( i , params.get( i-1 ));}}
}// 释放资源
private sttaic void clossAll( PreparedStatement pstmt , Connection con , ResultSet rs ){if( pstmt != null ){pstmt.close();}if( con !=null ){con.close();}if( rs != null ){rs.close();}
}

}

这篇关于1_基础版JDBC-DBHelper扩展(事务及大数据操作)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/294624

相关文章

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

从基础到进阶详解Pandas时间数据处理指南

《从基础到进阶详解Pandas时间数据处理指南》Pandas构建了完整的时间数据处理生态,核心由四个基础类构成,Timestamp,DatetimeIndex,Period和Timedelta,下面我... 目录1. 时间数据类型与基础操作1.1 核心时间对象体系1.2 时间数据生成技巧2. 时间索引与数据

使用SpringBoot整合Sharding Sphere实现数据脱敏的示例

《使用SpringBoot整合ShardingSphere实现数据脱敏的示例》ApacheShardingSphere数据脱敏模块,通过SQL拦截与改写实现敏感信息加密存储,解决手动处理繁琐及系统改... 目录痛点一:痛点二:脱敏配置Quick Start——Spring 显示配置:1.引入依赖2.创建脱敏

Linux链表操作方式

《Linux链表操作方式》:本文主要介绍Linux链表操作方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、链表基础概念与内核链表优势二、内核链表结构与宏解析三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势六、典型应用场景七、调试技巧与

Java Multimap实现类与操作的具体示例

《JavaMultimap实现类与操作的具体示例》Multimap出现在Google的Guava库中,它为Java提供了更加灵活的集合操作,:本文主要介绍JavaMultimap实现类与操作的... 目录一、Multimap 概述Multimap 主要特点:二、Multimap 实现类1. ListMult

安装centos8设置基础软件仓库时出错的解决方案

《安装centos8设置基础软件仓库时出错的解决方案》:本文主要介绍安装centos8设置基础软件仓库时出错的解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录安装Centos8设置基础软件仓库时出错版本 8版本 8.2.200android4版本 javas

Spring组件实例化扩展点之InstantiationAwareBeanPostProcessor使用场景解析

《Spring组件实例化扩展点之InstantiationAwareBeanPostProcessor使用场景解析》InstantiationAwareBeanPostProcessor是Spring... 目录一、什么是InstantiationAwareBeanPostProcessor?二、核心方法解

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化: