一、MyBatis概述
MyBatis 是一款优秀的持久层框架,ORM框架(对象映射框架),它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。
数据库表(table)–> 类(class)
记录(record,行数据)–> 对象(object)
字段(field) --> 对象的属性(attribute)
MyBatis 也是一个半自动化的框架,所谓的半自动,是因为还需要手动的写 SQL 语句,再由框架根据 SQL 及 传入数据来组装为要执行的 SQL。其优点为:
因为由程序员自己写 SQL,相对来说学习门槛更低,更容易入门。
更方便做 SQL的性能优化及维护。
对关系型数据库的模型要求不高,这样在做数据库模型调整时,影响不会太大。适合软件需求变更比较频繁的系统,因此国内系统大部分都是使用如 Mybatis 这样的半自动 ORM 框架。其缺陷为:
不能跨数据库,因为写的 SQL 可能存在某数据库特有的语法或关键词
MyBatis是一款优秀的Java持久层框架,它封装了JDBC,使开发者只需要关注Sql语句本身,二不需要花费精力去处理加载驱动,创建连接、创建Statement等繁杂的过程。
MyBatis通过xml或注解的方式将要执行的各种statement配置起来,并通过java对象和statement中sql的动态参数进行映射生成最终执行的sql语句,最后由MyBatis框架执行sql并将结果映射为java对象并返回。
采用ORM思想解决了实体和数据库映射的问题,对JDBC进行了封装,屏蔽了JDBC API底层访问细节,是我们不用与JDBC API打交道,就可以完成对数据库的持久化操作。
二、Hibernate
Hibernate是一种典型的全自动 ORM 框架,所谓的全自动,是 SQL 语句都不用在编写,基于框架的API,可以将对象自动的组装为要执行的 SQL 语句。其优点为:
全自动 ORM 框架,自动的组装为 SQL 语句。
可以跨数据库,框架提供了多套主流数据库的 SQL 生成规则。
其缺点为:
1、学习门槛更高,要学习框架 API 与 SQL 之间的转换关系
2、对数据库模型依赖非常大,在软件需求变更频繁的系统中,会导致非常难以调整及维护。可能数据库中随便改一个表或字段的定义,Java代码中要修改几十处。
3、很难定位问题,也很难进行性能优化:需要精通框架,对数据库模型设计也非常熟悉。
三、为什么需要Mybatis
帮助程序猿将数据存入到数据库中。·方便
传统的JDBC代码太复杂了。
简化。框架。自动化。不用Mybatis也可以。
更容易上手。技术没有高低之分。
优点: 简单,易学,灵活
sql和代码的分离,提高了可维护性。
提供映射标签,支持对象与数据库的orm字段关系映射。提供对象关系映射标签,支持对象关系组建维护
提供xml标签,支持编写动态sql。
四、Mybatis的使用步骤
1、先引入框架,添加依赖(在pom.xml文件中添加mybatis框架和MySQL)
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.1.3</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
2、配置信息
在application.properties配置文件中进行配置(连接数据信息mapper. xml文做规则),配置文件每行后面不要有空格
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/mydb?characterEncoding=utf8&useSSL=true
spring.datasource.username=root
spring.datasource.password=12345678
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
# 2.mybatis 扫描mapper 路径下的所有Mapper.xml文件
mybatis.mapper-locations=classpath:mapper//Mapper.xml
# 3.开启mybaits的sql执行日志
logging.level.com.example.demo.mapper=debug
3、声明映射接口
@Mapper
public interface UserMapper {
// 添加用户方法(注册功能)
public int addUser(User user);
4、mapper. xml——> mybatis 映射(sql),SQL语句就写在mapper. xml中
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.demo.mapper.UserMapper">
<!--namespace要实现的接口的全路径-->
<!--id="addUser"表示要实现的接口中的方法,parameterType="com.example.demo.model.User"表示参数类的全路径-->
<insert id="addUser" parameterType="com.example.demo.model.User"
useGeneratedKeys="true" keyProperty="id" keyColumn="id">
insert into userinfo(username,password,photo)
values(
#{username},#{password},#{photo}
)
</insert>
</mapper>
5、直接调用
@Resource
private UserMapper userMapper;
User user = new User();
user.setUsername(username);
user.setPassword(password);
user.setPhoto(AppFinal.IMAGE_PAHT + fileName); //设置头像地址
int result = userMapper.addUser(user);