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接口:
映射文件:
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/141561.html