在dao层给map赋值

纠正一下应该把dd作为传入而不是sbiId;

sqlMap中的parameterType="java.util.Map", 就 OK

package com.ldrc.srm.jczx.web.results.module.screen;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map; import org.springframework.beans.factory.annotation.Autowired; import com.alibaba.citrus.service.requestcontext.parser.ParserRequestContext;
import com.alibaba.citrus.turbine.Context;
import com.ldrc.srm.common.web.OuUser;
import com.ldrc.srm.jczx.biz.common.DateUtil;
import com.ldrc.srm.jczx.biz.construction.technology.IndexPlanManager;
import com.ldrc.srm.jczx.dal.dataobject.construction.projectinfo.Assessment;
import com.ldrc.srm.jczx.dal.dataobject.construction.technology.PatentExecute;
import com.ldrc.srm.jczx.dal.dataobject.construction.technology.SmAssessmentPlan; public class Kaimpatent {
@Autowired
private IndexPlanManager ipm;
@Autowired
ParserRequestContext parser;
public void execute(Context context){
OuUser ou = OuUser.getCurrentUser();
Integer sbiId = ou.getSubjectBaseId();
List<PatentExecute> pes = ipm.selectAllAimpatent();
List<PatentExecute> pesList = new ArrayList<PatentExecute>();
List<Assessment> ass = ipm.getAssessmentBySbiId(sbiId);
List<SmAssessmentPlan> assessmentPlanList = new ArrayList<SmAssessmentPlan>();
if (!ass.isEmpty()) {
for (Assessment assessment : ass) {
List<SmAssessmentPlan> assessmentPlan = assessment.getAssessmentPlan();
if (!assessmentPlan.isEmpty()) {
assessmentPlanList.addAll(assessmentPlan);
}
} if (!assessmentPlanList.isEmpty()) {
for (SmAssessmentPlan smAssessmentPlan : assessmentPlanList) {
Integer sadId = smAssessmentPlan.getSadId();
if (!pes.isEmpty()) {
for (PatentExecute patentExecute : pes) {
if (patentExecute.getSadId() != null && patentExecute.getSadId().equals(sadId)) {//使用程序代替sql相当于关联查询
pesList.add(patentExecute);
}
}
}
}
}
}
context.put("rUrl", parser.getRequest().getHeader("Referer"));
context.put("pes", pesList);
context.put("DateUtil", new DateUtil()); /**
* 上面的方法写了这么多其实不必
* 一条sql就搞定
* <select id="r" resultMap="BaseResultMap" parameterType="java.util.Map">
select t3.* from sm_s_assessment t1
left join SM_S_ASSESSMENT_PLAN t2
on t1.SASS_ID = t2.SASS_ID
left join SM_PATENT_EXECUTE t3
on t2.SAD_ID = t3.SAD_ID
where t1.SBI_ID = #{sbiId, jdbcType=INTEGER}
</select>
问题是我的resultMap中没有SBI_ID这个列,怎么办
有办法, 注意到parameterType有没有比平时不一样没<select id="r" resultMap="BaseResultMap" parameterType="java.util.Map">
呵呵, 就是parameterType="java.util.Map" ; 有了这个你可以在dao随意传递多少个参数, 不管下面的resultMap中有没有对应的列或属性
注意的是dao里传参,
Integer sbiId = 21;
Map<String, Object> m = new HashMap<String, Object>();
m.put("sbiId", sbiId);
List<PatentExecute> selectList = sqlSession.selectList("PatentExecuteMapper.r", m);
总结: 其实就是把parameterType平时使用的javaBean或四类八种换了 map, 原理是一样的
*/
其实还可以把上面的sql写到 指标 的sqlmap 中resultMap返回PatentExecuteMapper.BaseResultMap即可那么parameterType也不必须使用map类型了

如:<select id="r" resultMap="PatentExecuteMapper.BaseResultMap" parameterType="java.util.Map">
              select t3.* from sm_s_assessment t1
                left join SM_S_ASSESSMENT_PLAN t2
                    on t1.SASS_ID = t2.SASS_ID
                left join SM_PATENT_EXECUTE t3
                    on t2.SAD_ID = t3.SAD_ID
                where t1.SBI_ID = #{sbiId, jdbcType=INTEGER}
   </select>

mybatis是不是特别灵活啊!

    }
}

sqlMap文件

<?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="PatentExecuteMapper" >
<resultMap id="BaseResultMap" type="com.ldrc.srm.jczx.dal.dataobject.construction.technology.PatentExecute" >
<id column="SPE_ID" property="speId" jdbcType="INTEGER" />
<result column="SAD_ID" property="sadId" jdbcType="INTEGER" />
<result column="SPE_NUM" property="speNum" jdbcType="VARCHAR" />
<result column="SPE_APPLY_DATE" property="speApplyDate" jdbcType="DATE" />
<result column="SPE_APPLY_REMARK" property="speApplyRemark" jdbcType="VARCHAR" />
<result column="SPE_PEOPLE_NAME" property="spePeopleName" jdbcType="VARCHAR" />
<result column="SPE_INVENT_NAME" property="speInventName" jdbcType="VARCHAR" />
<result column="SPE_STUTAS" property="speStutas" jdbcType="VARCHAR" />
<result column="SPE_PRIORITY" property="spePriority" jdbcType="VARCHAR" />
<result column="SPE_PUBLISH_NUM" property="spePublishNum" jdbcType="VARCHAR" />
<result column="SPE_ISSUE_NUM" property="speIssueNum" jdbcType="VARCHAR" />
<result column="SPE_DIGEST" property="speDigest" jdbcType="VARCHAR" />
<result column="SPE_MAIN_NUM" property="speMainNum" jdbcType="VARCHAR" />
<result column="SPE_AGENT" property="speAgent" jdbcType="VARCHAR" />
<result column="SPE_FILE" property="speFile" jdbcType="VARCHAR" />
<collection property="files" column="SPE_FILE"
ofType="com.ldrc.srm.jczx.dal.dataobject.file.SrmFile" select="SrmFileMapper.selectByEgCode"
resultMap="SrmFileMapper.BaseResultMap">
</collection>
</resultMap> <sql id="Base_Column_List" >
SPE_ID, SAD_ID, SPE_NUM, SPE_APPLY_DATE, SPE_APPLY_REMARK, SPE_PEOPLE_NAME, SPE_INVENT_NAME,
SPE_STUTAS, SPE_PRIORITY, SPE_PUBLISH_NUM, SPE_ISSUE_NUM, SPE_DIGEST, SPE_MAIN_NUM,
SPE_AGENT, SPE_FILE
</sql>
<select id="r" resultMap="BaseResultMap" parameterType="java.util.Map">
select t3.* from sm_s_assessment t1
left join SM_S_ASSESSMENT_PLAN t2
on t1.SASS_ID = t2.SASS_ID
left join SM_PATENT_EXECUTE t3
on t2.SAD_ID = t3.SAD_ID
where t1.SBI_ID = #{sbiId, jdbcType=INTEGER}
</select>
<select id="selectAllAimpatent" resultMap="BaseResultMap" parameterType="java.lang.Integer" >
select *
from SM_PATENT_EXECUTE
</select>
<select id="selectByPrimaryKey" resultMap="BaseResultMap" parameterType="java.lang.Integer" >
select
<include refid="Base_Column_List" />
from SM_PATENT_EXECUTE
where SPE_ID = #{speId,jdbcType=INTEGER}
</select>
</mapper>

mybatis的parameterType使用map实现真正的sql随意写的更多相关文章

  1. mybatis的parameterType为map,map里带有多个list

    我写这个主要是为了解决sql注入 原sql有sql注入, 结果:select req_msg_id from account_message_info where req_msg_id in ('12 ...

  2. mybatis中parameterType可以写的别名

    mybatis中parameterType可以写的别名 https://blog.csdn.net/sdzhangshulong/article/details/51749807 _byte byte ...

  3. 解决:oracle+myBatis ResultMap 类型为 map 时返回结果中存在 timestamp 时使用 jackson 转 json 报错

    前言:最近在做一个通用查询单表的组件,所以 sql 的写法就是 select *,然后 resultType="map" ,然后使用 jackson @ResponseBody 返 ...

  4. mybatis中的map.xml文件中sql语句需要分号吗?

    mybatis中的map.xml文件中sql语句需要分号吗? :你是说sql介绍的分号吗?不需要的

  5. 【mybatis】mybatis查询 结果 用map接收,无实体接收 + 关联子表 一并返回主子表的结果

    如果后台程序没有实体对应mysql的数据表. 而mybatis想要查询mysql这个数据表的数据,返回给应用程序. 应用程序该如何接收? =============================== ...

  6. IntelliJ IDEA中,mybatis的配置文件(map.xml)无法编译到class文件夹下

    编译工具:IntelliJ IDEA 项目结构:maven 项目框架:SSM 问题:java目录下,mybatis的配置文件(map.xml)无法编译到class文件夹下 问题原因:在idea中,直接 ...

  7. mybatis中#{}与${}的差别(如何防止sql注入)

    默认情况下,使用#{}语法,MyBatis会产生PreparedStatement语句中,并且安全的设置PreparedStatement参数,这个过程中MyBatis会进行必要的安全检查和转义. # ...

  8. MyBatis基础入门《二十》动态SQL(foreach)

    MyBatis基础入门<二十>动态SQL(foreach) 1. 迭代一个集合,通常用于in条件 2. 属性 > item > index > collection : ...

  9. MyBatis基础入门《十九》动态SQL(set,trim)

    MyBatis基础入门<十九>动态SQL(set,trim) 描述: 1. 问题 : 更新用户表数据时,若某个参数为null时,会导致更新错误 2. 分析: 正确结果: 若某个参数为nul ...

随机推荐

  1. ORA-01790 错误处理

    今天在练手的时候出现了一个ORA-01790 的错误,决定把他写下来保留起来. 先来创建两张测试用的简单的表. SQL> create table test01 (id number(3),na ...

  2. 关于Could not parse configuration: /hibernate.cfg.xml的问题

    第一次在eclipse上配置hibernate,问题百出啊,比如下面的org.hibernate.HibernateException: Could not parse configuration: ...

  3. CSS3 box-flex属性和box-orient属性

    比较有意思的是虽然目前没有浏览器支持box-flex,box-orient属性,但CSS3问世以来,这两个属性却一直很火.2014年阿里校招第5题要求使用CSS3中的功能实现三个矩形的布局,总的宽度为 ...

  4. Java之日期和时间的计算

    学习是一个循序渐进的过程,不知道你们有没有这样的感受:有很多学习过的知识在很久没有温习之后就不知不觉地还给老师了.所以最近总结,把那些还给老师的再找回来. 运行图: 时间戳: 运行效果图: 时间日期的 ...

  5. SQL中PERSISTED关键字

    PERSISTED 指定 SQL Server 数据库引擎将在表中物理存储计算值,而且,当计算列依赖的任何其他列发生更新时对这些计算值进行更新.将计算列标记为 PERSISTED,可允许您对具有确定性 ...

  6. 剑指offer_面试题11 数值的整数次方_考察代码的完整性

    测试通过代码: package t0825; public class Power { public static void main(String[] args){ System.out.print ...

  7. Block深入浅出

    研究工具 clang 为了研究编译器的实现原理,我们需要使用 clang 命令.clang 命令可以将 Objetive-C 的源码改写成 C / C++ 语言的,借此可以研究 block 中各个特性 ...

  8. Bresenham算法画填充圆及SDL代码实现

    画圆是计算机图形操作中一个非常重要的需求.普通的画圆算法需要大量的浮点数参与运算,而众所周知,浮点数的运算速度远低于整形数.而最终屏幕上影射的像素的坐标均为整形,不可能是连续的线,所以浮点数运算其实纯 ...

  9. Spring boot 1.3.5 RELEASE 官方文档中文翻译--Part2:新手入门

    Part II. 新手入门 如果你刚刚开始学习Spring boot或"普通"的Spring,这部分非常适合你!在这里,我们回答了最基础的"什么是?".&quo ...

  10. Shared library can't open object

    将cpp的源文件和.so (shared object)链接成可执行程序之后,无法运行,提示如标题,实际就是找不到共享库. 最终找到了解决办法是: export LD_LIBRARY=./:$LD_L ...