JDBC进阶
1,封装已有jdbc
2,jdbc事物
3,三层架构
4,数据库连接池:Druid
5,DButils
JDBC封装
三层架构
项目三层架构(大)
前端:用户接口层
后端:数据处理层
数据库:数据存储层
后端三层架构(小)
Controller/web作用:与前端交互获取前端数据,给前端响应数据
Service 作用:处理业务
Dao 作用:操作数据库
分包
controller:用户交互包
service:业务处理包
dao:操作数据库包
bean:对应实体包
utils:工具类包
数据库连接池
简介
作用:储存与管理数据库连接,帮助我们创建,销毁,复用数据库连接
流行的数据库连接池
市面上的数据库连接池:
c3p0
Druid(德鲁伊)
Spring带的
综合能力最好的就是Druid
性能上最好的就是Spring带的
Druid的使用
下载Druid的jar包
https://mvnrepository.com/artifact/com.alibaba/druid/1.0.19
DButils
下载jar包
https://mvnrepository.com
核心类
QueryRunner
QueryRunner
方法:
query:
作用:执行DQL语句,类似与executeQuery方法
update:
作用:执行DML语句,类似与executeUpdate方法
ResultSetHandler:接口
子类:
BeanHandler:返回一个对象
注意:
1,bean类必须提供无参构造函数,如果没有无参构造会报错
2,bean类的属性名要与查询的结果的列名一致,如果名称不一致可能会取不到值.
BeanListHandler:返回一个集合
注意:
1,bean类必须提供无参构造函数,如果没有无参构造会报错
2,bean类的属性名要与查询的结果的列名一致,如果名称不一致可能会取不到值.
ScalarHandler:返回一个值