【laralve项目】@12 商品分类--观察者模式--单元测试--处理无极限分类(1)

简介: 【laralve项目】@12 商品分类--观察者模式--单元测试--处理无极限分类

屏幕快照 2022-05-16 上午11.32.03.png屏幕快照 2022-05-16 上午11.32.13.png

平时的分类基本都市这样的


水果(0)


    |--外国水果(1)


    |     |--栗子(2)


    |


    |--国产水果(1)


             |--栗子(2)



注意如果我们使用上面那种数据表的结构的话会存在这问题。如果数据量很多的时候就会出现。


1.       场景一:从上级开始查找它所有的子级,这个时候就需要使用递归的算法去查询所有的子级内容,同时会产生很多的SQL查询,从而影响性能。


2.       场景二:从最小的子级开始查找所有的上级,这个时候同样的也是递归的方式查找,同样也有很多的查询SQL


3.       场景三:这个情景可能会在多级分销中出现,就是判断哪个内容是否存在上下级的关系


应对与这个三个问题的解决可以通过新增一个字段possess来记录一个内容中的所有上级id,可以通过任意分割符号进行分 比如在本次项目中可以使用 ‘-’


php artisan make:migration add_path_to_goods_categories_table --table=goods_categories


                                       

image.png


加了这个字段之后对于上面的三个问题的解决


1. 从上往下查找的时候字只需要取出那个字段的内容 ,然后where ‘possess’  like  ‘-1-%’ 即可


2.从下往上查找的时候只需要获取那个字段,然后同样的字符串处理就好了


3.判断是否存在关系,先获取level最大的那个信息中的possess的值。然后再获取了一个possess同时在这个值上跟上这条数据的id-。 然后判断第一个值的内容是否以第二个值的内容开头如果是就存在关系,否则相反


修改模型


定义了一个关联关系,在category定义一个与上级以及子级的模型关联。然后添加三个获取器;1.获取所有的上级id,2.根据获取的id获取子级的所有上级,并且根据level排序。 至于之后一个只是获取所有的上级名称

屏幕快照 2022-05-16 上午11.33.04.png屏幕快照 2022-05-16 上午11.33.11.png

相关文章
|
2月前
|
测试技术 数据库 UED
Python 性能测试进阶之路:JMeter 与 Locust 的强强联合,解锁性能极限
【9月更文挑战第9天】在数字化时代,确保软件系统在高并发场景下的稳定性至关重要。Python 为此提供了丰富的性能测试工具,如 JMeter 和 Locust。JMeter 可模拟复杂请求场景,而 Locust 则能更灵活地模拟真实用户行为。结合两者优势,可全面评估系统性能并优化瓶颈。例如,在电商网站促销期间,通过 JMeter 模拟大量登录请求并用 Locust 模拟用户浏览和购物行为,可有效识别并解决性能问题,从而提升系统稳定性和用户体验。这种组合为性能测试开辟了新道路,助力应对复杂挑战。
102 2
|
1天前
|
网络协议 关系型数据库 应用服务中间件
【项目场景】请求数据时测试环境比生产环境多花了1秒是怎么回事?
这是一位粉丝(谢同学)给V哥的留言,描述了他在优化系统查询时遇到的问题:测试环境优化达标,但生产环境响应时间多出1秒。通过抓包分析,发现MySQL请求和响应之间存在500毫秒的延迟,怀疑是网络传输开销。V哥给出了以下优化建议:
|
26天前
|
测试技术
自动化测试项目学习笔记(五):Pytest结合allure生成测试报告以及重构项目
本文介绍了如何使用Pytest和Allure生成自动化测试报告。通过安装allure-pytest和配置环境,可以生成包含用例描述、步骤、等级等详细信息的美观报告。文章还提供了代码示例和运行指南,以及重构项目时的注意事项。
117 1
自动化测试项目学习笔记(五):Pytest结合allure生成测试报告以及重构项目
|
26天前
|
测试技术 Python
自动化测试项目学习笔记(四):Pytest介绍和使用
本文是关于自动化测试框架Pytest的介绍和使用。Pytest是一个功能丰富的Python测试工具,支持参数化、多种测试类型,并拥有众多第三方插件。文章讲解了Pytest的编写规则、命令行参数、执行测试、参数化处理以及如何使用fixture实现测试用例间的调用。此外,还提供了pytest.ini配置文件示例。
19 2
|
25天前
|
机器学习/深度学习 并行计算 数据可视化
目标分类笔记(二): 利用PaddleClas的框架来完成多标签分类任务(从数据准备到训练测试部署的完整流程)
这篇文章介绍了如何使用PaddleClas框架完成多标签分类任务,包括数据准备、环境搭建、模型训练、预测、评估等完整流程。
69 0
目标分类笔记(二): 利用PaddleClas的框架来完成多标签分类任务(从数据准备到训练测试部署的完整流程)
|
26天前
|
测试技术 Python
自动化测试项目学习笔记(二):学习各种setup、tearDown、断言方法
本文主要介绍了自动化测试中setup、teardown、断言方法的使用,以及unittest框架中setUp、tearDown、setUpClass和tearDownClass的区别和应用。
48 0
自动化测试项目学习笔记(二):学习各种setup、tearDown、断言方法
|
1月前
|
人工智能 自动驾驶 机器人
【通义】AI视界|苹果自动驾驶汽车项目画上句号:加州测试许可被取消
本文精选了24小时内的重要科技新闻,包括Waymo前CEO批评马斯克对自动驾驶的态度、AMD发布新款AI芯片但股价波动、苹果造车项目终止、Familia.AI推出家庭应用以及AI逆向绘画技术的进展。更多内容请访问通义官网体验。
|
1月前
|
前端开发 JavaScript 应用服务中间件
linux安装nginx和前端部署vue项目(实际测试react项目也可以)
本文是一篇详细的教程,介绍了如何在Linux系统上安装和配置nginx,以及如何将打包好的前端项目(如Vue或React)上传和部署到服务器上,包括了常见的错误处理方法。
160 0
linux安装nginx和前端部署vue项目(实际测试react项目也可以)
|
1月前
|
Java Maven
Maven 项目测试
接下来我们要学习如何构建和测试这个项目。
40 5
|
1月前
|
JavaScript
vue尚品汇商城项目-day07【55.编码测试与打包发布项目】
vue尚品汇商城项目-day07【55.编码测试与打包发布项目】
29 3