Mybatis基于注解与XML开发

这篇具有很好参考价值的文章主要介绍了Mybatis基于注解与XML开发。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1 关于SpringBoot

  • SpringBoot是一个基于Spring框架的快速开发的脚手架,它能够帮助我们开发者快速搭建项目环境,并提供了一些建议的配置方式,降低了开发者程序的开发和部署难度。

2 关于MyBatis

2.1 MyBatis概述

  • MyBatis是Java的持久化框架,目的是为了使操作数据库更加方便、灵活、高效。可以通过Java注解和XML文件来映射Java对象和SQL语句,提供了非常灵活的SQL编写方式和动态SQL语句的创建方式,可以与Spring框架结合使用。

2.2 MyBatis核心思想

  • 将Java对象和数据库操作分离,通过注解和XML映射文件映射到数据库的字段上,并提供相应的API来操作数据库。可以自动将SQL语句转为JDBC代码,并根据指定的返回值类型生成对应的结果提供给开发者使用。

2.3 MyBatis使用流程

  1. 配置MyBatis环境
    在pom.xml中添加相关依赖:MyBatis Framework 和 MySQL Driver
  2. 配置文件中配置数据库的连接信息(application.properties)
     spring.datasource.url=jdbc:mysql://localhost:3306/blog?characterEncoding=utf8&serverTimezone=Asia/Shanghai
      spring.datasource.username=root
      spring.datasource.password=root
  1. 定义pojo类,和数据表做好映射关系
  2. 编写Dao层接口,在接口中定义操作数据库的方法,在注解或者XML文件中实现具体的SQL语句。
      @Mapper
      public interface UserMapper{
          @Insert("INSERT INTO user VALUES(NULL,#{username})")
          int insert(User user);
      }
  1. 使用
       // 1.自动装配
       @Autowired
       private UserMapper userMapper
       
       // 2.调用方法
       userMpper.insert(...)

3 MyBatis配置SQL方式

3.1 基于注解方式

3.1.1 说明

  • 基于注解方式省去了配置XML文件的编写工作,并且可以很方便的完成一些 简单的 CRUD操作,但是对于一些复杂的SQL语句使用起来会很冗余。

3.1.2 使用流程

  • (maven工程)在pom.xml中添加MyBatis和MySQL相关的依赖
  • 在配置文件中(application.properties)配置数据库的连接信息
  • 创建实体类,和数据库中的表做好对应关系
  • 配置Mapper接口,在接口中添加@Mapper注解,告诉底层为此接口创建实现类,在实现类中定义数据访问的逻辑,执行与数据库的会话
  • 在接口中定义方法,在方法上使用注解标注SQL语句的类型,可以使用的注解有:@Insert、@Dlelete、@Update、@Select
    如果SQL语句中涉及到多个参数,可以使用@Param注解给每个参数取名。
  • 自动装配并在应用程序中使用即可
     @Autowired
      private XxxMapper xxxMapper;
      
      xxxMapper.接口中的方法(参数...);

3.1.3 常用注解

  • @Insert(“SQL”)
  • @Dlelete(“SQL”)
  • @Update(“SQL”)
  • @Select(“SQL”)

3.2 基于XML方式

3.2.1 相比注解优势

  • 更好的可读性
    XML文件具有良好的结构和语义,可以使JAVA代码和SQL语句彻底分离,便于管理和优化。注解配置SQL语句可能使JAVA代码变的冗长。
  • 更好的复用性
    将SQL语句写入XML文件中,通过 和标签 将重复的SQL抽取并引用,从而提高了SQL语句的复用性。
  • 更好的支持动态SQL
    动态SQL语句是根据运行时的参数来生成的SQL,复杂性较高,使用XML文件更加方便。

3.2.2 使用流程

  • 添加依赖:pom.xml
  • 配置数据源:application.propertis
  • 配置xml文件的扫描路径:application.properties
  • 创建实体类,做好和数据表的对应关系
  • 定义接口,添加@Mapper注解,并定义接口中的方法
  • 创建xml文件,使用标签配置SQL


  • 装配使用
      @Autowired
      private XxxMapper xxxMapper;
      
    xxxMapper.接口方法(参数...);

3.2.3 常用标签

  • insert标签
  • delelte标签
  • update标签
  • select标签
    使用select标签需要指定 resultType 的属性值
  • foreache标签:用于动态删除
      <delete id="xxx">
      	DELETE FROM xxx WHERE id in(
          	<foreache collection="对象类型" item="变量名" separator="分隔符">
          		#{变量名}
          	</foreache>
          )
      </delete>
  • set标签和if标签:用于动态修改
      <update id="xxx">
      	UPDATE xxx 
          <set>
          	<if test="属性名!=null">字段名=#{属性名},</if>
              <if test="属性名!=null">字段名=#{属性名},</if>
              <if test="属性名!=null">字段名=#{属性名}</if>
          </set>
      </update>
  • sql标签和include标签:用于SQL语句的复用
      <!--1.重复SQL抽取-->
      <sql id="selectSql">
          SELECT * FROM xxx
      </sql>
      
      <select id="xxx" resultType="xxx">
          <include refid="selectSql"></include>
      </select>
      
      <select id="yyy" resultType="yyy">
          <include refid="selectSql"></include> WHERE id&gt;5
      </select>

文章来源地址https://www.toymoban.com/news/detail-610086.html

到了这里,关于Mybatis基于注解与XML开发的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Spring Boot入门(10):Mybatis之XML映射文件中如何使用特殊符号?揭秘<、<=等符号的正确使用方法!

            在Mybatis的XML映射文件中,我们经常需要使用一些特殊符号来完成SQL语句的拼接,比如小于号“”、小于等于号“=”等。然而,由于这些符号在XML中有特殊的含义,因此直接在映射文件中使用可能会导致编译错误或者运行时异常。那么,如何才能正确地使用这些特殊

    2024年02月09日
    浏览(49)
  • MyBatis第二课,灰度发布,@Results注解,使用xml书写mysql

      目录 打印MyBatis的日志配置: 灰度发布:指发布环境,比如发布环境有200台机器,发布的时候是一批一批的机器的发布 2.删除与修改 使用@Results注解,这样就和上面的别名一个意思,column是数据库的列 自动转驼峰(优雅,最推荐使用) 学习XML的方式 MyBatis:用于去简化数据库

    2024年01月17日
    浏览(39)
  • Spring xml 方式整合mybatis 第三方框架

    MyBatis提供了mybatis-spring.jar专门用于两大框架的整合。 ①:第一步: 导入MyBatis整合Spring的相关坐标; ②:第二步: 编写Mapper和Mapper.xml ③:第三步: 配置SqlSessionFactoryBean和MapperScannerConfigurer ④:第四步: 编写测试代码

    2024年02月13日
    浏览(64)
  • Spring IOC基于XML和注解管理Bean(二)

    Spring IOC基于XML和注解管理Bean(一) 2.9、实验八:p命名空间 引入p命名空间 引入p命名空间后,可以通过以下方式为bean的各个属性赋值 2.10、实验九:引入外部属性文件 ①加入依赖 ②创建外部属性文件 [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

    2024年02月09日
    浏览(46)
  • Spring IOC基于XML和注解管理Bean(一)

    Spring IOC基于XML和注解管理Bean(二) IoC 是 Inversion of Control 的简写,译为“ 控制反转 ”,它不是一门技术,而是一种设计思想,是一个重要的面向对象编程法则,能够指导我们如何设计出 松耦合 、更优良的程序。 Spring 通过 IoC 容器来管理所有 Java 对象的实例化和初始化,控

    2024年02月08日
    浏览(78)
  • Spring注解驱动开发之常用注解案例_告别在XML中配置Bean

    注解驱动开发就是不再使用Spring的bean.xml文件,改为纯使用注解的方式开发 @Configuration 此注解为配置类注解,相当于spring.xml文件,即配置类==配置文件 @Bean 给容器中注册一个Bean;类型为返回值的类型,id默认是用方法名作为id 示例 Person类(后续注解配置类中都会以此类举例),

    2024年01月21日
    浏览(51)
  • 深入实现 MyBatis 底层机制的任务阶段4 - 开发 Mapper 接口和 Mapper.xml

    😀前言 在我们的自定义 MyBatis 底层机制实现过程中,我们已经深入研究了多个任务阶段,包括配置文件的读取、数据库连接的建立、执行器的编写,以及 SqlSession 的封装。每个任务阶段都为我们揭示了 MyBatis 内部工作原理的一部分,为构建完整的底层框架打下了坚实的基础

    2024年02月09日
    浏览(47)
  • Spring的注解开发-注解方式整合MyBatis代码实现

    之前使用xml方式整合了MyBatis,文章导航:Spring整合第三方框架-MyBatis整合Spring实现-CSDN博客 现在使用注解的方式无非是就是将xml标签替换为注解,将xml配置文件替换为配置类而已。 非自定义配置类                 与数据库建立连接的同时,扫描指定的mapper接口,实现实现

    2024年02月07日
    浏览(54)
  • Spring Boot学习随笔- 集成JSP模板(配置视图解析器)、整合Mybatis(@MapperScan注解的使用)

    学习视频:【编程不良人】2021年SpringBoot最新最全教程 在main创建webapp,然后创建index.jsp进行测试,在访问之前需要进行一个设置,否则springboot是找不到jsp页面的 修改jsp无需重启应用 数据库访问框架:hibernate、jpa、mybatis【主流】 SpringBoot(微框架) = Spring(工厂) + SpringMV

    2024年02月05日
    浏览(52)
  • 常用mybatis的XML

    2024年02月07日
    浏览(39)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包