第六章JDBS

文章介绍了JDBC的基础知识,包括与MySQL的连接,JDBC的CRUD操作,重点讲解了PreparedStatement的预编译机制和优于Statement的特性。还讨论了execute与executeUpdate的区别,以及在数据库操作中的ORM概念。最后,详细阐述了数据库连接池的工作原理和其在多线程环境中的优势,提到了ConnectionPool的构造和初始化方法。
摘要由CSDN通过智能技术生成

一.MySQL的基础准备

安装好了MySQL并且与Ecplies成功连接

 二.JDBC的删减改查操作

 

 

 

 

 

 

三.JDBS预编译Statement

 

 

PreparedStatement与Statement相比有很多的优点 

1.Statement 需要进行字符串拼接,可读性和维护性比较差;PreparedStatement 使用参数设置,可读性好,不易犯错

2.PreparedStatement有预编译机制,性能比Statement更快,在实际测试过后,发现在数据量比较多的情况时,PreparedStatement速度明显快于Statement

3.防止SQL注入式攻击

四.execute与executeUpdate

 

execute与executeUpdate有两个不同点

1.execute可以执行查询语句,然后通过getResultSet,把结果集取出来。但是executeUpdate不能执行查询语句 。

2.execute返回boolean类型,true表示执行的是查询语句,false表示执行的是insert,delete,update等等。executeUpdate返回的是int,表示有多少条数据受到了影响。

五.JDBS ORM

由于ORM部分在JDBC中是比较重要的部分,于是按照网站指导实践了一部分方法来加深对ORM的体会

 

 

 

 

 

 

 六.DAO

 七.数据库连接池

传统方式:当有多个线程,每个线程都需要连接数据库执行SQL语句的话,那么每个线程都会创建一个连接,并且在使用完毕后,关闭连接。创建连接和关闭连接的过程也是比较消耗时间的,当多线程并发的时候,系统就会变得很卡顿。同时,一个数据库同时支持的连接总数也是有限的,如果多线程并发量很大,那么数据库连接的总数就会被消耗光,后续线程发起的数据库连接就会失败。

使用池:与传统方式不同,连接池在使用之前,就会创建好一定数量的连接。
如果有任何线程需要使用连接,那么就从连接池里面借用,而不是自己重新创建.
使用完毕后,又把这个连接归还给连接池供下一次或者其他线程使用。
倘若发生多线程并发情况,连接池里的连接被借用光了,那么其他线程就会临时等待,直到有连接被归还回来,再继续使用。
整个过程,这些连接都不会被关闭,而是不断的被循环使用,从而节约了启动和关闭连接的时间。

ConnectionPool构造方法和初始化:

1. ConnectionPool() 构造方法约定了这个连接池一共有多少连接
2. 在init() 初始化方法中,创建了size条连接。
3. getConnection, 判断是否为空,如果是空的就wait等待,否则就借用一条连接出去
4. returnConnection, 在使用完毕后,归还这个连接到连接池,并且在归还完毕后,调用notifyAll,通知那些等待的线程,可以调用新连接池。

学习感受与领悟:这一章节是内容比较多的章节。由于在任务周期内时间较紧,所以任务集中提交。在这一章学习了JDBC的基本内容,并和SQL数据库内容相联系起来。两者结合一起学习综合了两个学科,对JavaWeb内容有了更理性的认识
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值