10年开发经验程序员一文带你把5种数据库操作框架给直接理解透彻
ztj100 2024-12-10 22:16 11 浏览 0 评论
数据库操作框架
数据库操作框架指的是第三方软件操作数据库的组件工具。虽然数据库操作框架根据不同的开发语言而有所不同,但是它们所要解决的问题是相同的,即建立连接、断开连接、发送操作指令(一般是SQL语句)和转换返回结果。
对于使用Java编写的后端应用程序而言,比较流行的数据库框架有JDBC、JDBC Template、Hibernate、JPA和MyBatis。
下面将对这5种数据库操作框架进行介绍和对比。
1.JDBC
JDBC(Java Database Connectivity)是Java操作数据库的基本工具,它为多种数据库提供统一的规范和接口。通过使用JDBC,Java应用程序可以通过使用相同的接口操作不同的数据库(如MySQL、Oracle等)。但实际上,JDBC不直接与数据库通信,它只是作为Java程序与数据库驱动器之间的桥梁,如图4.72所示。
说明:数据库驱动器是使用Java编写的组件,负责与其对应的数据库通信。数据库驱动器本身是可以直接使用的,JDBC只是统一了多种驱动器的使用方法。使用JDBC操作数据库之前,需要手动指定数据库驱动器。
JDBC可以在任意Java程序中使用,使用JDBC操作数据库如代码4.44所示。
但是,不推荐在后端应用程序中使用JDBC,因为JDBC相当原始,使用者需要编写大量代码以完善对数据库的操作,而在后端应用程序当中,使用其他数据库框架的话,则能省去很多代码(如建立连接、断开连接等)。
代码4.44 JDCB操作数据库的代码
#更新数据
update table1 set field1=value1 where id=id_1
…
//指定MySQL数据库驱动
Class.forName("com.mysql.jdbc.Driver");
//建立连接
Connection connection = DriverManager.getConnection(
//数据库连接地址,xxx为具体的数据库名
"jdbc:mysql://ip:port/xxx",
"userName", //用户名
"password"); //密码
//编写查询SQL语句,?为占位符,后续通过参数替换
String sqlString = "select * from formName where key = ?";
preparedStatement = connection.prepareStatement(sqlString);
//替换sqlString中的?占位符,1标识第一个占位符
preparedStatement.setString(1, "王五");
//执行SQL语句
ResultSet resultSet = preparedStatement.executeQuery();
//处理查询集合
while(resultSet.next()){
//对每条查询结果的处理,根据字段获取值的方法为resultSet.getString("id")
}
2.JDBC Template
JDBC Template是针对Spring相关框架(如Spring Boot、Spring MVC等)设计的数据库操作框架,是JDBC的上层封装。通过使用JDBC Template,开发者不需要关心数据库连接过程(不需要写连接和断开数据库的代码),只需要在后端应用程序的配置文件中配置数据库连接信息即可实现自动连接数据库。
JDBC只能在使用Spring相关框架的后端应用程序中使用。JDBC Template实现了自动连接和断开数据库,省去了JDBC中手动连接和断开数据库的麻烦。
与数据库通信方面,JDBC Template保持了SQL语句的方式,但简化了JDBC的调用方式,如代码4.45所示。
代码4.45 JDCB Template操作数据库的代码
//编写查询SQL语句,?为占位符,后续通过参数替换
String sqlString="select * from formName where key_1 = ? and key_2 = ?";
//执行SQL语句
List list = jdbcTemplate.queryForList(sqlString, "王五" , "50");
//处理查询集合
for (int i = 0; i < list.size(); i++) {
//转换每条结果的数据类型
Map<String, Object> result = (Map<String, Object>) list.get(i);
… //处理每条结果
}
3.Hibernate
Hibernate是一个高度自动化的数据库操作框架,是JDBC的上层封装。通过使用Hibernate,数据库中的表可以映射成Java的类,如代码4.46所示。开发者只需要使用这些映射的类就可以操作数据库(自动生成SQL语句),如代码4.47所示。
说明:根据数据库的表映射成的Java类被称为Entity(实体)模型,使用Hibernate的话,需要为每个需要操作的表都建立对应的Entity模型。
Entity模型可以使用相关工具自动生成,不需要手动填写。
代码4.46 数据库映射的Java类
//映射数据库的user表,表中有id和info两个字段
@Entity
@Table(name="user")
public class User {
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
@Column(name="id", unique=true, nullable=false)private Long id;
@Column(name="info")
private String info;
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getInfo() {
return info;
}
public void setInfo(String info) {
this.info = info;
}
}
代码4.47 Hibernate操作数据库的代码
//获取数据库连接的Session,此处的Session有别于4.3.4小节中的Session
Session session = HibernateUtil.getSession();
//编写查询HQL语句,?为占位符,后续通过参数替换
String hqlString = "from formName where key_1 = ?";
Query query= session.createQuery(hql);
query.setParameter(0, "王五");
//获取结果
List userages = query.list();
//处理查询结果
for (int i = 0; i < list.size(); i++) {
//把每条结果转换成对应的Java对象,其中User为代码4.45中定义的数据库映射成的
Java类
User user = (User) list.get(i);
… //处理每条结果
}
Hibernate可以在任意Java程序中使用。Hibernate可以自动连接和断开数据库(通过XML配置文件设置)。在与数据库通信方面,Hibernate可以根据映射关系自动生成SQL语句。为了增加自动生成的SQL语句的灵活性,Hibernate提供了HQL(Hibernate Query Language)语句。HQL语法与SQL类似,但功能上没有SQL健全。这种“自动生成SQL语句”的做法其实是为了节省学习SQL的时间,并且希望以面向对象的编程思想使用数据库。但是在实际编程当中,部分操作只能通过SQL语句实现(不能完全脱离SQL语句),而且当需要操作的数据表较多时,映射关系也会很复杂。因此,目前Hibernate的热度正在慢慢减退。
说明:类似于Hibernate这种把关系型数据库中的表映射成Java类的数据库操作框架,被称为ORM框架(Object Relation Mapping,对象-关系映射)。比较流行的ORM框架有Hibernate、TopLink等。
4.JPA
JPA(Java Persistence API,Java持久层API)是ORM框架的统一规范,为多个ORM框架提供统一的使用接口。使用JPA的好处是,可以自由切换ORM框架而不影响代码。JPA与ORM框架的关系如图4.73所示。需要注意的是,在使用JPA之前,需要指定具体ORM框架和数据库驱动。
5.MyBatis
MyBatis是一个不完全的ORM框架,是JDBC的上层封装。MyBatis也需要把数据库中的表映射成Java类,但是它不会根据Java对象自动生成SQL语句。使用MyBatis作为数据库操作框架的话,开发者需要编写SQL语句模板,MyBatis会根据指定的SQL语句模板和Java对象生成对应的SQL语句,如代码4.48所示。
代码4.48 MyBatis操作数据库的代码
@Mapper
public interface UserMapper {
//定义SQL模板,其中#{}为待替换的参数@Select("select * from formName where key_1 = #{value_1} and key_2 =
#{value_2}")
//定义操作函数,函数被调用后,会自动把参数填充到SQL模板并执行SQL语句,然后返回
结果,返回类型User为代码4.46中定义的数据库映射成的Java类
List<User> SelectAll(@Param("value_1") String value1, @Param("value_2")
String value2);
}
//下面是调用上述查询操作的示例
List<User> resultList = userMapper.SelectAll("王五", "0");
//处理查询结果
for (int i = 0; i < list.size(); i++) {
//把每条结果转换成对应的Java对象,其中User为代码4.46中定义的数据库映射成的
Java类
User user = list.get(i);
… //处理每条结果
}
MyBatis可以在任意Java程序中使用。MyBatis的出现,保持了ORM框架“以面向对象编程思想使用数据库”的同时,也避免了由于全自动生成SQL语句造成的局限。
6.数据库操作框架的选择
对于使用Java编写的后端应用程序而言,数据库框架一般是在JDBCTemplate、JPA(或Hibernate等ORM框架)和MyBatis中做出选择。而这三类数据库操作框架的主要区别在于SQL构造和返回结果转换的方式上,而这些方式本身是很难辨出孰优孰劣的,因此,只需要根据团队的使用习惯或偏好来选择数据库操作框架就可以了。
7.Spring Boot中使用数据库框架的具体方法
这里以JDBC Template为例,介绍在Spring Boot中使用数据库框架的具体方法。在Spring Boot中使用JDBC Template需要三步,即引入JDBC Template的依赖包、配置数据库信息和在代码中使用JDBC Template操作数据库。
(1)引入JDBC Template的依赖包。需要在工程配置文件(build.gradle)中添加JDBC Template的依赖包,如代码4.49所示。
代码4.49 在build.gradle中添加JDBC Template依赖包…
dependencies {
…
//在dependencies中添加JDBC Template的依赖包
implementation 'org.springframework.boot:spring-boot-starter-jdbc'
implementation 'com.alibaba:druid:1.0.26' //数据库连接池依赖
runtimeOnly 'mysql:mysql-connector-java' //MySQL驱动依赖
…
}
…
添加完依赖包之后,需要同步工程配置。JDBC Template的依赖包在同步工程配置后才会被下载和引入。在IntelliJ IDEA中,只需要单击“同步”按钮即可同步工程配置,如图4.74所示。
(2)配置数据库信息。配置数据库连接信息需要在后端应用程序的配置文件(默认是application.properties)中设置,如代码4.50所示,其中,连接池的具体设置需要根据实际情况而定。
说明:频繁地建立和断开数据库连接是很耗资源的,连接池的作用是避免频繁创建和释放连接引起的大量性能开销。
代码4.50 在配置文件中添加数据库连接信息…
#设置数据库连接地址,xxx为具体的数据库名
spring.datasource.jdbc-url=jdbc:mysql://ip:port/xxx
#设置用户名
spring.datasource.username=root
#设置密码
spring.datasource.password=password
#指定MySQL数据库驱动
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
#设置数据库连接池,type为指定连接池的包,max-active为最大激活连接数,max-idle为
最大等待连接的数量,initial-size为初始状态下建立的连接数
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.max-active=20
spring.datasource.max-idle=8
spring.datasource.initial-size=10
…
(3)使用JDBC Template操作数据库的代码一般在Dao层中,具体代码如代码4.51所示。
代码4.51 通过JDBC Template操作数据库
package com.example.demo.dao;
//引用JDBCTemplate的类
import org.springframework.jdbc.core.JdbcTemplate;
import … //省略其他引用的类
@Repository("TestDao")
public class TestDao {
//获取JdbcTemplate对象,此对象会被自动注入
@Autowired
private JdbcTemplate jdbcTemplate ;
public String create(String value1, String value2){
try{
//SQL语句,?为占位符,后续通过参数替换
String sqlString = "INSERT INTO formName VALUES (?, ?)";
//执行SQL语句
int result = jdbcTemplate.update(sqlString, value1, value2);
if(result > 0){
return "success";
}else {
return "fail";
}
}catch(Exception e){
return "fail";}
}
public List get(String key){
List resultList = new List();
try{
//SQL语句,?为占位符,后续通过参数替换
String sqlString="SELECT * FROM formName WHERE key_1 = ? and key_2
= ?";
//执行SQL语句
resultList = jdbcTemplate.queryForList(sqlString, "王五" , "50");
}catch(Exception e){
//失败
}
return resultList;
}
}
本文给大家讲解的内容是大型网站架构的技术细节:后端架构数据库--数据库操作框架
- 下篇文章给大家讲解的内容是大型网站架构的技术细节:后端架构数据库-数据库事务
- 感谢大家的支持!
- 上一篇:Redis这些知识你了解吗?
- 下一篇:一篇搞定Redis常用命令
相关推荐
- 干货 | 各大船公司VGM提交流程(msc船运公司提单查询)
-
VGM(VerifiedGrossMass)要来了,大外总管一本正经来给大家分享下各大船公司提交VGM流程。1,赫伯罗特(简称HPL)首先要注册账户第一,登录进入—选择product------...
- 如何修改图片详细信息?分享三个简单方法
-
如何修改图片详细信息?分享三个简单方法我们知道图片的详细信息里面包含了很多属性,有图片的创建时间,修改时间,地理位置,拍摄时间,还有图片的描述等信息。有时候为了一些特殊场景的需要我们需要对这些信息进行...
- 实用方法分享:没有图像处理软件,怎么将一张照片做成九宫格?
-
在发朋友圈时,如果把自己的照片做成九宫格,是不是更显得高大上?可能你问,是不是要借助图片处理软件,在这里,我肯定告诉你,不需要!!!你可能要问,那怎么实现呢?下面你看我是怎么做的,一句代码都不写,只是...
- 扫描档PDF也能变身“最强大脑”?RAG技术解锁尘封的知识宝藏!
-
尊敬的诸位!我是一名物联网工程师。关注我,持续分享最新物联网与AI资讯和开发实战。期望与您携手探寻物联网与AI的无尽可能。今天有网友问我扫描档的PDF文件能否做知识库,其实和普通pdf处理起来差异...
- 这两个Python库,轻而易举就能实现MP4与GIF格式互转,太好用了
-
mp4转gif的原理其实很简单,就是将mp4文件的帧读出来,然后合并成一张gif图。用cv2和PIL这两个库就可以轻松搞定。importglobimportcv2fromPILimpo...
- python图片处理之图片切割(python把图片切割成固定大小的子图)
-
python图片切割在很多项目中都会用到,比如验证码的识别、目标检测、定点切割等,本文给大家带来python的两种切割方式:fromPILimportImage"""...
- python+selenium+pytesseract识别图片验证码
-
一、selenium截取验证码#私信小编01即可获取大量Python学习资源#私信小编01即可获取大量Python学习资源#私信小编01即可获取大量Python学习资源importjso...
- 如何使用python裁剪图片?(python图片截取)
-
如何使用python裁剪图片如上图所示,这是一张包含了各类象棋棋子的图片。我们需要将其中每一个棋子都裁剪出来,此时可以利用python的...
- Python rembg 库去除图片背景(python 删除图片)
-
rembg是一个强大的Python库,用于自动去除图片背景。它基于深度学习模型(如U^2-Net),能够高效地将前景物体从背景中分离,生成透明背景的PNG图像。本教程将带你从安装到实际应用...
- 「python脚本」批量修改图片尺寸&视频安帧提取
-
【python脚本】批量修改图片尺寸#-*-coding:utf-8-*-"""CreatedonThuAug2316:06:352018@autho...
- 有趣的EXCEL&vba作图(vba画图表)
-
还记不记得之前有个日本老爷爷用EXCEL绘图,美轮美奂,可谓是心思巧妙。我是没有那样的艺术细胞,不过咱有自己的方式,用代码作图通过vba代码将指定的图片写入excel工作表中,可不是插入图片哦解题思...
- 怎么做到的?用python制作九宫格图片,太棒了
-
1.应用场景当初的想法是:想把一张图切割成九等份,发布到微信朋友圈,切割出来的图片,上传到朋友圈,发现微信不按照我排列的序号来排版。这样的结果是很耗时间的。让我深思,能不能有一种,直接拼接成一张...
- Python-连续图片合成视频(python多张图叠加为一张)
-
前言很多时候,我们需要将图片直接转成视频。下面介绍用python中的OpenCV将进行多张图合成视频。cv2安装不要直接用pipinstallcv2,这会报错。有很多人建议用打开window自带的...
- 如何把多个文件夹里的图片提取出来?文件夹整理合并工具
-
在项目管理中,团队成员可能会将项目相关的图片资料分散存储在不同的文件夹中,以便于分类和阶段性管理。然而,当项目进入汇报或总结阶段时,需要将所有相关图片整合到一个位置,以便于制作演示文稿、报告或进行项目...
- 超简单!为图片和 PDF 上去掉水印(pdf图片和水印是一体,怎么去除)
-
作者:某某白米饭...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- 干货 | 各大船公司VGM提交流程(msc船运公司提单查询)
- 如何修改图片详细信息?分享三个简单方法
- 实用方法分享:没有图像处理软件,怎么将一张照片做成九宫格?
- 扫描档PDF也能变身“最强大脑”?RAG技术解锁尘封的知识宝藏!
- 这两个Python库,轻而易举就能实现MP4与GIF格式互转,太好用了
- python图片处理之图片切割(python把图片切割成固定大小的子图)
- python+selenium+pytesseract识别图片验证码
- 如何使用python裁剪图片?(python图片截取)
- Python rembg 库去除图片背景(python 删除图片)
- 「python脚本」批量修改图片尺寸&视频安帧提取
- 标签列表
-
- idea eval reset (50)
- vue dispatch (70)
- update canceled (42)
- order by asc (53)
- spring gateway (67)
- 简单代码编程 贪吃蛇 (40)
- transforms.resize (33)
- redisson trylock (35)
- 卸载node (35)
- np.reshape (33)
- torch.arange (34)
- node卸载 (33)
- npm 源 (35)
- vue3 deep (35)
- win10 ssh (35)
- exceptionininitializererror (33)
- vue foreach (34)
- idea设置编码为utf8 (35)
- vue 数组添加元素 (34)
- std find (34)
- tablefield注解用途 (35)
- python str转json (34)
- java websocket客户端 (34)
- tensor.view (34)
- java jackson (34)