zoukankan      html  css  js  c++  java
  • 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的路径名+类名,#{}中的参数写法就是上面接口中加的注解中的别名.属性的名字。

    原文地址:https://www.cnblogs.com/jy107600/p/7112748.html?utm_source=itdadao&utm_medium=referral

  • 相关阅读:
    构造器
    方法
    Arrays常用的类
    栈内存和堆内存
    方法的重载
    数组遍历
    Scanner类
    连接符和三元运算符
    逻辑运算和位运算
    CSAPP笔记(第二章 信息的表示和处理)-02
  • 原文地址:https://www.cnblogs.com/it-deepinmind/p/11779285.html
Copyright © 2011-2022 走看看