MyBatis快速学习

news2025/1/13 15:33:51

目录

前言

MyBatis的具体使用

一些小工具:MyBatisX

常见问题:

1.表中字段名和实体属性名不一致

2.按条件查询(单条件)时的,查询条件怎么编写

3.按条件查询(多条件)

4.多条件查询时,用户不把所有条件填完

5.单条件查询时,不知道用户到底选了哪一个

6.添加用户怎么写接口和mapper.xml

7.添加信息时,如果要主键增长呢

8.修改信息

9.删除一行数据

10.批量删除☆☆☆

MyBatis注解



前言

为什么要有MyBatis呢?

当然是因为JDBC代码太繁琐啦~

上图标1的代码有很多字符串,而这些是连接数据库的四个基本信息,以后如果要将Mysql数据库换成其他的关系型数据库的话,这四个地方都需要修改,如果放在此处就意味着要修改我们的源代码。

上图标2的代码。如果表结构发生变化,SQL语句就要进行更改。这也不方便后期的维护。

操作很繁琐

使用MyBatis就可以解决这些问题

MyBatis的具体使用

1.创建一个表。

2.导入依赖坐标

3.在项目的resources 目录下创建mybatis的配置文件 mybatis-config.xml 

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "https://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <!--  配置别名  -->
    <!-- 这样的话,就在UserMapper中可以不用设置成这样了   -->
    <!--    <select id="selectAll" resultType="org.example.pojo.User">-->
    <!--    因为在mybatis中配置了别名,所以可以不用谢前面的包名了    -->
<!--    <select id="selectAll" resultType="User">-->
    <typeAliases>
        <package name="org.example.pojo"/>
    </typeAliases>

    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <!--   这一段代码是连接信息             -->
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql:///mybatis?useSSL=false"/>
                <property name="username" value="root"/>
                <property name="password" value="1234"/>
            </dataSource>
        </environment>
    </environments>
    <!-- 指定sql映射的路径   -->
<!--  因为在resource目录上有和src目录下的下相同目录,所以直接可以使用package包的方式  -->
    <mappers>
<!--        <mapper resource="org/example/mapper/UserMapper.xml"/>-->
        <package name="org.example.mapper"/>
    </mappers>
</configuration>

4.创建实体类User

public class User {
    private int id;
    private String username;
    private String password;
    private String gender;
    private String addr;
    
    //省略了 setter 和 getter
}

5.在模块的 resources 目录下创建映射配置文件 UserMapper.xml

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="test">
    <select id="selectAll" resultType="com.itheima.pojo.User">
        select * from tb_user;
    </select>
</mapper>

需要满足这样的目录层级

6.定义UserMapper接口代码

public interface UserMapper {
    List<User> selectAll();
}

注意层级和名称一致问题

7.定义一个测试类进行测试

/**
 * Mybatis 代理开发
 */
public class MyBatisDemo2 {

    public static void main(String[] args) throws IOException {

        //1. 加载mybatis的核心配置文件,获取 SqlSessionFactory
        String resource = "mybatis-config.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

        //2. 获取SqlSession对象,用它来执行sql
        SqlSession sqlSession = sqlSessionFactory.openSession();
        //3. 执行sql
        //3.1 获取UserMapper接口的代理对象
        UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
        List<User> users = userMapper.selectAll();

        System.out.println(users);
        //4. 释放资源
        sqlSession.close();
    }
}

一些小工具:MyBatisX

MyBatisX 插件

  • XML映射配置文件 和 接口方法 间相互跳转

  • 根据接口方法生成 statement

如下图操作就可以完成,生成Mapper.xml文件中的statement

常见问题:

1.表中字段名和实体属性名不一致

使用Mybatis时,可能会出现数据库表的字段名称和实体类的属性名称不一样的问题,这样的话就不能自动封装数据了。

可以resultMap

具体来说:就是在 **Mapper.xml中添加下图红框框住的<resultMap></resultMap>部分,对字段进行映射,下图中前面的字段是数据库中的命名,后面是实体类的属性名。

然后将resultType换成resultMap

2.按条件查询(单条件)时的,查询条件怎么编写

在 **Mapper中这样写,如下图查询条件是id  就这样写#{id}

对于有参数的Mapper接口方法

3.按条件查询(多条件)

可以使用以下三种方法

mapper.xml的编写

在测试类中的调用

4.多条件查询时,用户不把所有条件填完

这个时候就要使用到动态SQL

使用<where></where>标签 和 <if></if>标签

5.单条件查询时,不知道用户到底选了哪一个

这种需求需要使用到 choose(when,otherwise)标签 实现, 而 choose 标签类似于Java 中的switch语句。

6.添加用户怎么写接口和mapper.xml

定义接口

写mapper,使用的是<insert></insert>

封装对象,执行方法

7.添加信息时,如果要主键增长呢

添加 

useGeneratedKeys, keyProperty 关键字

8.修改信息

定义接口

编写mapper.xml

执行方法

9.删除一行数据

10.批量删除☆☆☆

编写SQL时需要遍历数组来拼接SQL语句。Mybatis 提供了 foreach 标签供我们使用

MyBatis注解

注解是用来替换映射配置文件方式配置的,所以使用了注解,就不需要再映射配置文件中书写对应的 statement。

使用注解开发会比配置文件开发更加方便。如下就是使用注解进行开发。

但是对于复杂的SQL语句还是建议使用配置文件的方法。

public interface UserMapper {
    @Insert("INSERT INTO users(username, age) VALUES(#{username}, #{age})")
    int insertUser(User user);
}

public interface UserMapper {
    @Delete("DELETE FROM users WHERE id = #{id}")
    int deleteUserById(@Param("id") int id);
}

public interface UserMapper {
    @Update("UPDATE users SET username = #{username}, age = #{age} WHERE id = #{id}")
    int updateUser(User user);
}

public interface UserMapper {
    @Select("SELECT * FROM users WHERE id = #{id}")
    User selectUserById(@Param("id") int id);
    
    // 查询所有用户
    @Select("SELECT * FROM users")
    List<User> selectAllUsers();
}

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

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

相关文章

需要增重的小猫看过来!猫咪很瘦吃不胖是怎么回事?增重猫罐头推荐!

前几天医院来了只小母猫&#xff0c;7个月了&#xff0c;现在刚5斤。主人反映她平时干饭积极&#xff0c;能吃能睡&#xff0c;能喝能拉&#xff0c;就是不长肉。虽然大家都说母猫确实没有公猫容易胖&#xff0c;但是这只猫咪确实也长得也太慢了。其实我们医院接到过不少这样的…

对于springboot无法连接redis解决方案

对于springboot无法连接redis解决方案 一、测试是否能在本地应用上访问到你的redis&#xff08;如果是部署在linux上的话&#xff09;1. 开启telnet功能2. 开始测试端口是否能访问到&#xff08;适用于所有&#xff0c;包括MQ&#xff09;3. 开放6379端口4. 看spring的配置文件…

CANdela/Diva系列5--CANdela Studio的Data Types功能介绍

Data Types在CDD文件中是一个很重要的部分&#xff0c;它能够便捷地解析DID/RID的数据内容和0x19服务的相关子服务&#xff0c;同时能够能够全局定义一些变量&#xff0c;达到整个CDD文件公用的效果。 目录 1. Raw Value: 2. Text Table: 3. Linear: 4. Characteristic Cu…

生活需要BGM,悠律凝声环开放式耳机全场景通用

如今&#xff0c;BGM围绕着我们的生活&#xff0c;音乐是生活的调料品&#xff0c;深受运动爱好者的喜爱&#xff0c;不但能够缓解锻炼时的单调&#xff0c;也能够更好地激发我们的身体状态。最近我入手的悠律凝声环ringbuds pro就是这样一款特别适合运动场景使用。 开放式耳机…

go语言day22 gin-vue-admin全栈项目的依赖安装

flipped-aurora/gin-vue-admin: &#x1f680;ViteVue3Gin的开发基础平台&#xff0c;支持TS和JS混用。它集成了JWT鉴权、权限管理、动态路由、显隐可控组件、分页封装、多点登录拦截、资源权限、上传下载、代码生成器【可AI辅助】、表单生成器和可配置的导入导出等开发必备功能…

从零开始学习性能测试

学习目标 理解性能测试定义、目的理解常见性能测试策略理解性能指标理解性能测试方法学习性能测试工具 什么是性能测试 测试中的非功能测试其实范围比较广&#xff0c;性能、稳定性、安全性等都可以放进这个范畴。非功能测试&#xff0c;一般比功能测试门槛高些&#xff0c;多数…

谷歌账号被停用了,申诉界面可以下载数据,有必要吗?有用吗?

有的朋友在使用谷歌账号的时候&#xff0c;登录遇到“您的账号已停用”的情形。 这个界面提示说可以下载账号相关的数据&#xff0c;那么&#xff0c;谷歌账号被停用后如何下载自己谷歌账号的数据呢&#xff1f;能下载哪些数据Une&#xff1f;下载的数据有用吗&#xff1f; 这…

记录|MVS和VM软件使用记录

目录 前言一、常用属性二、触发模式选择三、操作注意点四、录像、抓拍功能五、VM软件六、VM软件界面介绍七、VM软件运行间隔八、VM软件图像源九、VM软件相机管理十、获取图像十一、方案存储十一、相机拍摄彩图转换颜色转换快速匹配特征模板&#xff1a;运行参数 十二、位置修正…

力扣热题100_二叉树_226_翻转二叉树

文章目录 题目链接解题思路解题代码 题目链接 226. 翻转二叉树 给你一棵二叉树的根节点 root &#xff0c;翻转这棵二叉树&#xff0c;并返回其根节点。 示例 1&#xff1a; 输入&#xff1a;root [4,2,7,1,3,6,9] 输出&#xff1a;[4,7,2,9,6,3,1] 示例 2&#xff1a; …

63 变量的作用域

变量起作用的代码范围称为变量的作用域&#xff0c;不同作用域内同名变量之间互不影响。在函数外部和函数内部定义的变量&#xff0c;其作用域是不同的&#xff0c;函数内部定义的变量一般为局部变量&#xff0c;在函数外部定义的变量为全局变量。不管是局部变量还是全局变量&a…

【网络安全】探索AI 聊天机器人工作流程实现RCE

未经许可,不得转载。 文章目录 前言正文前言 我发现了一个广泛使用的AI聊天机器人平台中的远程代码执行漏洞。该漏洞存在于聊天机器人的自定义工作流响应代码中,这些工作流允许开发人员通过创建定制的流程来扩展机器人的功能。 正文 在浏览自动化聊天机器人的多个特定功能…

爱国者vs格行vs吉客猫随身wifi综合测评!哪款随身WiFi最好用?随身wifi哪个品牌性价比最高?随身WiFi哪个网速最快?

近两年&#xff0c;随身WiFi作为便携上网的解决方案&#xff0c;备受欢迎。不过市场上品牌众多&#xff0c;各有千秋。今天&#xff0c;我们将聚焦于爱国者、格行以及吉客猫这三个热门品牌&#xff0c;通过详细对比&#xff0c;为您揭示每款随身WiFi的特点和区别&#xff0c;方…

VMware14安装图文

1.下载 通过百度网盘分享的文件&#xff1a;VMware14安装图文 链接&#xff1a;https://pan.baidu.com/s/1t2kHDphI_z1guqp0P-NO_A 提取码&#xff1a;q3j0 --来自百度网盘超级会员V3的分享 2.安装

Python程序组成部分

此文为《Python入门经典以解决计算问题为导向的Python编程实践》27-31页的笔记。 程序组成部分 一、模块二、表达式和语句三、空白缩进续行 四、注释五、特殊元素1、关键字2、运算符3、标点符号&#xff08;又名分隔符&#xff09;4、字面量 六、对象命名&#xff08;很重要&a…

十七.核心动画 - 使用重复图层(CAReplicatorLayer)构建自定义loading视图.

引言 本篇博客我们来详细的讨论一下CAReplicatorLayer图层&#xff0c;它是一个功能非常强大的工具&#xff0c;允许我们通过重复图层来创建复杂且高效的动画效果&#xff0c;无论是加载动画&#xff0c;粒子效果&#xff0c;还是其它重复性的图形动画&#xff0c;CAReplicato…

init.rc及其一些语法

1&#xff0c;rc文件 on property:同时判断两个条件 拷打gbt on property:sys.usb.configncm,adb 这是什么意思 config是ncm或adb 这是一个Android系统的属性&#xff0c;它表示USB接口的配置。"ncm"代表使用NCM&#xff08;Network Control Model&#xff09;协议…

11、Fawkes

难度 高 目标 2个root 3个flag 当我看到这种类型我就知道肯定是docker系列的连锁环境了 netdiscover -i eth0 -r 192.168.189.0/24 kali 192.168.189.58 靶机 192.168.189.69 扫描一下开放的端口和服务识别 应该是存在ftp 的匿名访问&#xff0c;然后还有一个monkeycom&…

【Material-UI】Autocomplete 组件中的自定义过滤功能(Custom filter)详解

文章目录 一、简介二、createFilterOptions 工厂函数配置选项返回值示例代码代码解释 三、高级自定义&#xff1a;模糊匹配四、实际应用场景1. 数据清理和标准化2. 特定业务逻辑 五、总结 Material-UI 的 Autocomplete 组件不仅提供了强大的自动完成功能&#xff0c;还允许开发…

Prometheus监控组件在SpringBoot项目中使用实践

Prometheus监控组件在SpringBoot项目中使用实践 时间&#xff1a;2024/7/29 背景&#xff1a;本人最近参与的一个项目&#xff0c;要监控远程软硬件以及本地软硬件&#xff0c;实现远程监控以及告警功能。 开发环境&#xff1a; JDK1.8&#xff0c;Maven&#xff0c;PostgreS…

automa自动化工作流教程(三)循环元素进行操作

循环元素 选择器选中的必须是多个元素&#xff0c;如果是css选择器&#xff0c;举例&#xff1a;class属性有多个 .postTitle 并且要生成或填上循环id 有开发需求 call me