MyBatis框架的使用:mybatis介绍+环境搭建+基础sql的使用+如何使用Map传入多个参数+返回多个实体用List或者Map接收+特殊sql的使用

MyBatis框架的使用:mybatis介绍+环境搭建+基础sql的使用+如何使用Map传入多个参数+返回多个实体用List或者Map接收+特殊sql的使用

    • 一、MyBatis介绍
      • 1.1 特性
      • 1.2 下载地址
      • 1.3 和其它持久层技术对比
    • 二、搭建环境
      • 2.1配置maven
      • 2.2 创建mybatis配置文件
      • 2.3 搭建测试环境
    • 三、基础的sql语句
      • 3.1 配置接口
      • 3.2 配置映射文件
      • 3.3 map集合类型的参数
    • 四、各种查询功能的实现
    • 五、特殊的sql语句

一、MyBatis介绍

1.1 特性

1) MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架

2) MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集

3) MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录

4) MyBatis 是一个半自动的ORM(Object Relation Mapping)框架

1.2 下载地址

在github上下载,在里面可以挑选我们需要的版本
https://github.com/mybatis/mybatis-3

1.3 和其它持久层技术对比

JDBC

  • SQL 夹杂在Java代码中耦合度高,导致硬编码内伤

  • 维护不易且实际开发需求中 SQL 有变化,频繁修改的情况多见

  • 代码冗长,开发效率低

Hibernate和JPA

  • 操作简便,开发效率高
  • 程序中的长难复杂 SQL 需要绕过框架
  • 内部自动生产的 SQL,不容易做特殊优化
  • 基于全映射的全自动框架,大量字段的 POJO 进行部分映射时比较困难。
  • 反射操作太多,导致数据库性能下降

Mybatis

  • 轻量级,性能出色
  • SQL 和 Java 编码分开,功能边界清晰。Java代码专注业务、SQL语句专注数据
  • 开发效率稍逊于Hibernate,但是完全能够接受

二、搭建环境

新建maven项目

2.1配置maven

在这里插入图片描述

加入pom依赖

<dependencies><!-- Mybatis核心 --><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.5.7</version></dependency><!-- junit测试 --><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope></dependency><!-- MySQL驱动 --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.6</version></dependency><!-- log4j日志 --><dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</version></dependency></dependencies>

2.2 创建mybatis配置文件

习惯上命名为mybatis-config.xml,这个文件名仅仅只是建议,并非强制要求。将来整合Spring 之后,这个配置文件可以省略

核心配置文件主要用于配置连接数据库的环境以及MyBatis的全局配置信息

在这里插入图片描述

在标签中,使用引入属性文件 ,这里跟数据库的配置一一对应

    <properties resource="jdbc.properties"></properties>
  • < typeAliases > 标签设置类型别名,对于实体类可以直接使用类名,不区分大小写
  • < environments >配置数据库环境
  • < transactionManager >设置事务管理
  • < dataSource >设置数据源

这里数据库中的驱动jdbc.driver跟jdbc.properties文件中的value值对应

引入mybatis映射文件的方式有两种:

  • 直接引入,映射文件有多个的话需要一个一个的引入

  • 以包为单位引入,将包下的映射文件全部引入

    注意第二种方式:

    1.mapper接口所在的包要和映射文件所在的包一致

    2.mapper接口要和映射文件的名字一致

MySQL不同版本的注意事项

1、驱动类driver-class-name

MySQL 5版本使用jdbc5驱动,驱动类使用:com.mysql.jdbc.Driver

MySQL 8版本使用jdbc8驱动,驱动类使用:com.mysql.cj.jdbc.Driver

2、连接地址url

MySQL 5版本的url:

jdbc:mysql://localhost:3306/ssm

MySQL 8版本的url:

jdbc:mysql://localhost:3306/ssm?serverTimezone=UTC

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><properties resource="jdbc.properties"></properties>
<!--    设置类型的别名--><typeAliases>
<!--    typeAliases 设置类型别名 以包为单位,将包下所有的类型设置默认的类型别名,即类名,且不区分大小写 --><package name="com.entity"/></typeAliases><!--    数据库环境-->
<!--    environments配置多个连接数据库的环境default:设置默认使用的环境的idenvironment配置某个具体的环境属性:id 表示连接数据库环境的唯一标识,不能重复 --><environments default="development"><environment id="development"><transactionManager type="JDBC"/>
<!--          transactionManager:设置事务管理的方式属性 JDBC | MANAGEDJDBC:表示当前环境中,执行SQL时使用的是JDBC中原生的事务管理方式,事务的提交或回滚需要手动处理MANAGED:被管理,例如SpringdataSource:配置数据源type:设置数据源的类型type:POOLED | UNPOOLED | JNDIPOOLED:表示使用数据库连接池缓存数据库连接UNPOOLED:表示不使用数据库连接池缓存数据库连接JNDI:表示使用上下文中的数据源--><dataSource type="POOLED">
<!--                设置数据库的驱动--><property name="driver" value="${jdbc.driver}"/>
<!--                设置数据库的链接地址--><property name="url" value="${jdbc.url}"/>
<!--                设置连接数据库的用户名--><property name="username" value="root"/>
<!--                 设置连接数据库的密码--><property name="password" value="2020"/></dataSource></environment></environments>
<!--    引入mybatis映射文件-->
<!--    方式一-->
<!--    <mappers>-->
<!--        <mapper resource="mappers/UserMapper.xml"/>-->
<!--    </mappers>-->
<!--    方式二-->
<!--    以包为单位引入映射文件要求:mapper接口所在的包要和映射文件所在的包一致mapper接口要和映射文件的名字一致
--><mappers><package name="com.mapper"/></mappers>
</configuration>

创建属性文件,配置数据库连接的key-value值

在这里插入图片描述

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/mybatis_demo

接下来建好各级层次的包,尤其要注意com.mapper这里有两个,在resources下的目录是放置映射文件的,这两个包名需要对应

在这里插入图片描述

2.3 搭建测试环境

在utils下新建SqlSessionUtil类

package com.util;import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;import java.io.IOException;
import java.io.InputStream;public class SqlSessionUtil {//获取核心配置文件的输入流private static InputStream inputStream = null;public static SqlSession getSqlSession(){SqlSession sqlSession = null;try {inputStream = Resources.getResourceAsStream("mybatis-config.xml");//获取SqlSessionFactoryBuilder对象SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();//获取SqlSessionFactory对象SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(inputStream);//获取SqlSession对象,不会自动提交事务//SqlSession sqlSession = sqlSessionFactory.openSession();//获取SqlSession对象,会自动提交事务sqlSession = sqlSessionFactory.openSession(true);} catch (IOException e) {e.printStackTrace();}return sqlSession;}public static void inputStreamClose(){try {inputStream.close();} catch (IOException e) {e.printStackTrace();}}
}

SqlSession:代表Java程序和数据库之间的会话(HttpSession是Java程序和浏览器之间的会话)

SqlSessionFactory:是“生产”SqlSession的“工厂”

工厂模式:如果创建某一个对象,使用的过程基本固定,就可以把创建这个对象的相关代码封装到一个“工厂类”中,以后都使用这个工厂类来“生产”所需要的对象。

然后在test.java下新建测试类SelectMapperTest,在run方法中编写需要测试的内容

public class SelectMapperTest {private SqlSession sqlSession = null;private SelectMapper mapper = null;@Beforepublic void init(){//获取sqlSession对象sqlSession = SqlSessionUtil.getSqlSession();//获取UserMapper的代理实现类对象mapper = sqlSession.getMapper(SelectMapper.class);}@Testpublic void run(){}@Afterpublic void destroy(){//提交事务//sqlSession.commit();//关闭资源sqlSession.close();SqlSessionUtil.inputStreamClose();}}

接下来可以在com.mapper中创建接口,在resource下的com.mapper中创建配置文件

在这里插入图片描述

public interface UserMapper {}
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"><!-- 接口文件所在的包-->
<mapper namespace="com.mapper.UserMapper"></mapper>

三、基础的sql语句

测试用的数据库信息

在这里插入图片描述

使用sql之前,在entity生成实体类User

3.1 配置接口

/**
* 插入
* @param user
* @return
*/
int insertUser(User user);
/**
* 删除
* @return
*/
void deleteUser();/*** 更新用户信息* @return*/
int updateUser();
/*** 查询用户信息*/
List<User> findUser();/*** 根据用户名查询用户信息*/
User getUserByUserName(String userName);
/*** 根据用户名和年龄查询用户信息*/
User gerUserByUserNameAndAge(@Param("userName") String userName,@Param("age") Integer age);

这里的注解@Param里面的内容与映射文件中的变量名对应

MyBatis获取参数值的两种方式:${}和#{}

  • ${}的本质就是字符串拼接,采用sql拼接,无法防止sql注入
  • #{}的本质就是占位符赋值 ,采用预编译 防止sql注入

如果mapper接口中的方法参数为单个的字面量类型,此时可以使用#{}和 以任意的名称获取参数的值,如果使用 {}以任意的名称获取参数的值,如果使用 以任意的名称获取参数的值,如果使用{},注意需要手动添加单引号

如果mapper接口中的方法参数为多个时,此时MyBatis会自动将这些参数放在一个map集合(key,value)中,以arg0, arg1…为键,以参数为值;或者以param1, param2…为键,以参数为值。因此只需要通过#{}和 访问 m a p 集合的键就可以获取相对于的值,如果使用 {}访问map集合的键就可以获取相对于的值,如果使用 访问map集合的键就可以获取相对于的值,如果使用{},注意需要手动添加单引号。

3.2 配置映射文件

查询的标签select必须设置属性resultType或resultMap,用于设置实体类和数据库表的映射 关系

resultType:自动映射,用于属性名和表中字段名一致的情况

resultMap:自定义映射,用于一对多或多对一或字段名和属性名不一致的情况

<insert id="insertUser">insert into user values(null ,#{userName},#{password},#{age},#{sex},#{email});
</insert><delete id="deleteUser">delete from user where id = 2;
</delete><update id="updateUser">update user set userName="李明" ,password="123456" where id = 3;
</update><select id="findUser" resultType="com.entity.User">select * from user;
</select><select id="getUserByUserName" resultType="user">select * from user where userName='${userName}';
</select><select id="gerUserByUserNameAndAge" resultType="user">select  * from user where userName='${userName}' and age = '${age}';
</select>

3.3 map集合类型的参数

如果mapper接口中的方法参数为多个时,此时可以手动创建一个map集合,将这些参数放在map集合中,只需要通过#{}和 访问 m a p 集合的键(自己定义的键)就可以获取相对于的值,如果使用 {}访问map集合的键(自己定义的键)就可以获取相对于的值,如果使用 访问map集合的键(自己定义的键)就可以获取相对于的值,如果使用{},注意需要手动添加单引号。

接口,byMap方法传入一个Map

User byMap(Map<String , Object> map);

映射文件,userName是用户名,age是年龄,大括号里面的是自定义的,传入的map也应该使用这两个变量名

<select id="byMap" resultType="user">select  * from user where userName='${userName}' and age = '${age}';
</select>

测试类,查询指定姓名和年龄的用户

Map<String,Object> map=new HashMap<>();map.put("age",18);
map.put("userName","李明");
System.out.println(mapper.byMap(map));

四、各种查询功能的实现

配置接口

public interface SelectMapper {/*** 根据id查询用户信息** @param id* @return*/User getUserById(@Param("id") Integer id);/*** 查询所有用户信息,不确定有多少用户可以用集合* @return*/List<User> getAllUser();/**** 获取数量* @return*/Integer getCount();/*** 查询单个用户信息,返回一个map* @param id* @return*/Map<String,Object> getUserByIdToMap(Integer id);/*** 方式一:* 查询所有,结果返回一个list* @return*/List<Map<String,Object>> getAllUserToList();/*** 方式二:* 加入注解,返回一个  id:用户信息  的map* @return*/@MapKey("id")Map<String,Object> getAllUserToMap();}

配置映射文件

<select id="getUserById" resultType="user">select * from user where id = #{id};
</select><select id="getAllUser" resultType="user">select * from user;
</select><select id="getCount" resultType="java.lang.Integer">select count(*) from user;
</select><select id="getUserByIdToMap" resultType="map">select * from user where id = #{id};
</select><select id="getAllUserToList" resultType="map">select * from user;
</select><select id="getAllUserToMap" resultType="map">select * from user;
</select>

getUserByIdToMap查询单个用户信息,返回一个map

Map<String,Object> map = mapper.getUserByIdToMap(3);
System.out.println(map);

在这里插入图片描述

getAllUserToList查询所有,结果返回一个list

System.out.println(mapper.getAllUserToList());

在这里插入图片描述

getAllUserToMap加入注解,返回一个 id:用户信息 的map

System.out.println(mapper.getAllUserToMap());

在这里插入图片描述

五、特殊的sql语句

/*** 模糊查询* @param temp* @return*/
List<User> getUserLike(@Param("temp") String temp);/*** 批量删除* @param ids*/
void deleteMoreUser(@Param("ids") String ids);
    <select id="getUserLike" resultType="user">
<!--1. select * from user where userName like concat('%',#{temp},'%')  会使可移植性变差2.select * from user where userName like ”%“#{temp}“%”3.select * from user where userName like '%${temp}%';-->select * from user where userName like '%${temp}%';</select><delete id="deleteMoreUser" ><--这里注意使用${}的方式,且不能加单引号-->delete from user where id in(${ids});</delete>

模糊查询中字符串的拼接有三种方式,temp是传入的值

  • select * from user where userName like concat(‘%’,#{temp},‘%’)
  • select * from user where userName like ”%“#{temp}“%”
  • select * from user where userName like ‘%${temp}%’
System.out.println(mapper.getUserLike("lm"));

在这里插入图片描述

mapper.deleteMoreUser("10,11");

这里的10,11是需要删除信息的id范围

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/841987.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JAVA:Spring Boot整合MyBatis Plus持久层

1、简述 MyBatis Plus是MyBatis的增强工具包&#xff0c;它在MyBatis的基础上进行了扩展&#xff0c;提供了许多便捷的功能&#xff0c;例如通用CRUD操作、分页插件、代码生成器等。使用MyBatis Plus&#xff0c;开发者可以更加方便地进行持久层操作&#xff0c;并且减少了很多…

自动驾驶---Perception之IPM图和BEV图

1 前言 IPM&#xff08;Inverse Perspective Mapping&#xff0c;逆透视变换&#xff09;图的历史可以追溯到计算机视觉和图像处理领域的发展。逆透视变换是一种用于消除图像中透视效应的技术&#xff0c;使得原本由于透视产生的形变得以纠正&#xff0c;进而更准确地描述和理解…

【优选算法】位运算 {位运算符及其优先级;位运算的应用:判断位,打开位,关闭位,转置位,位图,get lowbit,close lowbit;相关编程题解析}

一、位运算符及其优先级 我们知道&#xff0c;计算机中的数在内存中都是以二进制形式进行存储的 &#xff0c;而位运算就是直接对整数在内存中的二进制位进行操作&#xff0c;因此其执行效率非常高&#xff0c;在程序中尽量使用位运算进行操作&#xff0c;这会大大提高程序的性…

04_前端三大件JS

文章目录 JavaScript1.JS的组成部分2.JS引入2.1 直接在head中通过一对script标签定义脚本代码2.2创建JS函数池文件&#xff0c;所有html文件共享调用 3.JS的数据类型和运算符4.分支结构5.循环结构6.JS函数的声明7.JS中自定义对象8.JS_JSON在客户端使用8.1JSON串格式8.2JSON在前…

弘君资本股市行情:股指预计保持震荡上扬格局 关注汽车、银行等板块

弘君资本指出&#xff0c;近期商场体现全体分化&#xff0c;指数层面上看&#xff0c;沪指一路震动上行&#xff0c;创出年内新高&#xff0c;创业板指和科创50指数体现相对较弱&#xff0c;依然是底部震动走势。从盘面体现上看&#xff0c;轮动依然是当时商场的主基调&#xf…

IBERT眼图扫描(高速收发器八)

前文讲解了GTX的时钟及收发数据通道的组成&#xff0c;之后讲解了眼图、加重、均衡等原理及原因&#xff0c;本文通过xilinx提供的IBERT IP完成实际工程的眼图扫描&#xff0c;确定加重和幅值调节的参数。 1、回环模式 在此之前&#xff0c;需要了解一下GTX的回环模式。如果板…

【字典树(前缀树) 字符串】2416. 字符串的前缀分数和

本文涉及知识点 字典树&#xff08;前缀树) 字符串 LeetCode 2416. 字符串的前缀分数和 给你一个长度为 n 的数组 words &#xff0c;该数组由 非空 字符串组成。 定义字符串 word 的 分数 等于以 word 作为 前缀 的 words[i] 的数目。 例如&#xff0c;如果 words [“a”,…

【list】list库介绍 + 简化模拟实现

本节博客先对list进行用法介绍&#xff0c;再在库的基础上简化其内容和形式&#xff0c;简单进行模拟实现&#xff0c;有需要借鉴即可。 目录 1.list介绍1.1 list概述1.2相关接口的介绍 2.简化模拟实现3.各部分的细节详述3.1结点3.2迭代器细节1&#xff1a;迭代器用原生指针还是…

【Codesys】-执行第三方程序,或Windows脚本

该记录旨在解决RTE作为第一个Windows的一个exe程序不能调用其他程序的问题。 可以实现:在PLC界面打开第三方程序、在PLC界面关闭本机Windows操作系统 首先添加依赖库-SysProcess,3.5.17.0 然后在程序里执行相应的指令&#xff0c;该指令可以被Windows识别为类似于执行Bat文件…

国产操作系统上使用rsync恢复用户数据 _ 统信 _ 麒麟 _ 中科方德

原文链接&#xff1a;国产操作系统上使用rsync恢复用户数据 | 统信 | 麒麟 | 中科方德 Hello&#xff0c;大家好啊&#xff01;今天给大家带来一篇关于在国产操作系统上使用rsync备份并还原用户数据的文章。rsync是一款功能强大的文件同步和备份工具&#xff0c;广泛用于Linux系…

河南乙级道路与桥梁资质年审材料准备要点解析

河南乙级道路与桥梁资质年审材料准备要点解析如下&#xff1a;河南宽信权经理 一、企业基本情况材料 营业执照副本复印件&#xff1a;确保复印件清晰、完整&#xff0c;并加盖企业公章。 企业章程&#xff1a;提供最新的企业章程&#xff0c;并加盖企业公章。此材料需反映企业…

代码随想录——从前序与中序遍历序列构造二叉树(Leetcode105)

题目链接 递归 /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode() {}* TreeNode(int val) { this.val val; }* TreeNode(int val, TreeNode left, TreeNode right) {* …

Linux(三)

Linux&#xff08;三&#xff09; Linux网络配置管理网络基础知识 IP地址A类 由1个字节网络地址3个字节主机地址B类 由2个字节网络地址2个主机地址C类 由3个字节网络地址1个主机地址D类:主要用于组播E类:为将来使用保留 子网掩码子网掩码作用网关DNS服务器 Linux用户管理用户的…

linux创建离线yum源给局域网机器使用

适用场景&#xff1a;在封闭的内网环境中&#xff0c;无法使用互联网进行安装各种rpm包的时候&#xff0c;离线yum源可以解决大部分问题&#xff0c;配置号后可直接使用yum进行安装包 1.准备好镜像源ISO&#xff1a; 例如以下示例&#xff0c;具体可参考自己的系统进行下载&a…

新书推荐:7.3 for语句

本节必须掌握的知识点&#xff1a; 示例二十四 代码分析 汇编解析 7.3.1 示例二十四 ■for语句语法形式&#xff1a; for(表达式1;表达式2;表达式3) { 语句块; } ●语法解析&#xff1a; 第一步&#xff1a;执行表达式1&#xff0c;表达式1初始化循环变量&#xff1b; …

【错题集-编程题】kotori 和迷宫(BFS / DFS)

牛客对应题目链接&#xff1a;kotori和迷宫 (nowcoder.com) 一、分析题目 迷宫问题的扩展。 二、代码 #include <iostream> #include <cstring> #include <queue>using namespace std;const int N 35; int x1, y1; // 标记起点位置 int n, m; char arr[N][…

电机控制系列模块解析(23)—— 同步机初始位置辨识

一、两个常见问题 为什么感应电机&#xff08;异步机&#xff09;不需要初始位置辨识&#xff1f;&#xff08;因此感应电机转子磁场在定子侧进行励磁&#xff0c;其初始位置可以始终人为定义为0&#xff09; 为什么同步磁阻电机需要初始位置辨识&#xff1f;&#xff08;因为…

五分钟搭建一个Suno AI音乐站点

五分钟搭建一个Suno AI音乐站点 在这个数字化时代&#xff0c;人工智能技术正以惊人的速度改变着我们的生活方式和创造方式。音乐作为一种最直接、最感性的艺术形式&#xff0c;自然也成为了人工智能技术的应用场景之一。今天&#xff0c;我们将以Vue和Node.js为基础&#xff…

【软件设计师】计算机组成原理

1、数据的表示 1.1 进制转换 整型有4种进制形式&#xff1a; 1.十进制&#xff08;D&#xff09;&#xff1a; 都是以0-9这九个数字组成&#xff0c;不能以0开头。 2.二进制&#xff08;B&#xff09;&#xff1a; 由0和1两个数字组成。 3.八进制&#xff08;O&#xff09;&am…

嵌入式进阶——数码管

&#x1f3ac; 秋野酱&#xff1a;《个人主页》 &#x1f525; 个人专栏:《Java专栏》《Python专栏》 ⛺️心若有所向往,何惧道阻且长 文章目录 数码管结构移位寄存器原理图移位寄存器数据流程移位寄存器控制流程移位寄存器串联实现数码管显示 数码管结构 共阴与共阳 共阳数码…