一、查询spu系列商品:

1、查询spu系列商品中所有属性值之间的组合(一个组合,即一个sku商品)!!!
这里的数据苹果11
颜色:黑色、白色、红色;
版本:128G、256G;
总共6种组合:

SELECTa.id,b.sale_attr_value_id
FROMpms_sku_info a,pms_sku_sale_attr_value b
WHEREa.id = b.sku_id
AND a.product_id = 67


二、制作哈希表:

2、把查到的结果,生成一个k是销售属性值组合v是skuId的hash哈希表
k:244|247| v:118
k:244|248| v:119
k:245|247| v:120
k:245|248| v:121
K:246|247| v:122
K:246|248| v:123

把这个哈希表,封装成一个json字符串,再传递过去给前端页面。
用户一打开这个sku商品页面,后台就能查询该spu系列下他的其他兄弟姐妹,转化为哈希表!并封装成json格式的字符串传递给前端页面!
当用户要点击该系列下其他属性版本的手机的时候,使用前端JavaScript根据哈希表的值,直接判断该属性的组合k属于哪个v:skuId,根据v:skuId跳转页面!

3、这个方法查询比异步查询还要好,异步还要开两次数据库。用这个方法直接查出所有组合给前端,前端根据这个组合,直接请求sku即可!

——当然也可以这样:当用户请求到某个sku商品的时候,不采取查询该spu系列其他的兄弟姐妹。
而是等待用户选择完颜色、版本等属性的时候,前端把用户选择的属性值返回给后端,去请求数据库(查询这些颜色、版本属性等组合属于哪个skuId?),再请求数据库根据这skuId查询sku商品并且返回这个商品对象!

(1)这样做也是可以的,但是这样的效率未免太低了!用户选择完这些属性组合,你再去数据库查询,并且还开了两次数据库。
如果用户一直在点击其他属性值,每次点击,你就去查两次数据库。这样的操作,效率太低,性能太差了!

(2)而如果采用hash哈希表法,每次请求sku商品页面的时候。就把其他所有的属性值组合查询出来。
如果用户一直在点击其他属性值,每次点击,只需要前端JavaScript做判断用户选择了哪些属性组合,根据这属性组合就能知道skuId,直接请求该id的html地址。这样的操作,是不是快很多呢??

三、代码实现:

Controller层:

//根据当前sku所属的spuId,查询其他的sku集合的哈希hash表
List<PmsSkuInfo> pmsSkuInfos = skuService.getSkuSaleAttrValueListBySpu(spuId);
//new一个哈希hashMap,写好string,string接收类型,快捷键Ctrl+alt+v生成。
HashMap<String, String> hashMap = new HashMap<>();
//循环后端传递过来的列表
for (PmsSkuInfo skuInfo : pmsSkuInfos) {String k="";   //定义k:为空字符串String v=skuInfo.getId();   //v是:skuId//遍历销售属性值列表,获取外键ID:SaleAttrValueId,即spu销售属性值的主键IDList<PmsSkuSaleAttrValue> skuSaleAttrValueList = skuInfo.getSkuSaleAttrValueList();for (PmsSkuSaleAttrValue skuSaleAttrValue : skuSaleAttrValueList) {k = k + skuSaleAttrValue.getSaleAttrValueId() + "|";  //每一个k值后+管道符“|”,不要使用逗号,避免java解析为数组}//插入每一对k和v到hash哈希表中hashMap.put(k,v);
}
//用阿里巴巴的fastJson技术,把哈希表hash转化为json的字符串格式!
String jsonStr = JSON.toJSONString(hashMap);
//把json传递给前端页面
modelMap.put("jsonStr",jsonStr);

实现层:

@Override
public List<PmsSkuInfo> getSkuSaleAttrValueListBySpu(String spuId) {List<PmsSkuInfo> pmsSkuInfos = pmsSkuInfoMapper.selectSkuSaleAttrValueListBySpu(spuId);return pmsSkuInfos;
}

Mybatis查询数据库(双层集合,需要添加映射关系!!!):

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.atguigu.gmall.manage.service.mapper.PmsSkuInfoMapper"><select id="selectSkuSaleAttrValueListBySpu" resultMap="selectSkuSaleAttrValueListBySpuMap">SELECTa.id as a_id,b.id as b_id,b.sale_attr_value_idFROMpms_sku_info a,pms_sku_sale_attr_value bWHEREa.id = b.sku_idAND a.product_id = #{spuId}</select><resultMap id="selectSkuSaleAttrValueListBySpuMap" type="com.atguigu.gmall.bean.PmsSkuInfo" autoMapping="true"><result column="a_id" property="id"></result><collection property="skuSaleAttrValueList" ofType="com.atguigu.gmall.bean.PmsSkuSaleAttrValue" autoMapping="true"><result column="b_id" property="id"></result></collection></resultMap></mapper>

Controller层封装好的hash表,转换为json字符串格式,使用阿里巴巴的fastJson技术

测试结果(成功!):

四、前端处理该哈希表:

k:244|247| v:118
k:244|248| v:119
k:245|247| v:120
k:245|248| v:121
K:246|247| v:122
K:246|248| v:123
前端页面处理这个json字符串:

(1)js控制:点击一次方框,被选中的方框就变红,不被选中的方框红色移除。并且调用
switchSkuId()函数

(2)先测试一下接收到的这个哈希表json字符串并弹窗

<!--接收后端的json字符串,隐藏的text-->
<input type="text" th:value="${jsonStr}" id="valuesSku"/>function switchSkuId() {var hashstr = $("#valuesSku").val();  //使用美元id选择器,选择input的对象(id)valuesSku,并获得里面的值val(json字符串!!!)alert(hashstr);
}


(3)那么怎么知道用户点击了哪些属性值呢?
其实在js里的代码就告诉你了,被选中的属性的方框会被标记为红色redborder!!!
只需要获取被标红方框里面的属性值ID即可!!!

(4)代码实现,用户点击了方框,方框标红。获取标红方框的div数组,循环遍历获取被选中的数值ID,并把这个属性值的ID组合成hash哈希表的K。

<!--接收后端的json字符串,隐藏的text-->
<input type="text" th:value="${jsonStr}" id="valuesSku"/>function switchSkuId() {var hashstr = $("#valuesSku").val();  //使用美元id选择器,选择input的对象(id)valuesSku,并获得里面的值val(json字符串!!!)alert(hashstr);var saleAttrValueIds = $(".redborder div");  //使用样式选择器,选择了被标红的方框样式,并获取层级选择器下一层的div的数组!var k = "";$(saleAttrValueIds).each(function (i,saleAttrValueId) {  //循环遍历这个数组,并获取被标红方框div里的id:saleAttrValueIdk=k+($(saleAttrValueId).attr("value"))+"|";});alert(k);
}

弹窗测试(获得被选中的销售属性值ID成功):


(5)知道用户选择的属性值组合k了。那么就可以根据后端传过来的哈希json判断是属于哪个v了。
k:244|247| v:118
k:244|248| v:119
k:245|247| v:120
k:245|248| v:121
K:246|247| v:122
K:246|248| v:123

这里注意了!!!!一开始后端传递过来的是一个json字符串,是一个字符串!!!要把这个字符串转换为json才行!!!

var hashstr_json =  JSON.parse(hashstr);   //把接收后端的json字符串 转换 为json
var skuId = hashstr_json[k];       //直接把k放进哈希json里,即可获得相对于的v(skuId)
alert(skuId);

弹窗测试(获得skuId成功):

(6)既然知道被选中的属性值ID,也获取了skuId,即知道用户点击了哪件sku商品了。接下来就是直接请求跳转到该skuId下的html页面即可!!!

if(skuId) {window.location.href = "http://item.gmall.com/" + skuId + ".html";
}

测试(根据skuId跳转成功):

好了现在功能是实现了!但是!!!有没有想过每次请求sku的html页面,都要制作一次哈希表,是不是性能也比较低???
还有一种静态文件的处理,就是把当前的spu系列所有的sku商品制作成的哈希表保存为一个spuId文件!!!这里可以应用前端技术生成这个文件!!!


在前端页面引入这个spuId的js文件!!!

当用户第一次访问一个sku商品的时候,制作好哈希表,并存储为js文件!
如果用户再次在当前spu系列商品里访问其他sku商品,前端根据这个js哈希表文件的skuId,直接进行页面请求过去即可了

就不需要再一次请求数据库,再一次制作哈希表,省去每次请求页面都制作哈希表!!!
这样的话,制作哈希的代码就不应该放在item项目的controller层了

制作销售属性的组合的集合为哈希表,根据用户点击的属性组合判断某个skuId并跳转到对应的页面相关推荐

  1. 数据结构与算法 学习笔记(8):字典、集合、哈希表

    数据结构与算法 学习笔记(8):字典.集合.哈希表 本次文章记录的是和字典.集合.哈希表等数据结构相关的LeetCode算法题(题号与LeetCode对应),包括其构造和使用,针对每一题或一类题给出了 ...

  2. 【Java】列表、集合、哈希表和可变参数

    1 List 1.1 List的特点 List接口继承自Collection接口 List是有序集合,存取顺序一致 允许存储重复元素 1.2 List的特有方法[带索引] public void ad ...

  3. C#中的集合、哈希表、泛型集合、字典

    集合ArrayList 集合:集合可以看做是数组,可以将其看成"长度可变,具有很多方法的数组".使用ArrayList,首先需要导入命名空间using.system.collect ...

  4. 【C#】集合_哈希表_字典_泛型_文件

    数组能做到:存放同种类型数据,且数据个数确定 object类型的数组能满足:放各种类型的数据,确定放多少个,但是随意插入元素,数组做不到 集合能做到:存放各种数据类型,且不确定存放多少个,能做到随意插 ...

  5. python 字典 哈希_Python 字典和集合基于哈希表实现

    哈希表作为基础数据结构我不多说,有兴趣的可以百度,或者等我出一篇博客来细谈哈希表.我这里就简单讲讲:哈希表不过就是一个定长数组,元素找位置,遇到哈希冲突则利用 hash 算法解决找另一个位置,如果数组 ...

  6. 一步一步教你制作销售业绩分析报告

    在入门案例动态销售报告中已经带领大家入门制作PowerBI可视化报告.本文主题销售业绩分析将继续针对入门案例进行进一步优化,让大家更改的了解和掌握使用PowerBI的功能.优化内容主要有两个: 1.数 ...

  7. PropertyGrid 绑定动态的属性与值的集合

    建立下面3个类: XProp XPropDescriptor XProps 建立Class XProp XProp 就是用户将具体使用的属性.PropertyGrid 很炫的一点就是属性的定制可以有很 ...

  8. 巧用Excel 2010数据透视表制作销售报表

    小刘需要根据2010-2011两年间的订单记录创建季度报表,以便分析各类图书的销售情况.面对如此庞大的订单记录,该从何下手呢? 其实最快捷的办法是使用Excel 2010创建数据透视表,以快速合并和比 ...

  9. 【Java 集合】Java 集合的线程安全性 ( 加锁同步 | java.utils 集合 | 集合属性 | java.util.concurrent 集合 | CopyOnWrite 机制 )

    文章目录 I . Java 集合的线程安全概念 ( 加锁同步 ) II . 线程不安全集合 ( 没有并发需求 推荐使用 ) III . 集合属性说明 IV . 早期的线程安全集合 ( 不推荐使用 ) ...

最新文章

  1. 20个经典函数细说 Pandas 中的数据读取与存储,强烈建议收藏
  2. java程序输出矩阵_java编程题之顺时针打印矩阵
  3. 粗糙表面的微表面模型——Physically Based Material
  4. csharp: ODP.NET,System.Data.OracleClient(.net 4.0) and System.Data.OleDb读取Oracle g 11.2.0的区别...
  5. 【excel技巧读书笔记001】清除打开过的文件记录
  6. mysql 统计查询不充电_MySql查询语句介绍,单表查询,来充电吧
  7. 实现背景透明的方法,兼容ie6/7/8等浏览器
  8. HSSWORKBOOK中读取Excel出现的异常现象
  9. linux git 搭建 debian,基于Debian Linux搭建Git服务器
  10. Nginx总复习---1
  11. Linux服务器挂死案例分析
  12. WSL2开启sshd
  13. Java 使用反射 Class.forName() 报错java.lang.ClassNotFoundException 的解决办法
  14. 《数字信号处理》——(一).DTFT、DFT(python实现)
  15. 微信公众号H5网页调用微信支付
  16. linux 更新包缓存目录,清除ubuntu下缓存、软件安装包和多余内核
  17. 基于Boostrap+jsp+spring+mysql的音乐推荐系统
  18. Android修改分区格式为F2FS
  19. 3年级计算机的知识能力,三年级信息技术教案资料三篇
  20. 源码看JAVA【五】Byte

热门文章

  1. Python关键字参数和可变参数
  2. 计算机主机与硬盘连接不上,如何连接计算机主机的内部电路?
  3. 之后的计划 我的日常日记系列。
  4. Python打开文件对话框(MacWin通用)
  5. EasyExcel做导出报表时的奇偶行、自动换行设置
  6. 【华为机试真题 Python实现】圆桌队列【2022 Q2 | 200分】
  7. 领导排挤员工有哪些暗示(盘点3种领导排挤你的暗示)
  8. 2020-2-25(93)
  9. MATLAB求解线性规划问题(附问题及代码)
  10. 如何将pdf大小压缩?怎么缩小pdf的文件大小?