iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >mybatis中怎么配置注解
  • 619
分享到

mybatis中怎么配置注解

2023-06-20 19:06:15 619人浏览 独家记忆
摘要

mybatis中怎么配置注解,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。注解与xml配置的对应关系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中怎么配置注解的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网精选频道,感谢各位的阅读!

--结束END--

本文标题: mybatis中怎么配置注解

本文链接: https://www.lsjlt.com/news/299551.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • mybatis中怎么配置注解
    mybatis中怎么配置注解,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。注解与xml配置的对应关系mybatis中注解就是简单不需要写配置文件,适合简单的数据处理,理解起来比...
    99+
    2023-06-20
  • MyBatis中怎么使用注解方式配置映射关系
    在 MyBatis 中使用注解方式配置映射关系可以通过使用 @Select, @Insert, @Update, @Del...
    99+
    2024-03-07
    MyBatis
  • mybatis学习笔记之mybatis注解配置详解
    Java API既然你已经知道如何配置 MyBatis 和创建映射文件,你就已经准备好来提升技能了。 MyBatis 的 Java API 就是你收获你所做的努力的地方。正如你即将看到的,和 JDBC 相比, MyBatis 很大程度简化了...
    99+
    2023-05-30
    mybatis 注解 配置
  • Mybatis中怎么配置typeAlias标签
    Mybatis中怎么配置typeAlias标签,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Mybatis typeAlias标签在实际的工程之中,类的全限定名...
    99+
    2023-06-20
  • Mybatis配置详解
    mybatis 1、mybatis的作用2、封装JDBC3、mybatis基于XML配置4、Mapper代理开发 1、mybatis的作用 再MVC三层模式中mybatis作用于...
    99+
    2023-10-25
    mybatis java spring mysql maven
  • springboot整合mybatis+Mysql(配置模式+注解模式)
    一.简单介绍 ❝ 配置相关的依赖 2.配置模式 3写.mapper、controller、service 4.配置yaml文件 配置mybatis全局配置文件 (这里我使用的是配置模式+注解模式所以需要配置全...
    99+
    2023-09-24
    mybatis spring boot mysql
  • mybatis-plus在yml中配置详解
    目录pom配置正常使用基础配置扩展配置pom配置 <dependency> <groupId>com.baomidou</groupId>...
    99+
    2023-02-24
    mybatis-plus yml配置 mybatis-plus yml
  • Quartz注解方式怎么配置
    本篇内容主要讲解“Quartz注解方式怎么配置”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Quartz注解方式怎么配置”吧!一:目录结构二:统一配置文件context-datasource.p...
    99+
    2023-06-04
  • 怎么在MyBatis中对properties进行配置
    本篇文章为大家展示了怎么在MyBatis中对properties进行配置,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。这些属性都是可外部配置且可动态替换的,既可以在典型的 Java 属性文件中配置,...
    99+
    2023-05-30
    mybatis properties
  • Mybatis-Plus全局配置无效怎么解决
    这篇“Mybatis-Plus全局配置无效怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Mybatis-Plus全局...
    99+
    2023-06-26
  • SpringBoot Mybatis怎么配置文件
    这篇文章主要介绍“SpringBoot Mybatis怎么配置文件”,在日常操作中,相信很多人在SpringBoot Mybatis怎么配置文件问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答...
    99+
    2023-07-05
  • SpringBoot中@ConfigurationProperties注解怎么实现配置绑定
    本篇内容介绍了“SpringBoot中@ConfigurationProperties注解怎么实现配置绑定”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能...
    99+
    2023-06-30
  • mybatis中注解与xml配置的对应关系和对比分析
    注解与xml配置的对应关系 mybatis中注解就是简单不需要写配置文件,适合简单的数据处理,理解起来比较容易,不动态生成SQL时候可以用用。 需要绑定,有些时候不如配置文件,配置文...
    99+
    2024-04-02
  • MyBatis @Param注解怎么实现
    本文小编为大家详细介绍“MyBatis @Param注解怎么实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“MyBatis @Param注解怎么实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知...
    99+
    2023-06-29
  • MyBatis @Select注解怎么使用
    这篇文章主要介绍“MyBatis @Select注解怎么使用”,在日常操作中,相信很多人在MyBatis @Select注解怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”...
    99+
    2023-07-02
  • 怎么配置MyBatis的数据源
    要配置MyBatis的数据源,首先需要在MyBatis的配置文件中指定数据源的信息。以下是一个示例配置文件: <xml ver...
    99+
    2024-03-07
    MyBatis
  • SpringBoot2底层注解@Configuration怎么配置类
    这篇文章主要讲解了“SpringBoot2底层注解@Configuration怎么配置类”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“SpringBoot2底层注解@Configuratio...
    99+
    2023-06-30
  • Mybatis配置之<environments>配置元素详解
    目录我们先来看一下配置还是从解析的入口开始看起进入方法内部isSpecifiedEnvironment方法如下所示这两种事务管理器的区别下面分别对这三种类型做一个简单的说明(1)UN...
    99+
    2024-04-02
  • MyBatis的核心配置出现问题怎么解决
    如果MyBatis的核心配置出现问题,可以尝试以下解决方法: 检查MyBatis配置文件(通常是mybatis-config.x...
    99+
    2024-03-01
    MyBatis
  • 怎么在struts2中利用注解对Action进行配置
    怎么在struts2中利用注解对Action进行配置?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。 使用注解来配置Action可以实现零配置,零配置将...
    99+
    2023-05-30
    struts2 action
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作