MyBatis你需要知道的事
刚开始学习MyBatis会遇到一些问题,这写问题是比较简单的,在这里总结下。
{}和${} 的区别
- {}解析传递进来的参数数据
- ${}对传递进来的参数原样拼接在SQL中
{}是预编译处理,${}是字符串替换。
使用#{}可以有效的防止SQL注入,提高系统安全性
当实体类中的属性名和表中的字段名不一样 ,怎么办 ?
第1种: 通过在查询的sql语句中定义字段名的别名,让字段名的别名和实体类的属性名一致
如下我们将 order_id重命名为id 了,这样在返回的实体中就可以接收到这样的参数了。
第2种: 通过``标签来映射字段名和实体类属性名的一一对应的关系
我们建立的这种关系就可以使得完美对应上。
此外,如果不想用实体进行接收数据库返回的参数,那我们可以使得resultType为map类型接收(java.util.HashMap),具体使用哪种类型由自己业务决定,
写法看下面
如何获取自动生成的(主)键值?
参考:https://blog.91lucky.top/articles/113
需求:
user对象插入到数据库后,新记录的主键要通过user对象返回,通过user获取主键值。
解决思路:
通过LAST_INSERT_ID()获取刚插入记录的自增主键值,在insert语句执行后,执行select LAST_INSERT_ID()就可以获取自增主键。
mysql:
oracle:
实现思路:
先查询序列得到主键,将主键设置到user对象中,将user对象插入数据库。
在mapper中如何传递多个参数?
第一种:使用占位符的思想
在映射文件中使用#{0},#{1}代表传递进来的第几个参数
使用@param注解:来命名参数
{0},#{1}方式

@param注解方式
第二种:使用Map集合作为参数来装载

Mybatis动态sql是做什么的?都有哪些动态sql?动态sql的执行原理?
Mybatis动态sql可以让我们在Xml映射文件内,以标签的形式编写动态sql,完成逻辑判断和动态拼接sql的功能。
Mybatis提供了9种动态sql标签:trim|where|set|foreach|if|choose|when|otherwise|bind。
其执行原理为,使用OGNL从sql参数对象中计算表达式的值,根据表达式的值动态拼接sql,以此来完成动态sql的功能
下面是一些来自官网例子:
http://www.mybatis.org/mybatis-3/zh/dynamic-sql.html