JPA多表查询

JPA多表查询

DTO

dto是做表示层的,不需要和数据库中的表的字段完全一样,不用加@Entity注解;entity是完全和数据库表的字段一一对应。

package com.zsj.dto;


/**
 * @author zsj55
 */

public class HomeworkIsSubmitDTO {
    private String userName;
    private String isSubmit;

    public String getUserName() {
        return userName;
    }

    public void setUserName(String userName) {
        this.userName = userName;
    }

    public String getIsSubmit() {
        return isSubmit;
    }

    public void setIsSubmit(String isSubmit) {
        this.isSubmit = isSubmit;
    }
}

Repository

package com.zsj.repository;

import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Repository;

import javax.annotation.Resource;
import java.sql.Types;
import java.util.List;
import java.util.Map;

/**
 * @author zsj55
 */
@Repository
public class DTODao {

    @Resource
    private JdbcTemplate jdbcTemplate;

    public List<Map<String, Object>> queryHomeworkDTOListMap(String homeworkId){
        String sql = "select u.name, uh.homeworkmaster_id from user u left join user_homework uh on (u.id = uh.user_id and uh.homeworkmaster_id=?);";
        /**
        *数组中存放传给uh.homeworkmaster_id=?的值,homeworkId
        */
        Object[] args = {homeworkId};
        int[] argsTypes = {Types.VARCHAR};
        return this.jdbcTemplate.queryForList(sql, args, argsTypes);
    }
}

Service

public List<HomeworkIsSubmitDTO> getHomeworkDetailByHid(String hid){
        List<HomeworkIsSubmitDTO> dtoList = new ArrayList<HomeworkIsSubmitDTO>();
        List<Map<String, Object>> mapList = dtoDao.queryHomeworkDTOListMap(hid);
        for(int i = 0; i < mapList.size(); i++){
            HomeworkIsSubmitDTO homeworkIsSubmitDTO = new HomeworkIsSubmitDTO();
            String name = (String) mapList.get(i).get("name");
            homeworkIsSubmitDTO.setUserName(name);
            String homeworkmasterId = (String) mapList.get(i).get("homeworkmaster_id");
            if(homeworkmasterId != null && !"".equals(homeworkmasterId)){
                homeworkIsSubmitDTO.setIsSubmit("已提交");
            }
            else{
                homeworkIsSubmitDTO.setIsSubmit("未提交");
            }
            dtoList.add(homeworkIsSubmitDTO);
        }

        return dtoList;
    }

Controller

/**
*submitdetail/{hid} 地址栏传值id
*/
@RequestMapping("submitdetail/{hid}")
    public List<HomeworkIsSubmitDTO> getHomeworkDetailByHid(@PathVariable("hid") String hid){
        return homeworkService.getHomeworkDetailByHid(hid);
    }

地址栏

[外链图片转存失败(img-echBujSE-1565570781020)(C:\Users\zsj55\AppData\Roaming\Typora\typora-user-images\1565570753556.png)]

结果

Service.getHomeworkDetailByHid(hid);
}




**地址栏**

[外链图片转存中...(img-echBujSE-1565570781020)]



**结果**

[外链图片转存失败(img-GVbRvHaD-1565570781036)(C:\Users\zsj55\AppData\Roaming\Typora\typora-user-images\1565570735317.png)]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值