码迷,mamicode.com
首页 > 数据库 > 详细

Mybatis中如何将POJO作为参数传入sql

时间:2017-07-03 21:07:40      阅读:254      评论:0      收藏:0      [点我收藏+]

标签:ack   pojo   tom   utf-8   pos   ddp   param   model   找不到   

    今天在工作时,需要将获取的用户的注册信息插入数据库,开始的做法是将所有的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

标签:ack   pojo   tom   utf-8   pos   ddp   param   model   找不到   

原文地址:http://www.cnblogs.com/jy107600/p/7112748.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!