mybatis 别名查询,map传参

本文介绍了一个基于MyBatis的统计查询实现方案,通过DAO层接口和XML映射文件结合,实现了根据不同时间粒度(日、月、年)进行访问量统计的功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

dao层interface

package com.bigdata.project.dao;

import java.util.List;
import java.util.Map;

import org.apache.ibatis.annotations.Param;
import com.bigdata.project.model.po.SearchResult;

public interface AiStatisticsMapper {
	
	List<SearchResult> countaAccessStatistis(@Param("statistics") Map<String, Object> map);
}

dao层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.bigdata.project.dao.AiStatisticsMapper" >
  <resultMap type="com.bigdata.project.model.po.SearchResult" id="searchResultMap">  
     <result column="dateFmt" jdbcType="TIMESTAMP" property="dateFmt" />
     <result column="countId" jdbcType="INTEGER" property="countId" />
  </resultMap>
  <!-- 日月年格式显示某时间段访问量统计 -->
  <select id="countaAccessStatistis" resultMap="searchResultMap" parameterType="java.util.Map" >
  		<if test="statistics.groupfmt!= null and statistics.groupfmt == 0">
  			SELECT DATE_FORMAT(add_time, '%Y%m%d' ) dateFmt , COUNT(id) countId FROM ai_kap_statistics_visitor WHERE  p_user_id = #{statistics.puserid} AND status = #{statistics.pstatus} AND add_time BETWEEN #{statistics.begindate} AND #{statistics.enddate} GROUP BY dateFmt
        </if>
        <if test="statistics.groupfmt!= null and statistics.groupfmt == 1">
  			SELECT DATE_FORMAT(add_time, '%Y%m' ) dateFmt , COUNT(id) countId FROM ai_kap_statistics_visitor WHERE  p_user_id = #{statistics.puserid}  AND status = #{statistics.pstatus} AND add_time BETWEEN #{statistics.begindate} AND #{statistics.enddate} GROUP BY dateFmt
        </if>
        <if test="statistics.groupfmt!= null and statistics.groupfmt == 2">
  			SELECT DATE_FORMAT(add_time, '%Y' ) dateFmt , COUNT(id) countId FROM ai_kap_statistics_visitor WHERE  p_user_id = #{statistics.puserid}  AND status = #{statistics.pstatus} AND add_time BETWEEN #{statistics.begindate} AND #{statistics.enddate} GROUP BY dateFmt
        </if>
  </select>
</mapper>

xml 映射返回别名实体类

/**
 *@description 统计查询返回封装类
 *@author DXH
 *@date 2018年7月20日16:46:47 
 */
public class SearchResult implements Serializable {
	/**
	 * 
	 */
	private static final long serialVersionUID = 1L;
	
	private String dateFmt;
	private String countId;
	
	public String getDateFmt() {
		return dateFmt;
	}
	public void setDateFmt(String dateFmt) {
		this.dateFmt = dateFmt;
	}
	public String getCountId() {
		return countId;
	}
	public void setCountId(String countId) {
		this.countId = countId;
	}
	
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值