热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

自动生成_JDBC第三天~JDBC之事务批处理自动生成主键连接池重构设计

篇首语:本文由编程笔记#小编为大家整理,主要介绍了JDBC第三天~JDBC之事务批处理自动生成主键连接池重构设计相关的知识,希望对你有一定的参考价值。

篇首语:本文由编程笔记#小编为大家整理,主要介绍了JDBC第三天~JDBC之事务批处理自动生成主键连接池重构设计相关的知识,希望对你有一定的参考价值。



JDBC第三天~JDBC之事务、批处理、自动生成主键、连接池、重构设计JDBC第三天学习:

 

一、事务Transaction(简写tx):

在数据库中,事务是指:一组逻辑操作,无论成或败,都作为一个整体进行工作,要么全部执行,要么全部不执行。

 

■  引入背景:银行转账突遇断电的bug

 

1,处理事务的两个动作:

■   提交commit:当整个事务中,所有的逻辑操作都是正常执行成功。 --》提交事务

■   回滚rollback:当整个事务中,有一个或多个逻辑操作执行失败。 --》回滚事务,撤销该事务中所有的操作,恢复到最初的状态。

 

2,面试常考的ACID属性:

原子性:事务是应用中不可再分的最小逻辑执行单位体,要么都执行,要么都不执行。

一致性:事务结束后,数据库内的数据是合法正确的;(数据不被破坏)‘数据守恒’

隔离性:并发执行的事务之间彼此相互独立、互相不干扰

持久性:事务提交后,数据是永久性的、不可回滚

 

3,处理事务操作的模板:

1):在一组逻辑操作之前:设置事务为手动提交(即取消自动提交) Connection对象.setAutoCommit(false);

2): 进行一组逻辑操作之后:进行事务的提交:connecton对象.commit();

3): 若该过程遇到了异常,则回滚:connection对象.rollback();

注意:

1,在jdbc事务中是默认提交的,在执行DML或DDL操作时就已经提交事务了。

2,对于CRUD操作,只有DML操作才需要事务,查询不需要事务

3,细节:以后但凡发现自己设计到事务的代码测试通过了,但是数据库表中的数据不被。--》事务没有提交

4,Mysql中,InnoDB支持外键,支持事务;MyISAM不支持外键,不支持事务。

 

 

二、批量处理(batch)

 

1,jdbc批处理语句的方法:

■  addBatch(); 添加需要批量处理的SQL语句或者参数;

■  executeBatch(); 执行批量处理语句;

 

2,通常我们会遇到两种情况需要执行sql语句的情况:

■  多条sql语句的批量处理:statement

■   一个sql语句的批量传参:preparedment

 

3,结论:对于MySql服务器:既不支持PreparedStatement的性能优化,也不支持JDBC中的批量操作。

   但是,在新的JDBC驱动中,我们可以通过设置参数来支持批处理操作。对PreparedStatement有效

   url=jdbc:mysql://localhost:3306/数据库名称?rewriteBatchedStatements=true

 

 

三、开发中获取自动生成主键

 

☆问题:为什么需要获取自动生成主键?

  举例:注册时,需要你填写的个人信息非常多,容易引起用户的反感,所以改成两个页面【快速注册+完善个人信息】:

■  在开发中,获取自动生成主键的案例还有很多,比如单据和单据明细之间的关系。

 











■ 如何获取自动生成的主键?

1):先找找原先代码的接口对象是否有提过对应的方法?

  // 贾琏欲执事

  Connection cOnn= null;  

  Statement st = null;

  cOnn= JdbcUtil.getConn();         //① 先在接口对象 connection中找一下,无

   st = conn.createStatement();    //② 则再接口对象 statement中找,发现了statement的执行接口方法:

int executeUpdate(String sql, int autoGenerateKeys );中这个参数autoGenerateKeys[int 类型,很有可能是常数],然发现果然,且其中一个常数值是

Statement.RETURN_GENERATED_KEYS, 然后再找一个发现有个方法:

getGeneratekeys(); 便是咱要的获取主键的最终方法  

        

  st.executeUpdate(sql.toString());


 

2):自动生成主键具体实现的步骤:

                      

//设置可以获取自动生成的主键

st.executeUpdate(sql.toString(), Statement.RETURN_GENERATED_KEYS);

 //去获取自动生成的主键

 ResultSet keyRs = st.getGeneratedKeys();

 if(keyRs.next()) {

         Long id = keyRs.getLong(1);//获取第一列

          System.out.println(id);

          return id;


  }

 

 

四、连接池(也叫数据源DataSource)

连接池 Connection Pool:

 

1、连接池的属性:提高连接池的性能 (缓存思想)

1):连接数据库的四要素

2):初始化连接数 [假如你想买票,卖票的窗口应该先存在吧]

3):最大的连接数和最小的连接数 [例如某块地(规划要建立成一个学校),不能全部都建立成操场吧,对于操场数量应该设定一定范围吧

4):最大的空闲时间和最大等待时间 [最大空闲时间:当你占着资源,在一定时间内都没有什么动作,总不能让你一直“占着茅坑不拉si吧”,就自动释放连接了; 最大的等待时间:等了一定时间,就提示你没有了]

 

2、连接池(数据源javax.sql.DataSource)概述:

注意:DataSource 和 JDBC 一样,仅仅只是接口,sun公司不自己提供实现,由第三方组织提供。

 

1):常用的连接池:

druid(德鲁伊):阿里巴巴提供的,号称世界最好的连接池

■ DBCP:Spring 推荐的

■ C3P0:Hibernate推荐的,已经过时了,性能比较差

 

2)使用数据源(连接池)和不使用的区别:

获取连接的方式不同、释放资源的方式不同。

 

3)学习连接池操作(主要重点是学习如何创建DataSource对象

       Connection cOnn= DataSource对象.getConnection();  //不同数据库连接池,其实就是在创建DataSource的方式上有所不同。

 

-------------------------------------------------------------------------------------------------------------------

❀ 开发中需要的jar包,到maven仓库中下载:https://mvnrepository.com/

1、dbcp:

● 下载:commons-dbcp和 commons-pool的jar包【注意是jar包,不是zip包】

2、druid:

● 下载:druid 的jar包

ps:文档:https://github.com/alibaba/druid/wiki    使用起来非常类似DBCP连接池

经过对比,Druid数据源(连接池)更加优秀,以后使用它即可

---------------------------------------------------------------------------------------------------------------

 

 

五、重构设计:

重构思想:至少是两段代码,因为一段代码,我们看不出相同与不同

■ 重构精髓:把多段代码共同的结构和代码提取出来,达到复用。

    □ 相同的代码抽取出去之后,不同的代码,通过类型最终可以找到共同点,处理为参数

    □ 这里以模板工具类JdbcTemplate 中的更新方法为例:

 

 

 

 

  问题 :JdbcTemplate模板类中查询方法结果集处理写死了:

 

 

 解决:把结果集的处理行为交个每个对象的DAO实现类来做

为了避免不同的DAO 实现类定义的处理结果集的方法名不同,我们定义了一个接口 IResultSetHandler来规范

 

  隐蔽性不合理的设计重构一开始设计jdbcTemplate中查询模板,返回的结果为List集合就不太合理,例如查询的是学生的总数量,就一个整型数值的结果,没必要存储到List集合,然后再取出来。

  解决:泛型

 

 

 

 

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

  让我们回到问题☆ :模板中查询方法结果集处理写死了:

 

 

■ 分析:



  • 上面我们采用的解决方法是:把结果集的处理行为交个每个对象的DAO实现类来做

【为了避免不同的DAO 实现类定义的处理结果集的方法名不同,我们定义了一个接口 IResultSetHandler来规范】

+ 以及通过了泛型解决了隐蔽设计中的不合理问题(重构一开始设计jdbcTemplate中查询模板,返回的结果为List集合就不太合理)



  • 但是交给每个DAO实现类来做,则有多少个DAO实现类就需要定义多少个具体的结果集处理类而且结果集处理的步骤都是相同的,【步骤重复----解决:编写一个通用的结果处理器类】

 

□ 结果集处理的步骤:

① 创建对应类的一个对象;

② 取出结果集中当前光标所在行的某一列的数据;

③ 调用该对象的setter方法,把某一列的数据设置进去。

 

解决:编写通用结果集处理器类【通过反射的子集javaBeans (即java.beans 接口) 实现】

--- 因为之前写死的是因为直接把处理结果集写成了具体对象-----通过反射技术,动态编译(这里采用反射的子集 java.beans).

----可以把不同表中的每一行数据,封装成不同类型的对象;

注意/规范:

1、规定表中的列名必须和对象的属性名相同;

2、规定表中的类型必须和java中的类型匹配。

 








使用java.beans 来解决该问题的步骤:

① 通过反射,类.newInstance() 创建一个对应类的对象obj;

② 创建BeanInfo 对象(即javaBean的实例):通过Introspector.getBeanInfo(类,Object.class);

③ 通过BeanInfo对象.getPropertyDescriptors(),获取到 javaBean对象中的所有的属性,存储到 PropertiesDescriptors[ ]   数组中(PropertiesDesciptors--属性描述器

④ 遍历获取到各个属性名,相应的得到结果集的列的值val,然后(调用该对象setter方法,把某一列的数设置进行),即

    通过属性描述器 Properties对象.getWriteMethod().invoke(obj对象, val );


 

 



推荐阅读
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • 达人评测 酷睿i5 12450h和锐龙r7 5800h选哪个好 i512450h和r75800h对比
    本文介绍了达人评测酷睿i5 12450h和锐龙r7 5800h选哪个好的相关知识,包括两者的基本配置和重要考虑点。希望对你在选择时提供一定的参考价值。 ... [详细]
  • 31.项目部署
    目录1一些概念1.1项目部署1.2WSGI1.3uWSGI1.4Nginx2安装环境与迁移项目2.1项目内容2.2项目配置2.2.1DEBUG2.2.2STAT ... [详细]
  • MySQL语句大全:创建、授权、查询、修改等【MySQL】的使用方法详解
    本文详细介绍了MySQL语句的使用方法,包括创建用户、授权、查询、修改等操作。通过连接MySQL数据库,可以使用命令创建用户,并指定该用户在哪个主机上可以登录。同时,还可以设置用户的登录密码。通过本文,您可以全面了解MySQL语句的使用方法。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • 本文讨论了在Windows 8上安装gvim中插件时出现的错误加载问题。作者将EasyMotion插件放在了正确的位置,但加载时却出现了错误。作者提供了下载链接和之前放置插件的位置,并列出了出现的错误信息。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • 如何在php中将mysql查询结果赋值给变量
    本文介绍了在php中将mysql查询结果赋值给变量的方法,包括从mysql表中查询count(学号)并赋值给一个变量,以及如何将sql中查询单条结果赋值给php页面的一个变量。同时还讨论了php调用mysql查询结果到变量的方法,并提供了示例代码。 ... [详细]
  • 一句话解决高并发的核心原则
    本文介绍了解决高并发的核心原则,即将用户访问请求尽量往前推,避免访问CDN、静态服务器、动态服务器、数据库和存储,从而实现高性能、高并发、高可扩展的网站架构。同时提到了Google的成功案例,以及适用于千万级别PV站和亿级PV网站的架构层次。 ... [详细]
author-avatar
萱萱loveTFOOYS
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有