(原文链接:http://www.studyshare.cn/blog/details/1178/1

一、开发中到底应该使用resultType还是resultMap?

强制使用resultMap,不要使用resultClass做返回参数,即便类的属性名称和数据库字段一一对应,也需要用resultMap进行定义,反之,每一个表也必然要有一个POJO类与之对应。

原因:

1、如果使用resultType,那么数据库的字段与POJO类字段必须一模一样(前提是不使用别名定义),这种情况下,如果一旦修改了数据库的表字段名称,则势必要修改对应的POJO类的属性名才能完全对应,否则会出错,然而一旦修改POJO的属性名称那业务代码用到该属性的所有地方也必须跟着修改,这就是一种强耦合。

2、数据库字段定义规则是字母+下划线(例:user_name),POJO类属性采用驼峰命名(例:userName)。使用resultType则势必会违反其中一种命名规则。

3、resultType降低了代码可维护性。如果使用resultMap只需要修改xml中字段映射配置,使数据库字段与DO类解耦,方便维护。

java开发工具下载地址及安装教程大全,点这里
更多深度技术文章,在这里

二、mybatis有哪几种方式传递入参?各有什么优缺点?

1、使用Map传参

Map<String, Object> params = new HashMap<String, Object>();

params.put("email", email);  
        params.put("sex", sex);
        List<User> getUserList(Map<String, Object> map):

缺点:这种传递参数方式可读性差,导致可维护和可扩展性差,杜绝使用。

2、使用注解传参

List<User> getUserList(@Param("name")String name, @Param("sex")Byte sex);

优点:直观明了,当参数较少一般小于5个的时候,建议使用。

3、使用JavaBean传参

User user = new User();
        user.setName(name);
        user.setSex(sex);
        List<User> getUserList(User user):

优点:代码可读性好,可维护性及扩展性佳,当参数大于5个的时候,建议使用。

三、#{}与${}使用有什么区别?

#{}:预编译,会给传入的值当成一个字符串,自动加上一个单引号,能很大程度防止sql注入。

${}:传值,传入的数据直接显示在sql中,无法防止sql注入。适用于动态报表生成,表名,选取的列是动态的,及order by和in操作。

sql注入举例:

1、xml文件编写一段sql如下:

2、传值代码:

最后执行的sql语句为:select id, userName, realName, sex, mobile, email, note from t_user where a.userName = 'xxx' or 1=1 order by sex,userName

红色部分是被注入的sql。

注意:sql.xml中建议使用#{},参数接收不要使用${},因为${}容易出现sql注入。

四、什么是N+1查询问题?如何解决?

查询方式分两种:嵌套结果与嵌套查询

1、嵌套结果:一个sql语句中将多个表关联一起查询出结果。

2、嵌套查询:用多个sql语句单独去查询每张表,主查询sql先将后续查询所需要的条件查询出来,然后去循环查询后续数据。

N+1查询问题是嵌套查询存在的问题,主查询查询一次表示1,后续查询会根据主查询查出来的结果作为参数条件去查询数据,可能是N次。

如何避免N+1问题?

使用按需加载,即:懒加载。开启懒加载配置:在<select>节点上配置“fetchType=lazy”

在MyBatis核心配置文件中加入如下配置:

<!-- 开启懒加载 ,当启用时,有延迟加载属性的对象在被调用时将会完全加载任意属性。否则,每种属性将会按需要加载。默认:true -->

<setting name="aggressiveLazyLoading" value="false" />

java开发工具下载地址及安装教程大全,点这里
更多深度技术文章,在这里

MyBatis基础之几道常见面试题详解的更多相关文章

  1. BTA 常问的 Java基础40道常见面试题及详细答案

    原文:http://www.ymq.io/2018/03/10/java/ 八种基本数据类型的大小,以及他们的封装类 引用数据类型 Switch能否用string做参数 equals与==的区别 自动 ...

  2. BTA 常问的 Java基础40道常见面试题及详细答案(山东数漫江湖))

    八种基本数据类型的大小,以及他们的封装类 引用数据类型 Switch能否用string做参数 equals与==的区别 自动装箱,常量池 Object有哪些公用方法 Java的四种引用,强弱软虚,用到 ...

  3. 《Java面试全解析》505道面试题详解

    <Java面试全解析>是我在 GitChat 发布的一门电子书,全书总共有 15 万字和 505 道 Java 面试题解析,目前来说应该是最实用和最全的 Java 面试题解析了. 我本人是 ...

  4. Mybatis常见面试题

    Mybatis常见面试题 #{}和${}的区别是什么? #{}和${}的区别是什么? 在Mybatis中,有两种占位符 #{}解析传递进来的参数数据 ${}对传递进来的参数原样拼接在SQL中 #{}是 ...

  5. Mybatis 的常见面试题

    背景:好久没用Mybatis了,有些面试题还是要好好准备的. Mybatis 的常见面试题

  6. 【搞定 Java 并发面试】面试最常问的 Java 并发基础常见面试题总结!

    本文为 SnailClimb 的原创,目前已经收录自我开源的 JavaGuide 中(61.5 k Star![Java学习+面试指南] 一份涵盖大部分Java程序员所需要掌握的核心知识.欢迎 Sta ...

  7. Java基础知识常见面试题汇总第一篇

    [Java面试题系列]:Java基础知识常见面试题汇总 第一篇 文中面试题从茫茫网海中精心筛选,如有错误,欢迎指正! 1.前言 ​ 参加过社招的同学都了解,进入一家公司面试开发岗位时,填写完个人信息后 ...

  8. Mybatis常见面试题汇总

    Mybatis常见面试题汇总 最近在复习整理Mybatis的相关知识,针对面试中的典型问题,结合相关书籍和网上相关帖子,做如下整理. ================================= ...

  9. MyBatis 常见面试题总结

    1.#{}和${}的区别是什么? 注:这道题是面试官面试我同事的. 答: ${}是 Properties 文件中的变量占位符,它可以用于标签属性值和 sql 内部,属于静态文本替换,比如${drive ...

随机推荐

  1. Spring系列(二):Spring IoC应用

    一.Spring IoC的核心概念 IoC(Inversion of Control  控制反转),详细的概念见Spring系列(一):Spring核心概念 二.Spring IoC的应用 1.定义B ...

  2. java并发编程(三)----线程的同步

    在现实开发中,我们或多或少的都经历过这样的情景:某一个变量被多个用户并发式的访问并修改,如何保证该变量在并发过程中对每一个用户的正确性呢?今天我们来聊聊线程同步的概念. 一般来说,程序并行化是为了获得 ...

  3. alluxio2.0特性-预览

    项目地址 https://github.com/Alluxio/alluxio/tree/branch-2.0-preview 2.0版本-构思和设计 支持超大规模数据工作负载 Alluxio作为计算 ...

  4. 微信小程序项目总结-记账小程序(包括后端)

    一.小程序部分 这是理财系统的前端,江苏海洋大学微信小程序比赛,最后获得了一等奖 GitHub:https://github.com/GeorgeLeoo/finance 1. 项目描述 (1). 此 ...

  5. .netcore consul实现服务注册与发现-集群部署

    一.Consul的集群介绍 Consul Agent有两种运行模式:Server和Client.这里的Server和Client只是Consul集群层面的区分,与搭建在Cluster之上的应用服务无关 ...

  6. input样式重置(outline:none)

    我们在写表单的时候,经常需要自定义表单的样式,当然input输入框也不例外,那么如何能写出好看一点的输入框呢? 例如简单的三个空按钮: <input type="button" ...

  7. 从一道没人能答对的面试题聊聊Java的值传递

    这是一道我们公司的面试题,从招第二个Java以来就一直存在了.但是面试了这么长的时间还没有一个人可以全部答对,让我们一度以为是这题出的不对.首先请看面试题. 以下运算的输出分别是多少: ```java ...

  8. Linux相关安装文档

    一.JDK环境安装 1.查看linux上是否存在已安装好的JDK (1)java -version openjdk version "1.8.0_181"OpenJDK Runti ...

  9. python 22 类与对象

    目录 1. 从空间角度研究类 1.1 添加对象的属性: 1.2 添加类的属性: 1.3 类与对象的关系: 2. 类与类直接的关系 2.1 类与类的关系: 2.2 依赖关系 -- 主从之分 2.3 组合 ...

  10. flutter无线调试与打包

    1.WIFI连接设备 设备打开开发者选项 -> 点击WIFI调试 ->  项目目录下输入终端命令: adb connect   设备ip地址:[端口号(一般是5555)] 2.apk打包 ...