今天在工作时,需要将获取的用户的注册信息插入数据库,开始的做法是将所有的model的属性作为DAO接口的参数,后来想想不对劲,要是有100个属性,那我这个接口岂不是要有100个参数传进来?

于是我就考虑将整个Model或者DTO作为DAO接口的参数,向SQL传参,具体的实现如下:

(1)定义DAO接口:

 @Repository
public interface ProjectDtoMapper { void addProject(@Param("projectDto")ProjectDto projectDto); //这里一定要加这个注解,不然在配置文件中会找不到这个DTO对象 }

(2)定义service:

 @Service
public class ProjectService {
@Resource
private ProjectDtoMapper projectDtoMapper; public void addProject(ProjectDto projectDto) {
projectDtoMapper.addProject(projectDto);
} }

(3)Mapper.xml配置(重要):

 <?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.kingnetdc.kingnetio.innerapi.service.db.dao.ProjectDtoMapper"> <insert id="addProject" parameterType="com.kingnetdc.kingnetio.innerapi.service.db.dto.background.ProjectDto">
INSERT INTO dana.auth_projects(project_id,project_name,sort,last_edit_date) VALUES
(#{projectDto.project_id},#{projectDto.project_name},#{projectDto.sort},#{projectDto.last_edit_date})
</insert> </mapper>

注意:这里的namespace必须是DAO接口的路径名+类名,parameterType就是对应的DTO的路径名+类名,#{}中的参数写法就是上面接口中加的注解中的别名.属性的名字。

最新文章

  1. Android中的ANR
  2. asp.net 重定向的三种方法
  3. Rectangle Area
  4. [BS-29] 给UIView添加背景图片
  5. input框限制只能输入正整数,逻辑与和或运算
  6. python 中 input 和 raw_input 的区别
  7. 转: 学习开源项目的若干建议(infoq)
  8. linux面试题1
  9. DialogFragment
  10. poj 2993 Emag eht htiw Em Pleh(模拟)
  11. TCP/IP源码(59)——TCP中的三个接收队列
  12. Apache Spark2.0正式发布
  13. 使用diff和patch指令生成文件差异和还原文件
  14. (10.11)Java第一小步
  15. set类型
  16. Hexo的更新 主题的更换
  17. java中编写增删改查
  18. Codeforces 1090M - The Pleasant Walk - [签到水题][2018-2019 Russia Open High School Programming Contest Problem M]
  19. [kubernetes]helm安装
  20. 使用STM32CubeMX生成USB_HOST_HID工程[添加对CAPS_LOCK指示灯的控制][SetReport]

热门文章

  1. 史上最全的IntelliJIdea快捷键
  2. map的常用方法
  3. C#中??和?分别是什么意思?
  4. flex词法解析
  5. mybatis逆向工程使用步骤详解
  6. CKEdit( htm编辑器)
  7. NuGet的使用、部署、搭建私有服务
  8. laravel查看执行sql的
  9. memcached复制-repcached
  10. 数字三角形-poj