MyBatis动态设置表名 获取添加功能自增的主键 自定义映射
动态设置表名
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接口:
映射文件: