Java Mybatis框架由浅入深全解析上篇
学习路线
什么是三层架构
在项目开发中,遵循一种形式模式,分为三层。
界面层: 用来接收客 户端的输入,调用业务逻辑层进行功能处理,返回结果给客户端.过去的servlet就是界面层的功能.
**业务逻辑层:**用来进行整个项目的业务逻辑处理,向上为界面层提供处理结果,向下问数据访问层要数据.
数据访问层:专门用来进行数据库的增删改查操作,向上为业务逻辑层提供数据.
严格遵守:
各层之间的调用顺序是固定的,不允许跨层访问.
界面层<------->业务逻辑层<------>数据访问层
举个简单的例子:如果你去饭店吃饭,那么第一个见到你的肯定是服务员,你点过菜之后,服务员去找厨师,厨师在做饭之前,先要去仓库找材料,去询问采购员。找到所有的材料之后,厨师开始做饭,最后服务员会把饭给你。要严格遵守的是:顾客不能直接找厨师,也不能直接找采购,那么服务员,厨师,采购员就是这三层,分别与项目开发的 界面层,业务逻辑层,数据访问层,三层对应。
常用的SSM框架(了解)
- Spring:它是整合其它框架的框架.它的核心是IOC和AOP.它由20多个模块构成.在很多领域都提供了很好的解决方案.是一个大佬级别的存在.
- SpringMVC:它是Spring家族的一员.专门用来优化控制器(Servlet)的.提供了极简单数据提交,数据携带,页面跳转等功能.
- MyBatis:是持久化层的一个框架.用来进行数据库访问的优化.专注于sql语句.极大的简化了JDBC的访问.
什么是框架
它是一个半成品软件.
将所有的公共的,重复的功能解决掉,帮助程序快速高效的进行开发.
它是可复用,可扩展的.
它让我们开发更加简单,快捷,只关注主要逻辑的开发
什么是Mybatis框架
MyBatis 本是 apache 的一个开源项目iBatis, 2010 年这个项目由 apache software foundation 迁移到了 google code,并且改名为 MyBatis 。2013 年 11 月迁移到 Github,最新版本是 MyBatis 3.5.7 ,其发布时间是 2021 年 4月 7日。
(划重点,面试可能会问哦!!!)MyBatis完成数据访问层的优化.它专注于sql语句.简化了过去JDBC繁琐的访问机制.
添加框架的步骤
- 添加依赖
- 添加配置文件:pom.xml文件是Mybatis的核心配置文件
具体步骤:
1.新建库建表
#创建数据库ssm
CREATE DATABASE ssm DEFAULT CHARSET utf8;
#使用(打开)ssm数据库
use ssm;
#创建表student
CREATE TABLE `student` (
`id` int(11) AUTO_INCREMENT primary key ,
`name` varchar(255) DEFAULT NULL,
`email` varchar(255) DEFAULT NULL,
`age` int(11) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
insert into student(name,email,age) values('张三','zhangsan@126.com',22);
insert into student(name,email,age) values('李四','lisi@126.com',21);
insert into student(name,email,age) values('王五','wangwu@163.com',22);
insert into student(name,email,age) values('赵六','zhaoliun@qq.com',24);
select * from student;
2.新建maven项目
选quickstart模板
新建空项目,创建模块选择maven项目,选择quicstart 模板创建java项目
3.修改目录
添加缺失的目录,修改目录属性
这里需要注意:新建完成的文件夹还要作为资源,注意新添加的文件 rescoures的颜色
4.修改pom.xml文件
添加MyBatis的依赖,添加mysql的依赖
这里选择的版本不是最新,但是学习足够了,同时也比较稳定
<!--添加MyBatis框架的依赖-->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.6</version>
</dependency>
<!--添加mysql依赖-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.32</version>
</dependency>
修改完成记得刷新,IDEA虽然会自动检测刷新,但是养成良好的习惯
5.修改pom.xml文件
添加资源文件指定
<!--添加资源文件的指定-->
<build>
<resources>
<resource>
<directory>class="lazy" data-src/main/java</directory>
<includes>
<include>***.properties</include>
</includes>
</resource>
<resource>
<directory>class="lazy" data-src/main/resources</directory>
<includes>
<include>***.properties</include>
</includes>
</resource>
</resources>
</build>
到这里我们把依赖和配置完全搞定了,下面是完整的pom.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.longlong</groupId>
<artifactId>mybatis</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.7</maven.compiler.source>
<maven.compiler.target>1.7</maven.compiler.target>
</properties>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<scope>test</scope>
</dependency>
<!--添加MyBatis框架的依赖-->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.6</version>
</dependency>
<!--添加mysql依赖-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.32</version>
</dependency>
</dependencies>
<!--添加资源文件的指定-->
<build>
<resources>
<resource>
<directory>class="lazy" data-src/main/java</directory>
<includes>
<include>***.properties</include>
</includes>
</resource>
<resource>
<directory>class="lazy" data-src/main/resources</directory>
<includes>
<include>***.properties</include>
</includes>
</resource>
</resources>
</build>
</project>
总结
到这里今天的文章就算结束了,今天我们了解了三层架构,SSM框架,Mybatis框架的初步了解,完成了框架的添加。
到此这篇关于Java Mybatis框架由浅入深全解析上篇的文章就介绍到这了,更多相关Java Mybatis内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341