mysql 商城商品属性开发的动态解决方案
终极方案:动态属性解决方案
推荐使用 JSON 字段 + 虚拟列索引
的组合方案
结合灵活存储与查询优化,平衡扩展性与性能
完整实现步骤
步骤 1:创建基础表结构
CREATE TABLE products (id INT PRIMARY KEY AUTO_INCREMENT,name VARCHAR(100) NOT NULL,price DECIMAL(10,2) NOT NULL,attributes JSON NOT NULL CHECK (JSON_VALID(attributes)) -- 强制验证JSON格式
);
步骤 2:插入动态属性数据
-- 插入带不同属性的产品
INSERT INTO products (name, price, attributes) VALUES
('T-Shirt', 29.99, '{"color": "red", "size": "XL"}'), -- 两个属性
('Coffee Mug', 9.99, '{"material": "ceramic"}'), -- 单个属性
('Phone Case', 14.99, '{"color": "black", "防摔等级": "IP68"}'); -- 中文属性名
步骤 3:动态查询技巧
-- 通用查询(所有属性包含特定值的商品)
SELECT * FROM products
WHERE JSON_CONTAINS(attributes, '"red"', '$') -- 查询所有属性值包含'red'的商品-- 精确属性查询(需知道属性名)
SELECT * FROM products
WHERE attributes->"$.color" = 'black' -- 查询颜色为黑色的商品-- 模糊属性名查询(不确定属性名时)
SELECT * FROM products
WHERE JSON_KEYS(attributes) LIKE '%防%' -- 查找属性名包含"防"的商品
步骤 4:按需创建虚拟列索引
-- 为高频查询属性创建虚拟列
ALTER TABLE products
ADD COLUMN dynamic_color VARCHAR(30) GENERATED ALWAYS AS (attributes->>"$.color") VIRTUAL,
ADD COLUMN dynamic_size VARCHAR(10) GENERATED ALWAYS AS (attributes->>"$.size") VIRTUAL,
ADD INDEX idx_color (dynamic_color),
ADD INDEX idx_size (dynamic_size);-- 混合查询示例(利用索引加速)
SELECT * FROM products
WHERE dynamic_color = 'red' AND price BETWEEN 20 AND 30;
方案优势说明
特性 | 实现方式 | 优势说明 |
---|---|---|
动态属性支持 | JSON 字段存储任意键值对 | 无需预定义字段,支持中文/特殊符号属性名 |
查询性能优化 | 虚拟列 + BTREE 索引 | 对高频查询属性建立索引,速度媲美传统列 |
数据验证 | CHECK 约束 + JSON_VALID() | 确保存储的JSON格式合法 |
多语言支持 | 直接存储UTF-8字符 | 完美支持中文属性名(如"防摔等级") |
扩展性 | 随时新增属性无需修改表结构 | 适应业务快速变化需求 |
高级用法示例
1. 数据类型自动转换
-- 存储数值型属性
UPDATE products
SET attributes = JSON_SET(attributes, '$.weight', '3.5')
WHERE id = 1;-- 查询时转换类型
SELECT name, CAST(attributes->>"$.weight" AS DECIMAL(3,1)) AS weight_kg
FROM products
WHERE attributes->>"$.weight" IS NOT NULL;
2. 动态属性统计
-- 统计所有出现过的属性名及其使用次数
SELECT attr_key, COUNT(*) AS usage_count
FROM products, JSON_TABLE(JSON_KEYS(attributes), '$[*]' COLUMNS (attr_key VARCHAR(50) PATH '$')) AS jt
GROUP BY attr_key
ORDER BY usage_count DESC;-- 结果示例:
-- attr_key | usage_count
-- ----------------------------
-- color | 2
-- size | 1
-- material | 1
-- 防摔等级 | 1
3. 动态属性搜索
-- 创建全文索引(MySQL 8.0+)
ALTER TABLE products
ADD COLUMN attributes_text TEXT GENERATED ALWAYS AS (JSON_UNQUOTE(attributes)) VIRTUAL,
ADD FULLTEXT INDEX ft_attributes (attributes_text);-- 全文检索示例
SELECT * FROM products
WHERE MATCH(attributes_text) AGAINST('+red -cotton' IN BOOLEAN MODE);
避坑指南
-
数据验证策略
-- 强制必须包含至少一个属性 ALTER TABLE products ADD CONSTRAINT chk_min_attributes CHECK (JSON_LENGTH(attributes) >= 1);-- 应用层验证示例(Python伪代码) def validate_attributes(attrs):if not isinstance(attrs, dict):raise ValueError("Attributes must be a dictionary")if len(attrs) == 0:raise ValueError("At least one attribute required")for k, v in attrs.items():if not isinstance(k, str) or len(k) > 50:raise ValueError("Attribute name invalid")
-
性能优化建议
- 为查询频率超过30%的属性创建虚拟列索引
- 使用
JSON_COMPACT()
存储节省空间 - 定期执行
OPTIMIZE TABLE
维护JSON字段
-
版本兼容方案
-- MySQL 5.6兼容方案(使用TEXT代替JSON) CREATE TABLE legacy_products (id INT PRIMARY KEY AUTO_INCREMENT,attributes TEXT,CHECK (attributes REGEXP '^\{.*\}$' -- 简单验证JSON格式) );
相关文章:
mysql 商城商品属性开发的动态解决方案
终极方案:动态属性解决方案 推荐使用 JSON 字段 虚拟列索引 的组合方案 结合灵活存储与查询优化,平衡扩展性与性能 完整实现步骤 步骤 1:创建基础表结构 CREATE TABLE products (id INT PRIMARY KEY AUTO_INCREMENT,name VARCHAR(100) NO…...
Java递归练习----猴子偷桃
问题: 有一堆桃子,猴子第一天吃灵其中的一般,并在多吃了一个!以后每天猴子都吃其中的一半,然后多吃一个。当到第十天时,想再吃时(即还没吃),发现只有1个桃子了ÿ…...
[干货]PHM学习软件|PHM预测性维护系统
使用步骤教程如下 1、登录 用户名:52phm 密码:xxx (区别在于不同用户密钥不一样) 2、上传需要分析的数据集 支持数据集格式:csv、xlsx、xls、mat、json 3、主题1:机械参数计算 计算轴承、齿轮、皮带的…...
详解正则表达式中的?:、?= 、 ?! 、?<=、?<!
1、?: - 非捕获组 语法: (?:pattern) 作用: 创建一个分组但不捕获匹配结果,不会将匹配的文本存储到内存中供后续使用。 优势: 提高性能和效率 不占用编号(不会影响后续捕获组的编号) 减少内存使用 // 使用捕获组 let regex1 /(hell…...
Java常见面试问题
一.Liunx 二.Java基础 1.final 2.static 3.与equals 三.Collection 1.LIst 2.Map 3.Stream 四、多线程 1.实现方法 2.线程池核心参数 3.应用场景 五、JVM 1.堆 2.栈 六、Spring 1.面向对象 2.IOC 3.AOP 七、Springboot 1.自动装配 八、SpringCloud 1.Nacos 2.seata 3.ga…...
C#MQTT协议服务器与客户端通讯实现(客户端包含断开重连模块)
C#MQTT协议服务器与客户端通讯实现 1 DLL版本2 服务器3 客户端 1 DLL版本 MQTTnet.DLL版本-2.7.5.0 基于比较老的项目中应用的DLL,其他更高版本变化可能较大,谨慎参考。 2 服务器 开启服务器 关闭服务器 绑定事件【客户端连接服务器事件】 绑定事件【客户…...
GGML源码逐行调试(上)
目录 前言1. 简述2. 环境配置3. ggml核心概念3.1 gguf3.2 ggml_tensor3.3 ggml_backend_buffer3.4 ggml_context3.5 backend3.6 ggml_cgraph3.7 ggml_gallocr 4. 推理流程整体梳理4.1 时间初始化与参数设置4.2 模型加载与词汇表构建4.3 计算图与内存分配4.4 文本预处理与推理过…...
智能测试用例生成:老旧平台页面查询功能的大模型改造
引言 由于GUI小工具【Deepseek APIPython 测试用例一键生成与导出】的不断升级实践,发现大模型的需求文档解析生成测试用例的可直接复用率不太理想,因此萌生了对老旧系统升级改造的想法。旧测试用例生成平台主要在于采集用户输入的字段名称、字段类型及…...
使用Python解决Logistic方程
引言 在数学和计算机科学中,Logistic 方程是描述人口增长、传播过程等现象的一种常见模型。它通常用于表示一种有限资源下的增长过程,比如动物种群、疾病传播等。本文将带领大家通过 Python 实现 Logistic 方程的求解,帮助你更好地理解这一经典数学模型。 1.什么是 Logist…...
文件上传基本原理靶场实现
一. 漏洞原理 未经验证的上传机制: 应用程序未对用户上传的文件进行充分验证,包括: 文件类型/扩展名:仅依赖客户端提交的MIME类型或简单检查扩展名(如.jpg),但未验证文件实际内容。 文件内容&a…...
灰色预测模型:GM(1,1)预测模型
灰色预测模型 灰色预测的主要特点是模型使用的不是原始数据序列,而是生成的数据序列。核心体系是灰色模型,即对原始数据作累加生成(或其他方法生成)得到近似的指数规律再进行建模的方法,优点是不需要很多的数据&#…...
SPORT(Serial Port)接口
SPORT(Serial Port)接口是DSP芯片中常用的高速同步串行通信接口,主要用于与外部设备(如ADC、DAC、编解码器等)进行数据传输。以下是对SPORT接口的详细介绍: 1. SPORT接口概述 SPORT接口设计用于高效传输连…...
Python及C++中的字典
一、Python中的字典 (一)基本概念 字典(dict)是Python中一种可变容器模型,用于存储键值对(key:value)。字典的键必须是不可变类型(如字符串、数字或元组),而…...
Neo4j GDS-11-neo4j GDS 库中相似度算法实现
neo4j GDS 系列 Neo4j APOC-01-图数据库 apoc 插件介绍 Neo4j GDS-01-graph-data-science 图数据科学插件库概览 Neo4j GDS-02-graph-data-science 插件库安装实战笔记 Neo4j GDS-03-graph-data-science 简单聊一聊图数据科学插件库 Neo4j GDS-04-图的中心性分析介绍 Neo…...
网络互连与互联网2
1.IP数据报首部在IHL 字段的最小值为5 2.三层交换机包括二层交换和三层转发,二层交换由硬件实现,三层转发采用软件实现 3.在BGP路由选择协议中,AS_PATH属性可以避免在AS之间产生环路 4.常用的电子邮件协议:SMTP(25&…...
4月12日随笔
今天大风天气的第一天,周六,早上九点半起来听了排球技术台培训。结果一天都没顾得上看教学视频。黄老师说有排球基础的可以试试当主裁,那一定要争取一下! 上午看了两集小排球,然后开始了解一些中介相关信息。因为下午…...
web自动化测试
自动化测试理论 UI:User Interface(用户接口-用户界面),主要包括:app、web ui自动化测试:使用工具或代码执行用例的过程 什么样的项目适合做自动化 1、需要回归测试项目(甲方自营项目、金…...
代码随想录二叉树小结1;(递归与迭代法小结)
一、递归遍历 1.递归算法三要素: 确定递归函数的参数和返回值: 在递归函数里加上递归的过程中需要处理的参数, 然后明确每次递归的返回值是什么,最后确定递归函数的返回类型。 确定终止条件: 递归算法运行的时候&…...
Audacity命令:“播录”菜单相关命令
1 Audacity命令:“播录”菜单相关命令 1.1 播录菜单 播录菜单中的命令可让您播放、停止、循环播放、擦洗音频或录制音频(包括定时录制和声控录制)。 Scripting IdActionParameters描述RescanDevice:Rescan Audio Devicesnone重新扫描连接到…...
Python及C++中的集合
1. Python 中的集合(set) 1.1 特性 无序性:集合中的元素没有顺序,不能通过索引访问。唯一性:集合中的元素不能重复,如果尝试添加重复的元素,集合会自动忽略。可变性:集合是可变的&…...
[CF2086E] Zebra-like Numbers 题解
确简单的啊,可是自己就是想不到。 考虑计算一个数的斑马值。贪心地,尽量选大的斑马数减即可。 考虑 DP,设 d p i , j dp_{i, j} dpi,j 表示 [ 1 , i ] [1, i] [1,i] 中斑马值为 j j j 的数的个数。那么显然有 d p i , j d p i − m …...
Linux-内核驱动
open uboot.bin target-connect U-Boot(Universal Boot Loader)是一种广泛使用的开源引导加载程序,它允许用户从各种设备(如硬盘、USB设备、网络等)加载操作系统。U-Boot提供了丰富的命令行接口(CLI&#…...
[Dify] 使用 Docker 本地部署 Dify 并集成 Ollama 模型的详细指南
在 AI 应用快速发展的今天,开源项目如 Dify 正成为构建本地化 AI 应用的利器。通过 Dify,你可以轻松地集成不同的大语言模型(LLM),如 Ollama,并快速创建可交互的 AI 应用。本篇文章将带你一步步通过 Docker…...
ESP32+Arduino入门(三):连接WIFI获取当前时间
ESP32内置了WIFI模块连接WIFI非常简单方便。 代码如下: #include <WiFi.h>const char* ssid "WIFI名称"; const char* password "WIFI密码";void setup() {Serial.begin(115200);WiFi.begin(ssid,password);while(WiFi.status() ! WL…...
软件架构评估两大法:ATAM 和 SAAM 的对比与实践
架构权衡分析方法(ATAM)和软件架构分析方法(SAAM)是软件架构评估领域中非常重要的两种方法,以下为你详细介绍: 一、架构权衡分析方法(ATAM) 1.背景与起源:ATAM 是由卡耐…...
《AI大模型应知应会100篇》第13篇:大模型评测标准:如何判断一个模型的优劣
第13篇:大模型评测标准:如何判断一个模型的优劣 摘要 近年来,大语言模型(LLMs)在自然语言处理、代码生成、多模态任务等领域取得了显著进展。然而,随着模型数量和规模的增长,如何科学评估这些模…...
编译 OpenCV 时,cmake 找到 TBB 的方法
编译 OpenCV 时,cmake 找到 TBB 的方法 编译 OpenCV 时,cmake 找到 TBB 的方法 编译 OpenCV 时,cmake 找到 TBB 的方法 HKEY_LOCAL_MACHINE\SOFTWARE\Intel\oneAPI\TBB\2022.1.0cmake 是从上面的注册表里找到的 TBB 安装路径。 这个键下面有…...
SMT贴片组装工艺优化与高效生产
内容概要 现代SMT贴片组装工艺的优化与高效生产涉及多维度技术协同,其核心在于构建精密可控的制造体系。本文系统梳理了从焊接参数调控到智能检测部署的全链路关键环节,重点解析影响生产效能的核心变量及其相互作用机制。通过对比不同贴装设备的速度-精…...
leetcode刷题日记——有效的数独
[ 题目描述 ]: [ 思路 ]: 题目要求求一个数独题目是否有效,即每行,每列,每个九宫格都不能出现相同的数字暴力求解:对每行,每列,以及九宫格进行检查是否存在相同数字运行如下 boo…...
Agent2Agent协议学习资源大全:从理论到实践
下面整理了一份关于谷歌 A2A 协议的学习资源,分为官方资源、开发教程/实践、行业解读和视频教程四个部分,方便您系统性地学习和掌握相关知识: 1. 官方资源 A2A 协议 GitHub 仓库 官方开源代码库,包含协议规范、示例代码和详细文档…...
PCDN收益高低的关键因素
PCDN(P2P内容分发网络)收益好的三个主要关键因素是:硬件配置与性能、网络环境与质量、业务调度与策略。 1. 硬件配置与性能 设备稳定性与兼容性 PCDN节点需长时间稳定运行,硬件性能直接影响收益。例如,使用高性能CPU、…...
ckeditor4.22版本 ckfinder php8版本下,上传提示400的问题
ckeditor4.22版本,ckfinder3,CKFinder 3 for PHP版本。 图片上传时提示:400错误,bad request。 通过编辑文件 D:\wamp\www\module\ckfinder\config.php 修改其配置: ini_set(display_errors, 1); $config[debug] tru…...
2025第四届大学生算法挑战赛 赛前测试赛 题解
前言 题解 测试考场【算法编程赛道】2025第四届大学生算法挑战赛 继续用Deepseek进行求解,还是非常丝滑。 A. 追债之旅 思路: 图论 bfs题 利用deepseek,直接给出答案 感觉deepseek在输入输出上,显得有些啰嗦。 # codingutf-8 import he…...
【软考系统架构设计师】系统配置与性能评价
1、 常见的性能指标 主频外频*倍频 主频1/CPU时钟周期 CPI(Clock Per Instruction)平均每条指令的平均时间周期数 IPC(Instruction Per Clock)每时钟周期运行指令数 MIPS百万条指令每秒 MFLOPS百万个浮点操作每秒 字长影响运算的…...
【软考系统架构设计师】信息系统基础知识
1、 信息的特点:客观性(真伪性)、动态性、层次性、传递性、滞后性、扩压性、分享性 2、 信息化:是指从工业社会到信息社会的演进与变革 3、 信息系统是由计算机硬件、网络和通信设备、计算机软件、信息资源、信息用户和规章制度…...
软考高级-系统架构设计师 其他知识补充
文章目录 系统配置与性能评价性能指标性能评价方法性能评测的常用方法 阿姆达尔解决方法 信息系统基础知识信息系统概述信息系统的分类(低级到高级)信息系统的生命周期(产生、开发、运行、消亡)信息系统开发方法 信息综合技术信息…...
基于查表法的 CRC8 / CRC16 / CRC32校验解析
在嵌入式开发中,CRC(Cyclic Redundancy Check)循环冗余校验算法广泛应用于通信数据校验、Flash 数据完整性检测、Bootloader 升级验证等场景。本文将深入剖析一套完整的 CRC8、CRC16 和 CRC32 实现,并通过查表法(Table…...
Web渗透之XSS注入
XSS的类型 1、反射型XSS 我们构建好一个urlXSS的payload,发送给受害者,受害者点击恶意链接后会在受害者的浏览器上执行恶意代码。反射型XSS是一次性的,而且比较容易被发现。通常恶意链接会被修改成短链接,或钓鱼图片的形式。 2…...
Eigen库的core模块源码阅读笔记
一、Eigen Core 模块概述 Eigen 是一个开源的C模板库,专注于线性代数运算(矩阵、向量、数值求解等)。其 Core 模块 是库的核心,定义了所有基础数据结构(如矩阵、向量、数组)和运算符重载,并实现…...
Blender安装基础使用教程
本博客记录安装Blender和基础使用,可以按如下操作来绘制标靶场景、道路标识牌等。 目录 1.安装Blender 2.创建面板资源 步骤 1: 设置 Blender 场景 步骤 2: 创建一个平面 步骤 3: 将 PDF 转换为图像 步骤 4-方法1: 添加材质并贴图 步骤4-方法2:创…...
网络相关基本概念
IP地址 描述一台主机在互联网上所处的位置。用32位整数表示。 用点分十进制表示。xxx.xxx.xxx.xxx表示。 端口号 区分当前主机上的指定的应用程序(进程)。一台主机上使用网络的程序有很多,可以通过端口号区分主机收到的数据要交给哪个程序…...
Prompt-Tuning方法
Fine-Tuning Fine-Tuning属于一种迁移学习方式,在自然语言处理(NLP)中,Fine-Tuning是用于将预训练的语言模型适应于特定任务或领域。Fine-Tuning的基本思想是采用已经在大量文本上进行训练的预训练语言模型,然后在小规模的任务特定文本上继续…...
C++ STL及Python中等效实现
1. STL 概述 STL 包含以下核心组件: 容器(Containers):存储数据的结构,如数组、链表、集合等。迭代器(Iterators):用于遍历容器的接口,类似指针。算法(Algo…...
动态规划(6)——01背包问题
欢迎来到博主的专栏:算法解析 博主ID:代码小号 文章目录 牛客网——【模板】01背包题目解析题目1算法原理题目1题解代码。问题2算法原理问题2题解代码01背包问题的滚动数组优化 牛客网——【模板】01背包 题目解析 关于I/O相关的东西博主就不多赘述了&a…...
vulkanscenegraph显示倾斜模型(5.8)-视景器编译
前言 上一章深入剖析了Vulkan渲染过程中的核心组件VkPipeline,以及vsg中针对图形渲染管线的封装GraphicsPipeline,本章将继续深入探讨视景器准备过程中的最后一章视景器编译,并进一步深入vsg中显存的传输机制,即vsg::TransferTask…...
21 天 Python 计划:MySQL索引机制从基础到应用
文章目录 一、引言二、MySQL索引机制概述2.1 MySQL索引的创建方式2.2 查询、删除、指定索引2.3 数据库索引的本质 三、MySQL的索引分类3.1 数据结构层次3.2 字段数量层次3.3 功能逻辑层次3.4 存储方式层次3.5 索引分类小结 四、MySQL其他索引的创建使用方式4.1 唯一索引的创建与…...
强化学习系统在复杂推理模型中的应用——以AReaL系统为例
目录 强化学习系统在复杂推理模型中的应用——以AReaL系统为例 1. 背景与系统设计目标 2. AReaL系统的主要技术特点 2.1 强化学习策略的引入 2.2 优化训练流程 2.3 泛化能力的提升 3. 实际应用场景 4. 总结与展望 强化学习系统在复杂推理模型中的应用——以AReaL系统为例…...
关于 微服务中服务注册与发现 的详细说明,涵盖主流框架/解决方案的对比、核心功能、配置示例及总结表格
以下是关于 微服务中服务注册与发现 的详细说明,涵盖主流框架/解决方案的对比、核心功能、配置示例及总结表格: 1. 服务注册与发现的核心概念 服务注册与发现是微服务架构的基础能力,主要解决以下问题: 服务注册:服…...
Tiny Cluster(1)——搭建树莓派小型计算集群
1 硬件说明 1.1 软硬件环境 k8s-master-0192.168.5.78Debian 12树莓派58G / 4核 / 64G TF卡 & 512G SSD控制节点k8s-worker-0192.168.5.48Debian 12树莓派4B4G / 4核 / 64G TF卡工作节点k8s-worker-1192.168.5.16Debian 11BTT-CB11G / 4核 / 64G TF卡工作节点 实现 K8s …...
【软考系统架构设计师】信息安全技术基础
1、 信息安全包括5个基本要素:机密性、完整性、可用性、可控性与可审查性。 机密性:确保信息不暴露给未授权的实体或进程。(采取加密措施) 完整性:只有得到允许的人才能修改数据,并且能够判断出数据是否已…...