MyBatis动态设置表名 获取添加功能自增的主键 自定义映射
- 动态设置表名
- 获取添加功能自增的主键
- 自定义映射
- 解决字段名和属性名不一致的情况
- 为字段起别名,保持和属性名的一致
- 设置全局配置,保持和属性名的一致
- 通过resultMap设置自定义的映射关系
动态设置表名
mapper接口:
映射文件:
<!--List<TUser> getUserByTableName(@Param("tableName") String tableName);-->
<select id="getUserByTableName" resultType="com.yc.mybatis.pojo.TUser">
select * from ${tableName}
</select>
注意点:
这里只能使用${}来接收参数因为sql语句的查询中,表名是不需要单引号的,如果用#{}来接收参数,他会给表名默认带上了单引号,从而使sql语句发生错误,与此不同${}的单引号是要手动添加的,我们在传输表名的时候,只需不给它添加单引号即可
获取添加功能自增的主键
设想假如我们在做一个学生管理系统,在添加老师信息的同时,也要给他分配相应的学生,那是不是我们此时就要把老师自增的id获取出来,存到学生表中,但我们 都清楚,添加语句只能要么不返回数据,要么返回自己影响的行数
mapper接口:
映射文件:
<!--void insertUser(TUser user);-->
<insert id="insertUser" useGeneratedKeys="true" keyProperty="id">
insert into t_user values (null,#{username},#{password},#{age},#{sex},#{email})
</insert>
useGeneratedKeys:设置当前标签中的sql使用了自增的主键
keyProperty:将自增的主键的值赋值给传输到映射文件中参数的某个属性
测试代码:
运行结果:
自定义映射
为什么要自定义映射呢?
1.实体类与数据库字段名有各自的特点,不能一一对应
2.一对多
3.多对一
那要怎么解决呢?
解决字段名和属性名不一致的情况
试想一下
实体类是这样:
数据库确实这样:
要怎么将数据映射到对应的实体类上面呢?
为字段起别名,保持和属性名的一致
mapper接口:
映射文件:
<select id="getAllEmp" resultType="emp">
select eid,emp_name empName,age,sex,email, from t_emp
</select>
设置全局配置,保持和属性名的一致
在配置文件中的setting标签中,可以将字段名中的下滑线自动映射成驼峰
<!--设置MyBatis的全局配置
mapUnderscoreToCamelCase:将字段名中的下滑线自动映射成驼峰-->
<settings>
<setting name="mapUnderscoreToCamelCase" value="true"/>
</settings>
mapper接口:
映射文件:
<select id="getAllEmp" resultType="emp">
select * from t_emp
</select>
通过resultMap设置自定义的映射关系
mapper接口:
映射文件: