0、Maven的作用(好处)
1)统一项目结构
2)可以做项目构建(编译 compile、测试test、打包package)
3)依赖管理
1、Maven常见命令
clean:清除编译后的文件就是删除target文件夹
compile:编译项目
test: 执行junit测试代码
package:把项目打成jar包
install:把打好的包放到本地仓库
deploy:把打好的包放到私服上
2、说下Maven生命周期
Maven的命令是有先后顺序的,执行后面的命令会自动执行前面的命令
举例: 我执行了package命令就自动会执行 compile test
3、jar包冲突怎么办?(等讲到Maven高级再说)
版本锁定
4、Mybatis中#{}和${}的区别
${}表示的是字符串拼接,#{}是预编译处理,是占位符。
${}存在SQL注入问题,#{}可以有效的防止SQL注入。
4、${}有SQL注入问题是不是就不会用到了
当然这也不是说${}就没有使用场景
比如:如果sql中需要动态传递表名或者字段名,那就只能使用${}了,这种情况的值是程序员自己传过去的,不是页面直接传的
5、当实体类中的属性名和表中的字段名不一样 ,怎么办
1、开启驼峰映射:这种方式可以处理掉字段和属性满足驼峰转换规则的那部分
2、字段起别名:可以在查询的SQL语句中定义字段名的别名,让字段名的别名和实体类的属性名一致
3、手动映射:mybatis提供了@Results注解 和在xml中提供了resultMap标签,它可以通过来自定义映射关系来保证字段和属性的映射
6、MyBatis动态SQL了解吗
动态SQL是为了解决SQL语句灵活性不足的问题而提出的一种技术,它可以根据条件拼接SQL语句以不同的查询需求
MyBatis常用的动态SQL标签有:
<if> 用来判断 符合条件的会拼接到sql中
<where> 如果没有条件时可以去除where关键字 还可以去除第一个And或or关键字
<set> 去除最后一个逗号
<foreach > 用来批量处理的 比如批量删除拼接 in后面的值
<sql> 定义一个sql片段 就是提取公共的sql <include> 引入sql片段
7、Mybatis的一级缓存和二级缓存?
一级缓存是sqlSession级别的,在同一个sqlSession中执行同样的sql语句时如果有缓存直接读取缓存中的数据
二级缓存是namespace(Mapper)级别的
一级缓存是默认开启的 二级缓存需要手动开启,一般二级缓存不用