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

news2024/12/23 8:46:24

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 configuration
        PUBLIC "-//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:设置默认使用的环境的id
        environment
            配置某个具体的环境
            属性:id 表示连接数据库环境的唯一标识,不能重复 -->
    
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
<!--          transactionManager:设置事务管理的方式
                属性 JDBC | MANAGED
                JDBC:表示当前环境中,执行SQL时使用的是JDBC中原生的事务管理方式,事务的提交或回滚需要手动处理
                MANAGED:被管理,例如Spring
              dataSource:配置数据源
                type:设置数据源的类型
                    type:POOLED | UNPOOLED | JNDI
                    POOLED:表示使用数据库连接池缓存数据库连接
                    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;

    @Before
    public void init(){
        //获取sqlSession对象
        sqlSession = SqlSessionUtil.getSqlSession();

        //获取UserMapper的代理实现类对象
        mapper = sqlSession.getMapper(SelectMapper.class);
    }

    @Test
    public void run(){


    }


    @After
    public void destroy(){
        //提交事务
        //sqlSession.commit();
        //关闭资源
        sqlSession.close();
        SqlSessionUtil.inputStreamClose();
    }

}


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

在这里插入图片描述

public interface UserMapper {

}
<?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.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.coloradmin.cn/o/1700145.html

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

相关文章

【CTF Web】CTFShow web7 Writeup(SQL注入+PHP+进制转换)

web7 1 阿呆得到最高指示&#xff0c;如果还出问题&#xff0c;就卷铺盖滚蛋&#xff0c;阿呆心在流血。 解法 注意到&#xff1a; <!-- flag in id 1000 -->拦截很多种字符&#xff0c;连 select 也不给用了。 if(preg_match("/\|\"|or|\||\-|\\\|\/|\\*|\…

宿舍管理系统代码详解(操作界面)

目录 一、前端代码 1.样式展示 2.代码详解 <1>主页面列表部分 &#xff08;1&#xff09;template部分 &#xff08;2&#xff09;script部分 <2>新增页面 &#xff08;1&#xff09;template部分 &#xff08;2&#xff09;script部分 <3>修改页面…

C++初阶学习第九弹——探索STL奥秘(四)——vector的深层挖掘和模拟实现

string&#xff08;上&#xff09;&#xff1a;C初阶学习第六弹——探索STL奥秘&#xff08;一&#xff09;——标准库中的string类-CSDN博客 string&#xff08;下&#xff09;&#xff1a;C初阶学习第七弹——探索STL奥秘&#xff08;二&#xff09;——string的模拟实现-CS…

访问tomcat的webapps下war包,页面空白

SpringBootvue前后端分离项目&#xff0c;Vue打包到SpringBoot中 常见问题 错误一&#xff1a;war包访问页面空白 前提&#xff1a;项目在IDEA里配置tomcat可以启动访问项目 但是&#xff0c;打成war包拷贝到tomcat webapps下能启动却访问不了&#xff0c;页面显示空白 原…

孜然多程序授权系统V2.0开源

源码介绍 孜然一款多程序授权系统&#xff0c;支持自定义权限价格/新增程序配置等支持自动生成授权代码在线签到在线充值多支付接口IP/域名云黑文章系统&#xff08;富文本编辑器&#xff09;卡密功能一键云黑&#xff08;挂个大马/一键黑页/一键删库/一键删源码&#xff09; …

linux 阿里云服务器安装ImageMagick和php扩展imagick

操作系统版本 Alibaba Cloud Linux 3.2104 LTS 64位 # 1.安装ImageMagick yum install -y ImageMagick ImageMagick-devel # 没有pecl要先安装pecl 和头文件 sudo yum install php-devel # 2.pecl 安装扩展 pecl install imagick #寻找所有php.ini文件 find / -name php.…

基于EV54Y39A PIC-IOT WA的手指数量检测功能开发(MPLAB+ADC)

目录 项目介绍硬件介绍项目设计开发环境及工程参考总体流程图硬件基本配置光照传感器读取定时器检测逻辑 功能展示项目总结 &#x1f449; 【Funpack3-2】基于EV54Y39A PIC-IOT WA的手指数量检测功能开发 &#x1f449; Github: EmbeddedCamerata/PIC-IOT_finger_recognition 项…

42-5 应急响应之日志分析

一、Windows 系统日志排查 1)日志概述 在 Windows 2000 专业版、Windows XP 和 Windows Server 2003 中: 系统日志的位置为 C:\WINDOWS\System32\config\SysEvent.evt安全性日志的位置为 C:\WINDOWS\System32\config\SecEvent.evt应用程序日志的位置为 C:\WINNT\System32\c…

在Windows中安装Redis

一、下载Redis github链接&#xff1a;https://github.com/redis-windows/redis-windows/releases 二、安装 解压后点击start.bat文件即可启动服务 新开一个cmd窗口进入安装了Redis的文件夹输入redis-cli.exe -h 127.0.0.1 -p 6379连接Redis&#xff0c;见如下结果便是成功&…

第六节:带你全面理解vue3 浅层响应式API: shallowRef, shallowReactive, shallowReadonly

前言 前面两章,给大家讲解了vue3中ref, reactive,readonly创建响应式数据的API, 以及常用的计算属性computed, 侦听器watch,watchEffect的使用 其中reactive, ref, readonly创建的响应式数据都是深层响应. 而本章主要给大家讲解以上三个API 对应的创建浅层响应式数据的 API,…

VUE3 学习笔记(3):VUE模板理念、属性绑定、条件渲染、列表渲染

准备 1.清空不必要的项目文件 项目/src/assets/ 目录文件清空 项目/src/components/ 目录文件清空 删除main.js 的css引用 App.vue 代码如下 <template> </template> <script>//注意这里默认有一个setup 去掉 </script> 运行一下无错误提示就可以了…

【教学类-58-05】黑白三角拼图05(2-10宫格,每个宫格随机1张-6张,带空格纸,1页3张黑白3张白卡)

背景需求&#xff1a; 【教学类-58-04】黑白三角拼图04&#xff08;2-10宫格&#xff0c;每个宫格随机1张-6张&#xff0c;带空格纸&#xff0c;1页6张黑白&#xff0c;1张6张白卡&#xff09;-CSDN博客文章浏览阅读582次&#xff0c;点赞16次&#xff0c;收藏3次。【教学类-58…

无人机的相关基础知识(看不懂了 待定以后继续补充)

视频&#xff1a; 【浙江大学】浙大博导带你从0制作无人机_哔哩哔哩_bilibili 什么是无人飞行器 无人机自主导航构架 IMU&#xff08;加速度计和陀螺仪&#xff09;&#xff0c;可以测出当前的 加速度和角速度 这俩信息再去融合外部传感器 &#xff08;例如视觉传感器或者雷…

一款网站源码下载开源工具 Website Downloader

一、简介 Website Downloader 是一款免费的网站源码下载器&#xff0c;下载任何网站的完整源代码&#xff0c;包括 JavaScript、样式表、图像等等&#xff0c;而且使用也非常简单&#xff0c;只需要粘贴网址&#xff0c;用户即可将网页链接内容下载到本地&#xff0c;而且自动…

文件操作知识点

前言: 我们应该知道一般程序运行时产生的数据是存放在内存中的。但是如果程序关闭后这些内存就会被系统回收&#xff0c;如果内存内的有用的数据没有被保存下来&#xff0c;这些数据就丢失了。所以这个时候我们就可以使用磁盘来储存我们的数据。 目录 程序文件的分类 文件名…

Jenkins 流水线(Pipeline)详解

大家好&#xff0c;Jenkins 流水线&#xff08;Pipeline&#xff09;是一种可编排的持续集成和交付&#xff08;CI/CD&#xff09;方法&#xff0c;它以代码的方式定义整个软件开发过程中的构建、测试和部署流程。接下来就跟大家分享一下Jenkins 流水线&#xff08;Pipeline&am…

MySQL:图文超详细教程MySQL5.7下载与安装

一、前言 MySQL 5.7 是一个重要的数据库管理系统版本&#xff0c;它带来了多项改进和新特性&#xff0c;本文将超详细的带大家手动安装一下MySQL5.7。 二、下载MySQL5.7版本 MySQL5.7安装包 链接&#xff1a;https://pan.baidu.com/s/1lz5rp9PwfyeHzkEfI_lW6A 提取码&#…

基于小波分析和机器学习(SVM,KNN,NB,MLP)的癫痫脑电图检测(MATLAB环境)

癫痫是一种由大脑神经元突发性异常放电导致的大脑功能性障碍疾病。据世界卫生组织统计&#xff0c;全球约有7000万人患有癫痫。癫痫患者在发病时呈现肌肉抽搐、呼吸困难、意识丧失等症状。由于癫痫发作的偶然性&#xff0c;患者极有可能在高空、驾驶、游泳等危险情况下发病并丧…

基于混合Transformer-CNN模型的多分辨率学习方法的解剖学标志检测

文章目录 Anatomical Landmark Detection Using a Multiresolution Learning Approach with a Hybrid Transformer-CNN Model摘要方法实验结果 Anatomical Landmark Detection Using a Multiresolution Learning Approach with a Hybrid Transformer-CNN Model 摘要 精确定位…