首页 > 其他分享 >MyBatis-架构概述,什么是框架,三层架构,JDBC

MyBatis-架构概述,什么是框架,三层架构,JDBC

时间:2022-11-06 10:11:34浏览次数:74  
标签:JDBC 架构 框架 rs Spring sql MyBatis 三层

MyBatis 框架-第1章 框架概述

1. 软件开发常用结构

1.1 三层架构

三层架构包含的三层:

界面层(User Interface layer)、业务逻辑层(Business Logic Layer)、数据访问层(Data access layer)

三层的职责

\1. 界面层(表示层,视图层):主要功能是接受用户的数据,显示请求的处理结果。使用 web 页面和

用户交互,手机 app 也就是表示层的,用户在 app 中操作,业务逻辑在服务器端处理。

\2. 业务逻辑层:接收表示传递过来的数据,检查数据,计算业务逻辑,调用数据访问层获取数据。

\3. 数据访问层:与数据库打交道。主要实现对数据的增、删、改、查。将存储在数据库中的数据提交

给业务层,同时将业务层处理的数据保存到数据库.

三层的处理请求的交互:

用户---> 界面层--->业务逻辑层--->数据访问层--->DB 数据库

如图:三层架构包含的三层:

如图:

为什么要使用三层?

1,结构清晰、耦合度低, 各层分工明确

2,可维护性高,可扩展性高

3,有利于标准化

4,开发人员可以只关注整个结构中的其中某一层的功能实现

5,有利于各层逻辑的复用

1.2 常用框架

常见的 J2EE 中开发框架:

MyBatis 框架:
MyBatis 是一个优秀的基于 java 的持久层框架,内部封装了 jdbc,开发者只需要关注 sql 语句
本身,而不需要处理加载驱动、创建连接、创建 statement、关闭连接,资源等繁杂的过程。
MyBatis 通过 xml 或注解两种方式将要执行的各种 sql 语句配置起来,并通过 java 对象和 sql 的
动态参数进行映射生成最终执行的 sql 语句,最后由 mybatis 框架执行 sql 并将结果映射为 java 
对象并返回。
Spring 框架:
Spring 框架为了解决软件开发的复杂性而创建的。Spring 使用的是基本的 JavaBean 来完成以前
非常复杂的企业级开发。Spring 解决了业务对象,功能模块之间的耦合,不仅在 javase,web 中使用,
大部分 Java 应用都可以从 Spring 中受益。
Spring 是一个轻量级控制反转(IoC)和面向切面(AOP)的容器。
SpringMVC 框架
Spring MVC 属于 SpringFrameWork 3.0 版本加入的一个模块,为 Spring 框架提供了构建 Web 
应用程序的能力。现在可以 Spring 框架提供的 SpringMVC 模块实现 web 应用开发,在 web 项目中
可以无缝使用 Spring 和 Spring MVC 框架。

2. 框架是什么?

2.1 框架的定义

框架(Framework)是整个或部分系统的可重用设计,表现为一组抽象构件及构件实例间交互的方

法;另一种认为,框架是可被应用开发者定制的应用骨架、模板。

简单的说,框架其实是半成品软件,就是一组组件,供你使用完成你自己的系统。从另一个角度来

说框架一个舞台,你在舞台上做表演。在框架基础上加入你要完成的功能。

框架安全的,可复用的,不断升级的软件。

2.2 框架解决的问题

框架要解决的最重要的一个问题是技术整合,在 J2EE 的 框架中,有着各种各样的技术,不同的应

用,系统使用不同的技术解决问题。需要从 J2EE 中选择不同的技术,而技术自身的复杂性,有导致更

大的风险。企业在开发软件项目时,主要目的是解决业务问题。 即要求企业负责技术本身,又要求解

决业务问题。这是大多数企业不能完成的。框架把相关的技术融合在一起,企业开发可以集中在业务领

域方面。

另一个方面可以提供开发的效率。

3. JDBC 编程

3.1 使用 JDBC 编程的回顾

public void findStudent() {
 Connection conn = null;
 Statement stmt = null;
 ResultSet rs = null;
 try {
 //注册 mysql 驱动
 Class.forName("com.mysql.jdbc.Driver");
 //连接数据的基本信息 url ,username,password
 String url = "jdbc:mysql://localhost:3306/springdb";
 String username = "root";
 String password = "123456";
 //创建连接对象
 conn = DriverManager.getConnection(url, username, password);
 //保存查询结果
 List<Student> stuList = new ArrayList<>();
 //创建 Statement, 用来执行 sql 语句
 stmt = conn.createStatement();
 //执行查询,创建记录集,
 rs = stmt.executeQuery("select * from student");
 while (rs.next()) {
 Student stu = new Student();
 stu.setId(rs.getInt("id"));
 stu.setName(rs.getString("name"));
 stu.setAge(rs.getInt("age"));
 //从数据库取出数据转为 Student 对象,封装到 List 集合
 stuList.add(stu);
 }
     } catch (Exception e) {
 e.printStackTrace();
 } finally {
 try {
 //关闭资源
 if (rs != null) ;
 {
 rs.close();
 }
 if (stmt != null) {
 stmt.close();
 }
 if (conn != null) {
 conn.close();
 }
 } catch (Exception e) {
 e.printStackTrace();
 }
 }
}

3.2 使用 JDBC 的缺陷

\1. 代码比较多,开发效率低

\2. 需要关注 Connection ,Statement, ResultSet 对象创建和销毁

\3. 对 ResultSet 查询的结果,需要自己封装为 List

\4. 重复的代码比较多些

\5. 业务代码和数据库的操作混在一起

3. MyBatis 框架:

MyBatis 本是 apache 的一个开源项目 iBatis, 2010 年这个项目由 apache software foundation 迁

移到了 google code,并且改名为 MyBatis 。2013 年 11 月迁移到 Github。

iBATIS 一词来源于“internet”和“abatis”的组合,是一个基于 Java 的持久层框架。iBATIS 提供的

持久层框架包括 SQL Maps 和 Data Access Objects(DAOs)

当前,最新版本是 MyBatis 3.5.1 ,其发布时间是 2019 年 4 月 8 日。

3.1 . MyBatis 解决的主要问题

​ 减轻使用 JDBC 的复杂性,不用编写重复的创建 Connetion , Statement ; 不用编写关闭资源代码。直接使用 java 对象,表示结果数据。让开发者专注 SQL 的处理。 其他分心的工作由 MyBatis 代劳。

MyBatis 可以完成:

\1. 注册数据库的驱动,例如 Class.forName(“com.mysql.jdbc.Driver”))

\2. 创建 JDBC 中必须使用的 Connection , Statement, ResultSet 对象

\3. 从 xml 中获取 sql,并执行 sql 语句,把 ResultSet 结果转换 java 对象

List<Student> list = new ArrayLsit<>();

ResultSet rs = state.executeQuery(“select * from student”);

while(rs.next){

 Student student = new Student();

 student.setName(rs.getString(“name”));

 student.setAge(rs.getInt(“age”));

 list.add(student);

}

4.关闭资源

ResultSet.close() , Statement.close() , Conenection.close()

标签:JDBC,架构,框架,rs,Spring,sql,MyBatis,三层
From: https://www.cnblogs.com/atao-BigData/p/16862046.html

相关文章

  • Mybatis 入门
    MyBatis简介: MyBatis是一种JDBC的框架,为了让JDBC更加简洁,快速,易于维护。MyBatis主要从以下几个方面简化JDBC:1.把注册驱动和sql语句这些硬编码,在配置文件中完成2.把手......
  • 【JAVA高级】——初识JDBC中Service业务逻辑层
    ✅作者简介:热爱国学的Java后端开发者,修心和技术同步精进。本文目录​​......
  • 【JAVA高级】——初识JDBC中DAO数据访问对象
    ✅作者简介:热爱国学的Java后端开发者,修心和技术同步精进。本文目录​​......
  • 33、Java——汽车租赁系统(对象+JDBC)
    ✅作者简介:热爱国学的Java后端开发者,修心和技术同步精进。本文目录​​覆盖知识​​​​项目需求​​​​设计步骤 ​​​​开发思路 ​​​​类的属性和方法​​​​代码......
  • 微服务架构
    转载:https://www.cnblogs.com/imyalost/p/6792724.html资料来源:有架构给我的一些资料,以及自己百度和论坛、社区找来的一些资料,权当做一个总结式的简介。。。 目录如下:......
  • Kubernetes(2)_概念和架构
    K8S概述和特性kubernetes,简称K8S,是一个开源的用于管理云平台多个主机上的容器化的应用.k8s是谷歌在2014年开源的容器化集群管理系统适用k8s进行容器化应用部署适......
  • 关于核酸架构思考后感
    看到一个推文,原文地址:https://mp.weixin.qq.com/s/PF26lWFG3ICsK-mlK52mFw 起因是成都核算系统崩溃。成都核酸系统崩溃事件陷“罗生门”_腾讯新闻(qq.com) 一位......
  • 【分布式技术专题】「架构实践于案例分析」盘点高并发场景的技术设计方案和规划
    自知之明是最难得的知识。高并发是什么?⾼并发(HighConcurrency)是互联⽹分布式系统架构设计中必须考虑的因素之⼀,它通常是指通过设计保证系统能够同时并⾏处理很多请求。高并......
  • 快速复习mybatis
    mybatis面试题1.MyBatis特性1)MyBatis是支持定制化SQL、存储过程以及高级映射的优秀的持久层框架2)MyBatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集......
  • shardingsphere-jdbc 水平分表学习记录
    放在自己博客里搬过来一份~前司使用的是自己魔改的TDDL,在家时间比较多就尝试学一些业内比较常用的中间件.这里记录一下学习中遇到的一些问题.环境设置的比较简单(太......