首页 > 数据库 >MyBatis 3种 使用 SQL 语句的方式;注解方式、注解提供器方式、XML 配置方式

MyBatis 3种 使用 SQL 语句的方式;注解方式、注解提供器方式、XML 配置方式

时间:2024-09-13 12:15:40浏览次数:7  
标签:XML 语句 方式 代码 SQL 注解

结论:为了统一使用方式,建议采用XML配置的方式;


MyBatis 提供了多种配置和使用 SQL 语句的方式,主要包括:注解方式(如 @Select)、注解提供器方式(如 @SelectProvider)和 XML 配置方式。每种方式都有其独特的优缺点,适用于不同的场景。以下是这三种方式的详细对比:

1. @Select 这类注解

优点

  • 简洁直观:SQL 语句直接写在注解中,与接口方法紧密结合,便于阅读和维护。
  • 编译时检查:注解中的 SQL 语句在编译时就能被检测到,减少运行时错误。
  • 减少配置文件:不需要额外的 XML 文件,减少了项目的复杂性。

缺点

  • 复杂 SQL 支持不足:对于动态 SQL 或特别复杂的 SQL 语句,注解方式可能显得力不从心。
  • 可读性问题:当 SQL 语句较长或包含复杂逻辑时,注解可能会使代码显得混乱。
  • 灵活性差:SQL 语句在注解中写死后,不易于动态修改或扩展。

适用场景

  • 适用于简单的查询操作,如单表查询、插入、更新、删除等。
  • 团队对代码整洁度和维护性要求较高,且 SQL 语句相对简单的情况。

2. @SelectProvider 这类注解

优点

  • 动态 SQL 支持:通过提供器方法,可以动态生成 SQL 语句,支持复杂的 SQL 逻辑。
  • 代码复用:提供器方法可以被多个注解共享,减少代码重复。
  • 灵活性高:可以在运行时动态生成 SQL,适应不同的业务需求。

缺点

  • 代码复杂度增加:需要额外编写提供器方法,增加了代码的复杂性。
  • 调试困难:动态生成的 SQL 语句在调试时可能不如静态 SQL 直观。
  • 虽然注解方式也支持通过@SelectProvider等注解来动态生成SQL,但在复杂性和灵活性方面通常不如XML配置。

适用场景

  • 适用于需要动态生成 SQL 语句的复杂查询场景。
  • 项目中存在大量相似但不完全相同的 SQL 语句,需要代码复用的情况。

3. XML 配置方式

优点

  • 灵活性高:支持复杂的 SQL 语句和动态 SQL,易于管理和维护。
  • 分离职责:SQL 语句与 Java 代码分离,便于独立测试和修改。
  • 易于扩展:XML 文件可以方便地添加新的 SQL 语句,不影响现有代码。

缺点

  • 文件繁多:当项目规模较大时,可能需要管理大量的 XML 文件。
  • 阅读不便:需要在多个文件之间切换,不如注解方式直观。
  • 编译时检查不足:XML 文件中的错误通常只能在运行时被发现。

适用场景

  • 适用于大型项目,SQL 语句复杂且需要频繁修改的情况。
  • 团队对 SQL 语句和 Java 代码分离有明确要求,或需要独立测试 SQL 语句的情况。

总结

  • @Select 等注解:适用于简单、直观的 SQL 语句,便于快速开发和维护。
  • @SelectProvider 等提供器注解:适用于需要动态生成 SQL 语句的复杂查询场景,提高代码复用性。
  • XML 配置方式:适用于大型项目或 SQL 语句特别复杂的情况,提供高灵活性和易于扩展的维护方式。

根据项目的实际需求和团队的开发习惯,可以选择最适合的方式来配置和使用 MyBatis。

标签:XML,语句,方式,代码,SQL,注解
From: https://www.cnblogs.com/del88/p/18411968

相关文章

  • YAML 与 JSON、XML 比较及 YAML 使用最佳实践
    YAML(YAMLAin'tMarkupLanguage的递归缩写)是一种人类可读的数据序列化格式,通常用于配置文件、数据交换和设置管理。它简洁且易于读写,尤其适合在编程语言之间传递配置数据。以下是一些YAML的基本概念和语法示例:基本语法键值对:name:JohnDoeage:30嵌套:person:name:JohnDoe......
  • 一个Android App最少有几个线程?实现多线程的方式有哪些?
    本文首发于公众号“AntDream”,欢迎微信搜索“AntDream”或扫描文章底部二维码关注,和我一起每天进步一点点多线程编程是Android应用开发中非常重要的一个环节,可以有效地提升应用的性能和用户体验。下面是对Android中多线程相关内容的详细介绍,包括app最少有几个线程。1.基本概念主线......
  • PbootCMS模板禁止数字id方式访问栏目,如/1/
    在PbootCMS中,如果你希望禁止用户通过直接输入数字ID的方式访问栏目,比如通过URL /1/ 进行访问,可以采取以下几种策略来实现这一目标:1.修改URL规则1.1重写规则配置.htaccess文件:编辑网站根目录下的 .htaccess 文件,增加或修改URL重写规则,使得所有数字ID的访......
  • springcloud间通信的方式
    在SpringCloud中,主要有以下几种通信方式:一、基于HTTP的RESTfulAPI工作原理:这是一种常见的通信方式,各个微服务通过发送HTTP请求来相互调用。服务提供者暴露RESTfulAPI接口,服务消费者通过HTTP客户端(如RestTemplate、Feign等)发送请求。例如,一个订单服务需要......
  • 书法只是东方族群自由的心灵生活方式
     雷家林艺术真正有最高价值的,不是他的画和传统书法,而是现代派书法,或水墨书法,在现代书道艺术中增添了新的东西……雷家林:因为我倾向钟繇,有好多老钟的笔意,比如那个当,这算婴儿风格吧,别讨厌婴儿风格,赤子风格乃上乘书道了,所谓思无邪,很高的境界。#书法真的是毁于创新吗?#正好......
  • dotnet OpenXML SDK 添加 CoreFilePropertiesPart 的方法
    本文记录在OpenXMLSDK2.15版本下,为PPTX文件添加CoreFilePropertiesPart的方法,通过本文的方法可以正确且简单的添加core.xml文件到PPTX文件里当前的OpenXMLSDK存在已知问题,那就是默认情况下生成不包含core.xml文件,请参阅https://github.com/dotnet/Open-XML-SDK......
  • 【linux】一种基于虚拟串口的方式使两个应用通讯
    在Linux系统中,两个应用之间通过串口(SerialPort)进行通信是一种常见的通信方式,特别是在嵌入式系统、工业自动化等领域。串口通信通常涉及到对串口设备的配置和读写操作。以下是一个基本的步骤指南,说明如何在Linux中设置两个应用以通过串口进行通信:1.确认串口设备首先,你需要确......
  • python 异步的几种方式
    importasyncioimportrandomimportthreadingfromconcurrent.futuresimportThreadPoolExecutorimporttimedefblocking_task(x):time.sleep(2)thread_name()print(f'arg:{x}\n')returnx*2asyncdefunblocking_task(x):t......
  • 寻址方式
    在嵌入式系统设计课程中,寻址方式(AddressingModes)是指处理器或控制器在执行指令时如何访问操作数或指令中的数据。寻址方式分为指令寻址和数据寻址1.指令寻址(InstructionAddressing)指令寻址是指寻找下一条将要执行的指令地址。指令寻址包括顺序寻址、跳跃寻址*顺序寻址:程序......
  • PbootCMS生成的sitemap.xml中增加tag标签链接
    //指定分类标签调用publicfunctiongetSortTags($scode){$join=array(array('ay_content_sortb','a.scode=b.scode','LEFT'),array('ay_modelc......