我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mybatis中怎么配置注解

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mybatis中怎么配置注解

mybatis中怎么配置注解,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

注解与xml配置的对应关系

mybatis中注解就是简单不需要写配置文件,适合简单的数据处理,理解起来比较容易,不动态生成SQL时候可以用用。

需要绑定,有些时候不如配置文件,配置文件扩展强。 选择合适的方式应用在合适的场景,注解主要应用于sql语句比较简单容易理解的情况下可读性高;生成动态sql时用xml配置文件要更简洁,扩展性强

常用的注解和xml的对应关系

  • @CacheNamespace 类 <cache>

  • @CacheNamespaceRef 类 <cacheRef>

  • @Results 方法 <resultMap>

  • @Result 方法 <result> <id>

  • @One 方法 <association>

  • @Many 方法 <collection>

  • @select <select>

  • @Insert <insert>

  • @Update <update>

  • @Delete 方法 <delete>

  • @InsertProvider <insert> 允许创建动态SQL

  • @UpdateProvider <update> 允许创建动态SQL

  • @DeleteProvider <delete> 允许创建动态SQL

  • @SelectProvider <select> 允许创建动态SQL

  • @Param 参数 N/A 如果你的映射器的方法需要多个参数, 这个注解可以被应用于映射器的方法 参数来给每个参数一个名字。否则,多 参数将会以它们的顺序位置来被命名 (不包括任何 RowBounds 参数) 比如。 #{param1} , #{param2} 等 , 这 是 默 认 的 。 使用 @Param(“person”),参数应该被命名为 #{person}。

  • @Options 方法 映射语句的属性 这个注解提供访问交换和配置选项的 宽广范围, 它们通常在映射语句上作为 属性出现。 而不是将每条语句注解变复 杂,Options 注解提供连贯清晰的方式 来访问它们

注解样例和xml配置样例

举几个比较典型和常用的

一对一关联查询

注解方式
@Select("select * from authority") @Results(id="au", value=@Result(column="uid",      property="user",      one=@One(select="findUserByid",           fetchType=FetchType.LAZY))) List<Authority> findAll();
  • @Select里面填写要查询的主表的sql语句

  • @Results里面映射一个id="au"的返回结果集

  • value=@Result()表示某一属性的映射关系

  • column为对应从表的外键名

  • property为主表实体类的从表实体类属性名

  • one表示一对一映射

  • fetchType=FetchType.LAZY表示为惰性加载,当查询的结构数据需要用到从表的数据才会调用select中的从表的查询方法

  • select为关联查询的另一个从表的查询方法

  • uid为select里的参数

  • findUserByid为mapper中定义的方法

@Select("select * from user where id = #{id}") User findUserByid(int id);

此方法可以在xml中配置也可以在本方法中用注解配置

xml中配置方式
<resultMap type="com.jt.mybatis.entity.Authority" id="au">    <association property="user" column="uid" javaType="com.jt.mybatis.entity.User"      select="findByUserId">    </association></resultMap><select id="findAll" resultMap="au">  select * from authority</select><select id="findUserByid" resultType="com.jt.mybatis.entity.User">  select * from user where id= #{id}</select>

测试方法

@Test public void testA(){  AuthorityMapper mapper = session.getMapper(AuthorityMapper.class);  mapper.findAll().get(0).getUser(); }

一对多关联查询

xml配置方式

<resultMap type="com.jt.mybatis.entity.User" id="user">      <id column="id" property="id" />      <collection property="authoritieList" column="id"       fetchType="lazy" select="findAuthorityByUid">       <id column="id" property="id" />      </collection>    </resultMap> <select id="findUserByUserName" resultMap="user">  select * from user  where username = #{username} </select>  <select id="findAuthorityByUid" resultType="com.jt.mybatis.entity.Authority">  select * from  authority where uid = #{uid} </select>
注解方式
@Select("select * from user where username = #{username}")@Results(id="user",value=@Result(column="id",property="authoritieList",many=@Many(fetchType=FetchType.LAZY,select="findAuthorityByUid")))User findUserByUserName(String username);@Select("select * from authority where uid = #{uid}")List<Authority> findAuthorityByUid(int uid);

many表示一对多映射

测试方法

@Testpublic void testB(){ AuthorityMapper mapper = session.getMapper(AuthorityMapper.class); mapper.findUserByUserName("admin").getAuthoritieList();}

动态sql

注解方式
@SelectProvider(type=AuthorityProvider.class,method="returnSelectSQL") List<Authority> findByIdAndUid(Authority authority); class AuthorityProvider{  public String returnSelectSQL(Authority authority){   SQL sql = new SQL(){{    SELECT("*");    FROM("authority");    if(authority.getId() != 0){     WHERE("id = " + authority.getId());    }    if(authority.getUid() != 0){     WHERE("uid = " + authority.getUid());    }   }};   return sql.toString();  } } //用XXXProvider的注解是动态生成sql语句的, //type=AuthorityProvider.class为生成动态语句的具体类 //method="returnSelectSQL"为生成动态语句的方法 //SQL类为动态生成sql的类

测试方法

@Test public void testC(){  AuthorityMapper mapper = session.getMapper(AuthorityMapper.class);  Authority authority = new Authority();  mapper.findByIdAndUid(authority);  //执行此语句返回的sql语句为DEBUG [main] - ==>  Preparing: SELECT * FROM authority  authority.setId(1);  mapper.findByIdAndUid(authority);  //执行此语句返回的sql语句为DEBUG [main] - ==>  Preparing: SELECT * FROM authority WHERE (id = 1)  authority.setUid(2);  mapper.findByIdAndUid(authority);  //执行此语句返回的sql语句为DEBUG [main] - ==>  Preparing: SELECT * FROM authority WHERE (id = 1 AND uid = 2)  }

mybatis 注解和xml 优缺点

xml:

增加了xml文件,修改麻烦,条件不确定(ifelse判断),容易出错,特殊转义字符比如大于小于

注释:

  复杂sql不好用,搜集sql不方便,管理不方便,修改需重新编译

#和$区别:

相同

  • 都是对参数进行标记的符号

  • #是预编译,防止sql注入

  • $ 相当于一个占位符,不能防止sql注入

看完上述内容,你们掌握mybatis中怎么配置注解的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网行业资讯频道,感谢各位的阅读!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mybatis中怎么配置注解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mybatis中怎么配置注解

mybatis中怎么配置注解,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。注解与xml配置的对应关系mybatis中注解就是简单不需要写配置文件,适合简单的数据处理,理解起来比
2023-06-20

MyBatis中怎么使用注解方式配置映射关系

在 MyBatis 中使用注解方式配置映射关系可以通过使用 @Select, @Insert, @Update, @Delete 等注解来配置 SQL 语句,并通过 @Results, @Result, @ResultMap 等注解来配置结
MyBatis中怎么使用注解方式配置映射关系
2024-03-07

mybatis学习笔记之mybatis注解配置详解

Java API既然你已经知道如何配置 MyBatis 和创建映射文件,你就已经准备好来提升技能了。 MyBatis 的 Java API 就是你收获你所做的努力的地方。正如你即将看到的,和 JDBC 相比, MyBatis 很大程度简化了
2023-05-30

MyBatis ORM的注解配置与XML配置的抉择

在MyBatis ORM中,注解配置和XML配置各有其优缺点,适用于不同的场景和需求。以下是两种配置方式的详细对比:注解配置优点:简洁性:减少了大量的XML配置文件,使得代码更加简洁,易于阅读和维护。开发效率:在开发初期,可以快速编写和
MyBatis ORM的注解配置与XML配置的抉择
2024-09-11

Mybatis中怎么配置typeAlias标签

Mybatis中怎么配置typeAlias标签,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Mybatis typeAlias标签在实际的工程之中,类的全限定名
2023-06-20

mybatis-plus在yml中配置详解

本文主要介绍了mybatis-plus在yml中配置详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-02-24

Quartz注解方式怎么配置

本篇内容主要讲解“Quartz注解方式怎么配置”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Quartz注解方式怎么配置”吧!一:目录结构二:统一配置文件context-datasource.p
2023-06-04

怎么在MyBatis中对properties进行配置

本篇文章为大家展示了怎么在MyBatis中对properties进行配置,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。这些属性都是可外部配置且可动态替换的,既可以在典型的 Java 属性文件中配置,
2023-05-30

SpringBoot Mybatis怎么配置文件

这篇文章主要介绍“SpringBoot Mybatis怎么配置文件”,在日常操作中,相信很多人在SpringBoot Mybatis怎么配置文件问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”SpringBoo
2023-07-05

SpringBoot中@ConfigurationProperties注解怎么实现配置绑定

本篇内容介绍了“SpringBoot中@ConfigurationProperties注解怎么实现配置绑定”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能
2023-06-30

Mybatis-Plus全局配置无效怎么解决

这篇“Mybatis-Plus全局配置无效怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Mybatis-Plus全局
2023-06-26

MyBatis @Select注解怎么使用

这篇文章主要介绍“MyBatis @Select注解怎么使用”,在日常操作中,相信很多人在MyBatis @Select注解怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MyBatis @Select
2023-07-02

MyBatis @Param注解怎么实现

本文小编为大家详细介绍“MyBatis @Param注解怎么实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“MyBatis @Param注解怎么实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。先说结论:当输
2023-06-29

怎么配置MyBatis的数据源

要配置MyBatis的数据源,首先需要在MyBatis的配置文件中指定数据源的信息。以下是一个示例配置文件:
怎么配置MyBatis的数据源
2024-03-07

SpringBoot2底层注解@Configuration怎么配置类

这篇文章主要讲解了“SpringBoot2底层注解@Configuration怎么配置类”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“SpringBoot2底层注解@Configuratio
2023-06-30

怎么在struts2中利用注解对Action进行配置

怎么在struts2中利用注解对Action进行配置?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。 使用注解来配置Action可以实现零配置,零配置将从基于纯X
2023-05-30

详解MyBatis iterate参数配置

MyBatis 的 标签用于在 SQL 查询中遍历集合,例如在 WHERE 子句中使用 IN 条件。` 标签有一些参数可以配置,以下是这些参数的详细解释:collection:要遍历的集合名称。这个集合可以是一个 List、Map 或者数组
详解MyBatis iterate参数配置
2024-09-19

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录