登录
首页 >  数据库 >  MySQL

MyBatis基础之几道常见面试题详解

来源:SegmentFault

时间:2023-02-24 19:14:08 144浏览 收藏

积累知识,胜过积蓄金银!毕竟在##column_title##开发的过程中,会遇到各种各样的问题,往往都是一些细节知识点还没有掌握好而导致的,因此基础知识点的积累是很重要的。下面本文《MyBatis基础之几道常见面试题详解》,就带大家讲解一下MySQL、Redis、Java、Linux知识点,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~

原文链接http://www.studyshare.cn/blog...

一、开发中到底应该使用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 params = new HashMap();  

params.put("email", email);

params.put("sex", sex);

List getUserList(Map map):

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

2、使用注解传参

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

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

3、使用JavaBean传参

User user = new User();

user.setName(name);

user.setSex(sex);

List getUserList(User user):

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

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

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

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

sql注入举例:

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

clipboard.png

2、传值代码:

clipboard.png

最后执行的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问题?

使用按需加载,即:懒加载。开启懒加载配置:在

持续更新,阅读请点击这里

java开发工具下载地址及安装教程大全,点这里

更多深度技术文章,在这里

到这里,我们也就讲完了《MyBatis基础之几道常见面试题详解》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于mysql的知识点!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>