mybatis 之 parameterType="List" 2
<select id="queryGoodsByGoodsNoPcweb" parameterType="List" resultMap="simpleProductExtLucene">
select g.goods_no,
wp.PRODUCT_ID, p.product_name, p.drug_treatment, p.drug_prescription_type,
p.product_least_order || '' as "product_least_order", p.order_limit_amount || '' as "order_limit_amount",
wg.goods_id, g.goods_name,
g.market_price || '' as "market_price",
g.sale_amount, g.click_amount, nvl(g.available_stock,) || '' as "available_stock",
pc.pro_catalog_id || '' as "pro_catalog_id", pi.pro_image_url, tag.tag_id || '' as "tag_id",
tag.tag_icon_url,
<![CDATA[
(case when exists (
select 1
from ec_promote_rule_goods_new npg
right join ec_promote_rule_new np on npg.promote_rule_id = np.promote_rule_id
where npg.goods_id = wg.goods_id
and np.promote_client = 'wap'
and np.is_enable = 'Y'
and to_char(sysdate, 'yyyy-mm-dd hh24:mi:dd') between np.begin_time and np.end_time
)
then 'Y' else 'N' end) as MOBILE_SPECIAL,
]]>
pc.full_index,
to_number(case
when wg.discount_state = 'enable'
<!-- and wg.member_ranks = '0' -->
and to_char(sysdate, 'yyyy-mm-dd hh24:mi:dd') between wg.begin_time and wg.end_time
and wg.discount_price is not null
then
wg.discount_price
when g.discount_state = 'enable'
<!-- and g.member_ranks = '0' -->
and to_char(sysdate, 'yyyy-mm-dd hh24:mi:dd') between g.begin_time and g.end_time
and g.discount_price is not null
then
g.discount_price
else
g.ec_price
end) || ' ' as ec_price,
(case
when wg.discount_state = 'enable'
and to_char(sysdate, 'yyyy-mm-dd hh24:mi:dd') between wg.begin_time
and wg.end_time
then
wg.promote_phrase
when g.discount_state = 'enable'
and to_char(sysdate, 'yyyy-mm-dd hh24:mi:dd') between g.begin_time
and g.end_time
then
g.promote_phrase
else
''
end) as promote_phrase, pc.pro_catalog_name, wp.product_keyword, wp.PRODUCT_CHN_NO,
pb.product_brand_name, nvl(wp.product_order,) product_order
from product wp
left join product p on p.product_id = wp.product_id and p.is_delete = 'N'
left join goods wg on wp.product_id = wg.product_id and wg.is_delete = 'N' and wg.is_default = 'Y'
left join goods g on g.goods_id = wg.goods_id and g.is_delete = 'N' and g.is_default = 'Y'
left join product_catalog pc on pc.pro_catalog_id = wp.pro_catalog_id and pc.is_delete = 'N'
left join product_brand pb on pb.product_brand_id = wp.product_brand_id and pb.is_delete = 'N'
left join (
select min(pt.tag_id) as tag_id,
min(ptd.goods_id) as goods_id,
min(pt.tag_icon_url) as tag_icon_url
from product_tag_def ptd, product_tag pt
where ptd.tag_id = pt.tag_id
and pt.is_delete = 'N'
and pt.tag_type = 'icon'
group by ptd.goods_id
) tag on tag.goods_id = wg.goods_id
left join (
select pig.product_id as product_id,
min(pig.image_order),
min(pig.pro_image_url) as
pro_image_url
from wap_product_img pig
where pig.image_type = 'small'
group by pig.product_id) pi on wp.product_id = pi.product_id
where wp.is_delete = 'N'
and p.is_onsale = 'Y'
and wg.is_delete = 'N'
and wg.is_default = 'Y'
and wp.pro_catalog_id is not null
and wp.product_code NOT like 'AJ%'
and g.goods_no in
<foreach collection="list" item="listItem" index="index"
open="(" separator="," close=")" >
#{listItem,jdbcType=VARCHAR}
</foreach>
</select>
<select id="queryGoodsByGoodsNoMobile" parameterType="List" resultMap="simpleProductExtLucene">
select g.goods_no,
wp.PRODUCT_ID, p.product_name, p.drug_treatment, p.drug_prescription_type,
p.product_least_order || '' as "product_least_order", p.order_limit_amount || '' as "order_limit_amount",
wg.goods_id, g.goods_name,
g.market_price || '' as "market_price",
g.sale_amount, g.click_amount, nvl(g.available_stock,) || '' as "available_stock",
pc.pro_catalog_id || '' as "pro_catalog_id", pi.pro_image_url, tag.tag_id || '' as "tag_id",
tag.tag_icon_url,
<![CDATA[
(case when exists (
select 1
from ec_promote_rule_goods_new npg
right join ec_promote_rule_new np on npg.promote_rule_id = np.promote_rule_id
where npg.goods_id = wg.goods_id
and np.promote_client = 'wap'
and np.is_enable = 'Y'
and to_char(sysdate, 'yyyy-mm-dd hh24:mi:dd') between np.begin_time and np.end_time
)
then 'Y' else 'N' end) as MOBILE_SPECIAL,
]]>
pc.full_index,
to_number(case
when wg.discount_state = 'enable'
<!-- and wg.member_ranks = '0' -->
and to_char(sysdate, 'yyyy-mm-dd hh24:mi:dd') between wg.begin_time and wg.end_time
and wg.discount_price is not null
then
wg.discount_price
when g.discount_state = 'enable'
<!-- and g.member_ranks = '0' -->
and to_char(sysdate, 'yyyy-mm-dd hh24:mi:dd') between g.begin_time and g.end_time
and g.discount_price is not null
then
g.discount_price
else
g.ec_price
end) || ' ' as ec_price,
(case
when wg.discount_state = 'enable'
and to_char(sysdate, 'yyyy-mm-dd hh24:mi:dd') between wg.begin_time
and wg.end_time
then
wg.promote_phrase
when g.discount_state = 'enable'
and to_char(sysdate, 'yyyy-mm-dd hh24:mi:dd') between g.begin_time
and g.end_time
then
g.promote_phrase
else
''
end) as promote_phrase, pc.pro_catalog_name, wp.product_keyword, wp.PRODUCT_CHN_NO,
pb.product_brand_name, nvl(wp.product_order,) product_order
from wap_product wp
left join product p on p.product_id = wp.product_id and p.is_delete = 'N'
left join wap_goods wg on wp.product_id = wg.product_id and wg.is_delete = 'N' and wg.is_default = 'Y'
left join goods g on g.goods_id = wg.goods_id and g.is_delete = 'N' and g.is_default = 'Y'
left join product_catalog pc on pc.pro_catalog_id = wp.pro_catalog_id and pc.is_delete = 'N'
left join product_brand pb on pb.product_brand_id = wp.product_brand_id and pb.is_delete = 'N'
left join (
select min(pt.tag_id) as tag_id,
min(ptd.goods_id) as goods_id,
min(pt.tag_icon_url) as tag_icon_url
from product_tag_def ptd, product_tag pt
where ptd.tag_id = pt.tag_id
and pt.is_delete = 'N'
and pt.tag_type = 'icon'
group by ptd.goods_id
) tag on tag.goods_id = wg.goods_id
left join (
select pig.product_id as product_id,
min(pig.image_order),
min(pig.pro_image_url) as
pro_image_url
from wap_product_img pig
where pig.image_type = 'small'
group by pig.product_id) pi on wp.product_id = pi.product_id
where wp.is_delete = 'N'
and p.is_onsale = 'Y'
and wg.is_delete = 'N'
and wg.is_default = 'Y'
and wp.pro_catalog_id is not null
and wp.product_code NOT like 'AJ%'
and g.goods_no in
<foreach collection="list" item="listItem" index="index"
open="(" separator="," close=")" >
#{listItem,jdbcType=VARCHAR}
</foreach>
</select>
public List<Map<String, Object>> queryGoodsByGoodsNoPcweb(List<String> goodsNos);
public ServiceMessage<List<Map<String, Object>>> queryGoodsListByGoodsNoList(List<String> goodsNoList, SiteType siteType) {
try {
if (goodsNoList == null || goodsNoList.size() < 1) {
return super.returnParamsError("接收到的goodsNoList(" + goodsNoList + ")为空");
} else if (goodsNoList.get(0) == null || "".equals(goodsNoList.get(0).trim())) {
return super.returnParamsError("接收到的goodsNoList(" + goodsNoList.get(0) + ")元素为空");
} else if (siteType == null) {
return super.returnParamsError("接收到的SiteType(" + siteType + ")元素为空");
}
List<Map<String, Object>> goodsList = null;
if (SiteType.PCWEB.equals(siteType)) {
goodsList = goodsMapper.queryGoodsByGoodsNoPcweb(goodsNoList);
} else if (SiteType.MOBILE.equals(siteType)) {
goodsList = goodsMapper.queryGoodsByGoodsNoMobile(goodsNoList);
}
return super.returnCorrectResult(goodsList);
} catch (Throwable e) {
return super.returnException(e);
}
}
mybatis 之 parameterType="List" 2的更多相关文章
- mybatis中parameterType可以写的别名
mybatis中parameterType可以写的别名 https://blog.csdn.net/sdzhangshulong/article/details/51749807 _byte byte ...
- mybatis的parameterType使用map实现真正的sql随意写
在dao层给map赋值 纠正一下应该把dd作为传入而不是sbiId; sqlMap中的parameterType="java.util.Map", 就 OK package com ...
- 【JAVA - SSM】之MyBatis的ParameterType的使用
在MyBatis的Mapper.xml文件中,参数的表示方法有两种:一种是使用 "#{XXX}" 的方式表示的,另一种是使用 "${XXX}" 的方式表示的.今 ...
- MyBatis mapper parameterType
1. 传入简单类型 JAVA代码: public User get(Long id) { return (User) getSqlSession().selectOne("com.liu ...
- Mybatis中parameterType、resultMap、statementType等等配置详解(标签中基本配置详解)
一.(转自:https://blog.csdn.net/majinggogogo/article/details/72123185) 映射文件是以<mapper>作为根节点,在根节点中支持 ...
- mybatis之parameterType传递多个参数
当在查询的时候需要传入多个参数的时候该怎么办呢: 1,封装成一个Model对象,底层HashMap还是一个 User user=new User(); user.setUserName("z ...
- MyBatis的parameterType传入参数类型
在mybatis映射接口的配置中,有select,insert,update,delete等元素都提到了parameterType的用法,parameterType为输入参数,在配置的时候,配置相应的 ...
- 【JavaEE】之MyBatis的ParameterType的使用
在MyBatis的Mapper.xml文件中,参数的表示方法有两种:一种是使用 “#{XXX}” 的方式表示的,另一种是使用 “${XXX}” 的方式表示的.今天来介绍以下这两种方式的不同之处. 1. ...
- Mybatis的parameterType传入多个参数
如果查询的条件有多个的时候,mybatis有三种传入方式: 1.通过注解传入 例如: public interface Mapper(){ public User login(@Param(" ...
- mybatis 之 parameterType="String" resultType="java.util.HashMap">
public ServiceMessage<Map<String, String>> getGoodsStockNo( List<Map<String, Strin ...
随机推荐
- Oracle Grid Infrastructure Installation Guide for Linux 以debug模式安装并记录日志
最新文章:Virson's Blog 使用如下命令能够以debug模式安装Oracle Grid并将日志记录到文件 [grid@vdb1 11ggrid]$ ./runInstaller -debug ...
- 自然语言交流系统 phxnet团队 创新实训 项目博客 (十一)
神经网络的计算过程 神经网络结构如下图所示,最左边的是输入层,最右边的是输出层,中间是多个隐含层,隐含层和输出层的每个神经节点,都是由上一层节点乘以其权重累加得到,标上“+1”的圆圈为截距项b,对输入 ...
- linux刻录iso到u盘
需要的工具:Linux系统.U盘.ISO镜像文件.首先在Linux系统中打开终端,使用dd命令,格式如下:sudo dd if=xxx.iso of=/dev/sdb命令中xxx.iso是你的ISO镜 ...
- 关于Unity中的光照(二)
光源 1: 光照的本质:就是光的颜色和物体纹理的颜色的混合;2: 光源类型: 点光源,定向光源,聚光灯, 区域光源; 区域光的范围会在场景中用黄色的光显示出来; z轴是光的方向; 光的强度会随距离衰减 ...
- c 二维数组动态分配和释放
c动态语言 函数声明的头文件在<stdlib.h>里 使用malloc函数为字符串分配内存 -->记得释放内存 free() #include <stdio.h> #in ...
- Oracle 数据泵使用详解
数据泵使用EXPDP和IMPDP时应该注意的事项: EXP和IMP是客户端工具程序,它们既可以在客户端使用,也可以在服务端使用. EXPDP和IMPDP是服务端的工具程序,他们只能在ORACLE服务端 ...
- CSS的块级元素和内联元素,以及float
说明:之前有一点搞错了,就是float其实是浮动起来,其它元素会位于它的底层. 最近在系统地学习HTML5,感觉补上了好多缺失的知识. 例如: 锚点定位其实可以通过 id 来实现: CSS 使用 !i ...
- org.in2bits.MyXls.XlsDocument 生成excel文件 ; 如果想读取模板再另外生成的话,试试 NPOI
优点:不依赖Microsoft组件,在内存中操作excel,读写速度快. 缺点:无法读取模板,只能生成新的excel (我亲自测试是在读取完模板后,不能保存,也不能另存,并且其他人说这个读取还会有 ...
- Oracle错误IMP-00010: 不是有效的导出文件, 头部验证失败 分类: Oracle 2015-07-09 13:56 20人阅读 评论(0) 收藏
Oracle 11g的dmp备份文件导入到Oracle 10g,出现错误信息: Import: Release 10.2.0.1.0 - Production on 星期四 7月 9 13:47:04 ...
- Python 判断文件是否存在的三种方法
通常在读写文件之前,需要判断文件或目录是否存在,不然某些处理方法可能会使程序出错.所以最好在做任何操作之前,先判断文件是否存在. 这里将介绍三种判断文件或文件夹是否存在的方法,分别使用os模块.Try ...