首页 > 代码库 > Mybatis中如何将POJO作为参数传入sql
Mybatis中如何将POJO作为参数传入sql
今天在工作时,需要将获取的用户的注册信息插入数据库,开始的做法是将所有的model的属性作为DAO接口的参数,后来想想不对劲,要是有100个属性,那我这个接口岂不是要有100个参数传进来?
于是我就考虑将整个Model或者DTO作为DAO接口的参数,向SQL传参,具体的实现如下:
(1)定义DAO接口:
1 @Repository 2 public interface ProjectDtoMapper { 3 4 void addProject(@Param("projectDto")ProjectDto projectDto); //这里一定要加这个注解,不然在配置文件中会找不到这个DTO对象 5 6 }
(2)定义service:
1 @Service 2 public class ProjectService { 3 @Resource 4 private ProjectDtoMapper projectDtoMapper; 5 6 public void addProject(ProjectDto projectDto) { 7 projectDtoMapper.addProject(projectDto); 8 } 9 10 }
(3)Mapper.xml配置(重要):
1 <?xml version="1.0" encoding="UTF-8"?> 2 <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> 3 <mapper namespace="com.kingnetdc.kingnetio.innerapi.service.db.dao.ProjectDtoMapper"> 4 5 <insert id="addProject" parameterType="com.kingnetdc.kingnetio.innerapi.service.db.dto.background.ProjectDto"> 6 INSERT INTO dana.auth_projects(project_id,project_name,sort,last_edit_date) VALUES 7 (#{projectDto.project_id},#{projectDto.project_name},#{projectDto.sort},#{projectDto.last_edit_date}) 8 </insert> 9 10 </mapper>
注意:这里的namespace必须是DAO接口的路径名+类名,parameterType就是对应的DTO的路径名+类名,#{}中的参数写法就是上面接口中加的注解中的别名.属性的名字。
Mybatis中如何将POJO作为参数传入sql
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。