关于Mybatis中Mapper是使用XML还是注解的一些思考

XML 据说可以灵活的进行注解,但是修改以后还是要重新发布程序。当然,你可以说,在Tomcat中改了,然后热加载了,不就可以了。可是一般情况下都是几台,十几台服务器。都是用发布系统,持续集成的方式部署。这点灵活性也就没什么意义了。当然,一定要说XML支持好,这点我不否认。然而在注解中支持了大部分功能,如果实在复杂一点的SQL可以使用<script>方式或者使用Provider也行。

那再说,ResultMap支持的不好,但从3.某个版本,支持使用id,这样也可以在一定程度上进行复用了。

如果再说,Result 不支持继承,这。。,我暂时没有从注解中找相应的解决方案。

在XML中最不爽的一点,就是一个接口定义好了,如果要查SQL还要去另一个文件中查找。来回切换,比较消耗精力,特别是在查找问题的时候。

如果要说我把SQL跟代码混在一起了,的确是这样。

注解除了XML认为的灵活外,但它可以自定义一些注解 https://www.jianshu.com/p/03642b807688 (自定义 in , update 注解)

另外,今天花了几个小时的时间做了一个把XML转为注解代码小工具,没什么技术含量,

对于些复杂的转换还是不太成功,至少可以减少手工时间,把这点时间用来喝一杯也好。

mybatis xml mapper to  annotation

代码地址: https://github.com/zbw911/mybitis-xmlmapper2annotation

原文地址:https://www.cnblogs.com/zbw911/p/10158765.html

时间: 2024-07-29 10:37:20

关于Mybatis中Mapper是使用XML还是注解的一些思考的相关文章

Mybatis中mapper.xml中的模糊查询

Mybatis中mapper.xml中的模糊查询 <!-- 方法一: 直接使用 % 拼接字符串 注意:此处不能写成 "%#{name}%" ,#{name}就成了字符串的一部分, 会发生这样一个异常: The error occurred while setting parameters, 应该写成: "%"#{name}"%",即#{name}是一个整体,前后加上% --> <if test="name != nul

MyBatis 中 Mapper 接口的使用原理

MyBatis 中 Mapper 接口的使用原理 MyBatis 3 推荐使用 Mapper 接口的方式来执行 xml 配置中的 SQL,用起来很方便,也很灵活.在方便之余,想了解一下这是如何实现的,之前也大致知道是通过 JDK 的动态代理做到的,但这次想知道细节. 东西越多就越复杂,所以就以一个简单的仅依赖 MyBatis 3.4.0 的 CRUD 来逐步了解 Mapper 接口的调用. 通常是通过 xml 配置文件来创建SqlSessionFactory对象,然后再获取SqlSession对

mybatis 中mapper 的namespace有什么用

原文:http://zhidao.baidu.com/link?url=ovFuTn7-02s7Qd40BOnwHImuPxNg8tXJF3nrx1SSngNY5e0CaSP1E4C9E5J6Xv5fI9P_dTMqHeBRGOID9bk9IcY1o9h6O21l6rHRAwj_Km3 ----------------------------------------------------------------------------------------------------------

关于使用mybatis中mapper instrances,通过session另一种操作方式

1 String resource = "mybatis-config.xml"; 2 InputStream inputStream = null; 3 try { 4 // 获取SqlSessionFactory 5 inputStream = Resources.getResourceAsStream(resource); 6 SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(inputStream)

SSM框架中mapper和mapping.xml文件在同一个包下需要的配置

前言 当我们在开发过程中,由于maven项目本身的限制,我们不能直接把我们的mapper.xml文件和对应mapper.java接口文件放到一起,也就是不能直接放在java包中,如图:  因为maven项目在构建打包时,会从src/main/java中获取所有的java文件然后编译,会从src/main/resources中获取配置文件等其它文件,然后打包, 所以尽管你在Spring整合Mybatis时配置也好,在Mybatis单独的配置文件中配置也好,都是会出错的: <!--配置SqlSess

关于mybatis中mapper文件resultMap中collection的使用

collection的使用有两种resultMap和select,必须手动指定一种 1. 实体类: 1 package com.mrlu.mybatis.domain; 2 3 import java.util.List; 4 5 /** 6 * Created by stefan on 15-12-31. 7 */ 8 public class User { 9 private Integer id; 10 private String name; 11 private List<Accoun

Mybatis中Mapper代理形式开发与spring整合

1.导入jar包 2.分包 cogfig:存放配置文件 mapper:存放映射与接口 pojo:存放实体类 test:测试代码 3.编写配置文件 SqlMapConfig.xml <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybat

Mybatis中Mapper.xml文件sql中动态获取----&gt;#{}和${}区别

1. #{} 获取参数的内容,支持索引获取,param1获取指定位置参数,并且sql使用?占位符 2. ${} 纯字符串拼接,不使用?,默认找${内容}内容的get/set方法,如果写数字,就是一个数字 原文地址:https://www.cnblogs.com/yikuan-919/p/9691702.html

mybatis中mapper的扩展

用mbgenerator自动生成mybatis的实体和mapper(xml和接口)文件后,如果想在mapper中添加新的操作,就不方便在自动生成的文件上去改,解决办法是定义一个新的接口和新的mapper xml文件. BlogExtMapper.java public interface BlogExtMapper extends BlogMapper {     List<Blog> selectAll();     List<Blog> selectRecent();