1.分析前端保存商品发布信息的json数据
1.分析commoditylaunch.vue的submitSkus
1.将后面的都注销,只保留查看数据的部分
data:image/s3,"s3://crabby-images/ff550/ff5506878540602b53bdf5718eb600cc87b2f9ef" alt="image-20240423095755248"
2.填写基本信息
data:image/s3,"s3://crabby-images/035d1/035d137ac3c2ab83cc9e938501f3e4834f591f71" alt="image-20240423095919741"
data:image/s3,"s3://crabby-images/99f51/99f51b3ec1eb61fcfce535a3e939395a6ae40dbf" alt="image-20240423095953088"
data:image/s3,"s3://crabby-images/360db/360db1ac78e1a49c11fbd1977a9c9b8bba133bf0" alt="image-20240423100005414"
data:image/s3,"s3://crabby-images/66726/66726e9fc284261932752f79dc93b9202ed5ac1f" alt="image-20240423100013921"
3.保存信息,得到json
data:image/s3,"s3://crabby-images/0ae17/0ae17f85bf9138880e63f10c22400e0eb11b6eb9" alt="image-20240423100045156"
4.使用工具格式化一下
data:image/s3,"s3://crabby-images/4d9b5/4d9b5e004a36ef73d53718063125d8147a67c899" alt="image-20240423100406121"
2.使用工具将json转为model
data:image/s3,"s3://crabby-images/69a95/69a95cb5c40793465106dcf3d385a1e640d8a587" alt="image-20240423105118842"
3.根据业务修改vo,放到vo包下
data:image/s3,"s3://crabby-images/8cae6/8cae6a0cfac1cbd3c87dc24d8afeecf1da099a15" alt="image-20240423110715861"
2.保存spu基本信息
1.创建表commodity_spu_info
1.用这个表来存储json的前六条信息
data:image/s3,"s3://crabby-images/bd4ca/bd4cadeeb5581523655f3458bf6b909d99d72dd9" alt="image-20240423112229157"
2.sql
use sunliving_commodity;
CREATE TABLE commodity_spu_info
(
id BIGINT NOT NULL AUTO_INCREMENT COMMENT '商品 id',
spu_name VARCHAR(200) COMMENT '商品名称',
spu_description VARCHAR(1000) COMMENT '商品描述',
catalog_id BIGINT COMMENT '所属分类 id',
brand_id BIGINT COMMENT '品牌 id',
weight DECIMAL(18,4),
publish_status TINYINT COMMENT '上架状态[0 - 下架,1 - 上架]',
create_time DATETIME,
update_time DATETIME,
PRIMARY KEY (id)
)CHARSET=utf8mb4 COMMENT='商品 spu 信息';
SELECT * FROM commodity_spu_info
2.生成基本的CRUD
1.启动项目,访问localhost:81,点击生成
data:image/s3,"s3://crabby-images/075ae/075ae256f5e4299c232a97e900ae2f864be870db" alt="image-20240423112537477"
2.将生成的main目录覆盖sunliving-commodity的main目录
data:image/s3,"s3://crabby-images/036e2/036e2310a99562f86a90c967ccca2fb068e468da" alt="image-20240423112806104"
3.注释掉SpuInfoController.java中跟shiro相关的
data:image/s3,"s3://crabby-images/1c66b/1c66be2fb1071655992ab963760ffe3a5fde9ef9" alt="image-20240423113012171"
4.重启测试接口
1.访问 http://localhost:5050/api/sunliving-commodity/commodity/spuinfo/list
data:image/s3,"s3://crabby-images/dc2f9/dc2f905d206aa5264e95eda9cb04dfb4e3c95216" alt="image-20240423113337244"
2.注意,如果提示VO不识别之类的就先刷新maven然后build一下即可
3.完成基本信息的保存
1.后端 sunliving-commodity模块
1.SpuInfoService.java 接受SpuSaveVO,保存到数据库
public interface SpuInfoService extends IService<SpuInfoEntity> {
PageUtils queryPage(Map<String, Object> params);
public void saveSpuInfo(SpuSaveVO spuSaveVO);
}
2.SpuInfoServiceImpl.java 实现方法
@Override
public void saveSpuInfo(SpuSaveVO spuSaveVO) {
SpuInfoEntity spuInfoEntity = new SpuInfoEntity();
BeanUtils.copyProperties(spuSaveVO, spuInfoEntity);
spuInfoEntity.setCreateTime(new Date());
spuInfoEntity.setUpdateTime(new Date());
this.save(spuInfoEntity);
}
3.SpuInfoController.java 编写保存信息的接口
@RequestMapping("/save")
public R save(@RequestBody SpuSaveVO spuSaveVO) {
spuInfoService.saveSpuInfo(spuSaveVO);
return R.ok();
}
4.前端 commoditylaunch.vue的submitSkus方法
1.修改url为环境变量+资源路径的方式
data:image/s3,"s3://crabby-images/ce43b/ce43be9e46caccb2cbc0d8c6c81bed291c219557" alt="image-20240423134925019"
2.解掉下面的注释
data:image/s3,"s3://crabby-images/d275a/d275a40034300deca46be48df6e119b449c81d3f" alt="image-20240423134945642"
5.前后端联调
1.前端输入信息
data:image/s3,"s3://crabby-images/502a3/502a32e4b32f203c7ecb2cdbdac4ca57c80256f3" alt="image-20240423135116668"
2.后端查看数据库
data:image/s3,"s3://crabby-images/937e7/937e727c91497b1fe8e1fb74ba8b41987a50c78c" alt="image-20240423135140107"
3.保存spu图片描述url
1.数据库表设计
use sunliving_commodity;
CREATE TABLE commodity_spu_info_desc
(
spu_id BIGINT NOT NULL COMMENT '商品 id',
decript LONGTEXT COMMENT '商品介绍图片',
PRIMARY KEY (spu_id)
) CHARSET = utf8mb4 COMMENT ='商品 spu 信息介绍';
select * from commodity_spu_info_desc;
2.生成基本CRUD
1.将生成的main目录覆盖sunliving-commodity的main目录
data:image/s3,"s3://crabby-images/43dd8/43dd8e0f7ed9071a866f272c67c2baf3900872e1" alt="image-20240423141530797"
2.注释掉SpuInfoDescController.java的与shiro有关的部分
3.重启测试
data:image/s3,"s3://crabby-images/08661/086611c8e90d8b0cecfa466ac4f0d4a6663b2367" alt="image-20240423141844270"
3.完成保存spu的图片描述url
1.后端 sunliving-commodity模块
1.将SpuInfoDescEntity.java的id修改为不是自增的
data:image/s3,"s3://crabby-images/69550/695503014fe153bdcb8d3987e9177c27fc7c5cfd" alt="image-20240423152006569"
2.修改SpuInfoServiceImpl.java的saveSpuInfo方法即可,注意需要添加@Transactional进行事务管理
@Transactional
@Override
public void saveSpuInfo(SpuSaveVO spuSaveVO) {
SpuInfoEntity spuInfoEntity = new SpuInfoEntity();
BeanUtils.copyProperties(spuSaveVO, spuInfoEntity);
spuInfoEntity.setCreateTime(new Date());
spuInfoEntity.setUpdateTime(new Date());
List<String> decript = spuSaveVO.getDecript();
SpuInfoDescEntity spuInfoDescEntity = new SpuInfoDescEntity();
if (decript != null && !decript.isEmpty()) {
spuInfoDescEntity.setDecript(String.join(",", decript));
} else {
spuInfoDescEntity.setDecript("暂无描述");
}
spuInfoDescEntity.setSpuId(spuInfoEntity.getId());
spuInfoDescService.save(spuInfoDescEntity);
this.save(spuInfoEntity);
}
3.前后端联调
1.前端保存信息
2.后端在保存图片描述url的时候发现是空,原因是在将spuInfoEntity的id保存到db之前的确是空的,更改一下执行顺序即可
data:image/s3,"s3://crabby-images/7b7c9/7b7c9f40f94bebac1d7c87e3cd2b171777eb8cb7" alt="image-20240423153604583"
3.将spuInfoEntity的保存提前
data:image/s3,"s3://crabby-images/7d774/7d774535492b0e426e21a71ca7a9efb157dd41aa" alt="image-20240423153819500"
4.再次测试,成功保存信息
data:image/s3,"s3://crabby-images/50630/50630cd55ddb925193f500cb2cdff337c2514f29" alt="image-20240423154059819"
4.保存SPU图片集信息
1.数据库表设计
use sunliving_commodity;
CREATE TABLE commodity_spu_images
(
id BIGINT NOT NULL AUTO_INCREMENT COMMENT 'id',
spu_id BIGINT COMMENT 'spu_id',
img_name VARCHAR(200) COMMENT '图片名',
img_url VARCHAR(255) COMMENT '图片地址',
img_sort INT COMMENT '顺序',
default_img TINYINT COMMENT '是否默认图',
PRIMARY KEY (id)
) CHARSET = utf8mb4 COMMENT ='spu 图片集';
SELECT *
FROM commodity_spu_images;
2.生成基本CRUD(不再赘述)
data:image/s3,"s3://crabby-images/63bea/63bea0131824d7c856d60836799997cba7d97d2b" alt="image-20240423155424779"
3.完成保存图片集信息
1.后端 sunliving-commodity 模块
1.修改SpuInfoServiceImpl.java的saveSpuInfo即可
@Transactional
@Override
public void saveSpuInfo(SpuSaveVO spuSaveVO) {
SpuInfoEntity spuInfoEntity = new SpuInfoEntity();
BeanUtils.copyProperties(spuSaveVO, spuInfoEntity);
spuInfoEntity.setCreateTime(new Date());
spuInfoEntity.setUpdateTime(new Date());
List<String> decript = spuSaveVO.getDecript();
SpuInfoDescEntity spuInfoDescEntity = new SpuInfoDescEntity();
if (decript != null && !decript.isEmpty()) {
spuInfoDescEntity.setDecript(String.join(",", decript));
} else {
spuInfoDescEntity.setDecript("暂无描述");
}
this.save(spuInfoEntity);
spuInfoDescEntity.setSpuId(spuInfoEntity.getId());
spuInfoDescService.save(spuInfoDescEntity);
List<String> images = spuSaveVO.getImages();
if (images == null || images.isEmpty()) {
SpuImagesEntity spuImagesEntity = new SpuImagesEntity();
spuImagesEntity.setSpuId(spuInfoEntity.getId());
spuImagesEntity.setDefaultImg(0);
spuImagesEntity.setImgUrl("暂无图片");
spuImagesEntity.setImgSort(0);
spuImagesService.save(spuImagesEntity);
} else {
List<SpuImagesEntity> collect = images.stream().map(img -> {
SpuImagesEntity spuImagesEntity = new SpuImagesEntity();
spuImagesEntity.setSpuId(spuInfoEntity.getId());
spuImagesEntity.setDefaultImg(0);
spuImagesEntity.setImgUrl(img);
spuImagesEntity.setImgSort(0);
return spuImagesEntity;
}).collect(Collectors.toList());
spuImagesService.saveBatch(collect);
}
}
2.前后端联调
1.前端保存信息
2.后端查看数据库
data:image/s3,"s3://crabby-images/c564f/c564ff1b83cd2e2c46133aeafe4a032e04f694a1" alt="image-20240423163624417"
5.保存SPU的基本属性
1.数据库表创建
use sunliving_commodity;
CREATE TABLE commodity_product_attr_value
(
id BIGINT NOT NULL AUTO_INCREMENT COMMENT 'id',
spu_id BIGINT COMMENT '商品 id',
attr_id BIGINT COMMENT '属性 id',
attr_name VARCHAR(200) COMMENT '属性名',
attr_value VARCHAR(200) COMMENT '属性值',
attr_sort INT COMMENT '顺序',
quick_show TINYINT COMMENT '快速展示【是否展示在介绍上;0-否 1-是】',
PRIMARY KEY (id)
) CHARSET = utf8mb4 COMMENT ='spu 基本属性值';
select * from commodity_product_attr_value;
2.生成基本CRUD(不再赘述)
data:image/s3,"s3://crabby-images/e2bae/e2baeb169c70c590eca1c2614797576794c56839" alt="image-20240423171620380"
3.保存SPU的基本属性
1.后端 sunliving-commodity模块
1.ProductAttrValueService.java 新增方法,批量保存
void saveProductAttrValue(List<ProductAttrValueEntity> productAttrValueEntities);
2.ProductAttrValueServiceImpl.java 实现方法
@Override
public void saveProductAttrValue(List<ProductAttrValueEntity> productAttrValueEntities) {
this.saveBatch(productAttrValueEntities);
}
3.修改SpuInfoServiceImpl.java 的saveSpuInfo方法,新增代码
List<BaseAttrs> baseAttrs = spuSaveVO.getBaseAttrs();
List<ProductAttrValueEntity> collect = baseAttrs.stream().map(
baseAttr -> {
ProductAttrValueEntity productAttrValueEntity = new ProductAttrValueEntity();
productAttrValueEntity.setSpuId(spuInfoEntity.getId());
productAttrValueEntity.setAttrId(baseAttr.getAttrId());
productAttrValueEntity.setQuickShow(baseAttr.getShowDesc());
productAttrValueEntity.setAttrSort(0);
productAttrValueEntity.setAttrValue(baseAttr.getAttrValues());
productAttrValueEntity.setAttrName(attrService.getById(baseAttr.getAttrId()).getAttrName());
return productAttrValueEntity;
}
).collect(Collectors.toList());
productAttrValueService.saveProductAttrValue(collect);
2.前后端联调
1.前端保存基本属性
2.后端查看数据库
data:image/s3,"s3://crabby-images/f3b92/f3b923833e8da0f4da736849b1e3c1f6d5a4aa47" alt="image-20240423192720404"
6.保存SKU的基本信息
1.数据库表设计
use sunliving_commodity;
CREATE TABLE commodity_sku_info
(
sku_id BIGINT NOT NULL AUTO_INCREMENT COMMENT 'skuId',
spu_id BIGINT COMMENT 'spuId',
sku_name VARCHAR(255) COMMENT 'sku 名称',
sku_desc VARCHAR(2000) COMMENT 'sku 介绍描述',
catalog_id BIGINT COMMENT '所属分类 id',
brand_id BIGINT COMMENT '品牌 id',
sku_default_img VARCHAR(255) COMMENT '默认图片',
sku_title VARCHAR(255) COMMENT '标题',
sku_subtitle VARCHAR(2000) COMMENT '副标题',
price DECIMAL(18, 4) COMMENT '价格',
sale_count BIGINT COMMENT '销量',
PRIMARY KEY (sku_id)
) CHARSET = utf8mb4 COMMENT ='sku 信息';
SELECT *
FROM commodity_sku_info;
2.生成基本CRUD(不再赘述)
3.保存SKU基本信息 sunliving-commodity模块
1.SkuInfoService.java 新增批量添加的方法
void saveBatch(List<SkuInfoEntity> skuInfoEntities);
2.SkuInfoServiceImpl.java 实现方法
@Override
public void saveBatch(List<SkuInfoEntity> skuInfoEntities) {
this.saveBatch(skuInfoEntities);
}
3.SpuInfoServiceImpl.java 修改saveSpuInfo方法,新增代码
List<Skus> skus = spuSaveVO.getSkus();
List<SkuInfoEntity> skusCollect = skus.stream().map(sku -> {
SkuInfoEntity skuInfoEntity = new SkuInfoEntity();
skuInfoEntity.setBrandId(spuInfoEntity.getBrandId());
skuInfoEntity.setSkuDesc("");
skuInfoEntity.setSkuName(sku.getSkuName());
skuInfoEntity.setPrice(sku.getPrice());
skuInfoEntity.setSpuId(spuInfoEntity.getId());
List<Images> skuImages = sku.getImages();
for (Images image : skuImages) {
if (image.getDefaultImg() == 1) {
skuInfoEntity.setSkuDefaultImg(image.getImgUrl());
}
else {
skuInfoEntity.setSkuDefaultImg("暂无默认图片");
}
}
skuInfoEntity.setSkuSubtitle(sku.getSkuSubtitle());
skuInfoEntity.setSkuTitle(sku.getSkuTitle());
skuInfoEntity.setCatalogId(spuInfoEntity.getCatalogId());
skuInfoEntity.setSaleCount(0L);
return skuInfoEntity;
}).collect(Collectors.toList());
skuInfoService.saveSkuInfoEntitys(skusCollect);
4.前后端联调
1.后端报错,java.lang.StackOverflowError
data:image/s3,"s3://crabby-images/e7092/e70922dac17a70f3ea80bbd2540df2897573f337" alt="image-20240424152315435"
2.问题分析
- 这里只报了这一个StackOverflowError,没有任何其他的提示信息
- 栈溢出,只可能是无限递归,debug查看数据没问题,在调用saveBatch报错
- 检查一下saveBatch发现,我自定义的名字跟IService接口的saveBatch相同,这样就相当于重写了IService接口中的方法,然后不断递归,所以出现了栈溢出
- 解决方式:修改一下自定义方法的名字即可
data:image/s3,"s3://crabby-images/169d9/169d9884e4e6241e1c4e8dd50451fa56a51f8450" alt="image-20240424153407345"
3.问题解决
1.修改自定义方法的名字
data:image/s3,"s3://crabby-images/f9eb8/f9eb817b87fd854f3d420ea423081481a3ba7246" alt="image-20240424153745459"
2.修改SpuInfoServiceImpl.java调用的方法
data:image/s3,"s3://crabby-images/00eda/00eda8123a4b3eb30f45dabbfdf26b00f8894e55" alt="image-20240424153844730"
3.重启测试,保存成功!
data:image/s3,"s3://crabby-images/1531d/1531d5b4a1a3b7dea91d4852b65ddabf2cb02a17" alt="image-20240424154050572"
data:image/s3,"s3://crabby-images/ffeb2/ffeb2d5591d7b97a0523603116a2b8853c87eccd" alt="image-20240424154217814"
7.保存SPU和SKU图片信息
1.数据库表创建
use sunliving_commodity;
CREATE TABLE commodity_sku_images
(
id BIGINT NOT NULL AUTO_INCREMENT COMMENT 'id',
sku_id BIGINT COMMENT 'sku_id',
img_url VARCHAR(255) COMMENT '图片地址',
img_sort INT COMMENT '排序',
default_img INT COMMENT '默认图[0 - 不是默认图,1 - 是默认图]',
PRIMARY KEY (id)
) CHARSET = utf8mb4 COMMENT ='sku 图片';
SELECT *
FROM commodity_sku_images
2.生成基本CRUD(不再赘述)
data:image/s3,"s3://crabby-images/660f2/660f2ea854307a0a6633bd849bf86211fe9a79f8" alt="image-20240424165537977"
3.完成保存SPU和SKU图片信息 sunliving-commodity模块
1.SkuImagesService.java 新增方法,批量保存sku图片
void saveSkuImages(List<SkuImagesEntity> skuImagesEntity);
2.SkuImagesServiceImpl.java 实现方法
@Override
public void saveSkuImages(List<SkuImagesEntity> skuImagesEntity) {
this.saveBatch(skuImagesEntity);
}
3.修改 SpuInfoServiceImpl.java,修改代码
List<Skus> skus = spuSaveVO.getSkus();
skus.forEach(sku -> {
SkuInfoEntity skuInfoEntity = new SkuInfoEntity();
skuInfoEntity.setBrandId(spuInfoEntity.getBrandId());
skuInfoEntity.setSkuDesc("");
skuInfoEntity.setSkuName(sku.getSkuName());
skuInfoEntity.setPrice(sku.getPrice());
skuInfoEntity.setSpuId(spuInfoEntity.getId());
List<Images> skuImages = sku.getImages();
for (Images image : skuImages) {
if (image.getDefaultImg() == 1) {
skuInfoEntity.setSkuDefaultImg(image.getImgUrl());
}
else {
skuInfoEntity.setSkuDefaultImg("暂无默认图片");
}
}
skuInfoEntity.setSkuSubtitle(sku.getSkuSubtitle());
skuInfoEntity.setSkuTitle(sku.getSkuTitle());
skuInfoEntity.setCatalogId(spuInfoEntity.getCatalogId());
skuInfoEntity.setSaleCount(0L);
skuInfoService.save(skuInfoEntity);
List<SkuImagesEntity> skuImagesEntities = skuImages.stream().map(image -> {
SkuImagesEntity skuImagesEntity = new SkuImagesEntity();
skuImagesEntity.setSkuId(skuInfoEntity.getSkuId());
skuImagesEntity.setDefaultImg(image.getDefaultImg());
skuImagesEntity.setImgUrl(image.getImgUrl());
skuImagesEntity.setImgSort(0);
return skuImagesEntity;
}).collect(Collectors.toList());
skuImagesService.saveSkuImages(skuImagesEntities);
});
4.前后端联调
1.前端保存信息
2.后端测试,发现commodity_sku_images表插入了两条空的字段
data:image/s3,"s3://crabby-images/7284f/7284f615bdf3a348ecae0115ab32d1f53dc37967" alt="image-20240424200701966"
3.debug分析
1.第一个sku有两张图片,第二个sku没有图片,在遍历第二个sku时发现,即使第二个没有图片,前端会传一个url为空的数组,包含两个元素
data:image/s3,"s3://crabby-images/8bf6e/8bf6e5a605eaebdc420a5bff95b68cd77bb5ff67" alt="image-20240424195959111"
2.在保存sku图片信息的时候,就会将这个图片的信息保存到数据库中
data:image/s3,"s3://crabby-images/f8e8e/f8e8eb15dd44ac97e37054eb3cf257efc677a956" alt="image-20240424200456325"
3.解决方式:在保存sku图片信息时加一个过滤即可,把url为空的过滤掉
data:image/s3,"s3://crabby-images/b3301/b3301717d6c85b7669f00b55ef6ac8333ca2ffe2" alt="image-20240424200616141"
4.重启测试,再添加一次,没有空值了
data:image/s3,"s3://crabby-images/38c2f/38c2fa100b8c984619c50056d4bf80d1162739ff" alt="image-20240424201542051"
8.保存SKU销售属性
1.数据库表设计
use sunliving_commodity;
CREATE TABLE commodity_sku_sale_attr_value
(
id BIGINT NOT NULL AUTO_INCREMENT COMMENT 'id',
sku_id BIGINT COMMENT 'sku_id',
attr_id BIGINT COMMENT 'attr_id',
attr_name VARCHAR(200) COMMENT '销售属性名',
attr_value VARCHAR(200) COMMENT '销售属性值',
attr_sort INT COMMENT '顺序',
PRIMARY KEY (id)
) CHARSET = utf8mb4 COMMENT ='sku 的销售属性/值表';
SELECT *
FROM commodity_sku_sale_attr_value;
2.生成基本CRUD(不再赘述)
data:image/s3,"s3://crabby-images/42488/4248806383b0ef17565b2f5a0e04f915ffd820cb" alt="image-20240425092806248"
3.完成保存SKU销售属性 sunliving-commodity模块
1.SkuSaleAttrValueService.java 新增方法批量保存sku销售属性
void saveSkuSaleAttrValues(List<SkuSaleAttrValueEntity> skuSaleAttrValueEntities);
2.SkuSaleAttrValueServiceImpl.java 实现方法
@Override
public void saveSkuSaleAttrValues(List<SkuSaleAttrValueEntity> skuSaleAttrValueEntities) {
this.saveBatch(skuSaleAttrValueEntities);
}
3.SpuInfoServiceImpl.java 新增代码保存sku的销售属性信息
List<Attr> attr = sku.getAttr();
List<SkuSaleAttrValueEntity> skuSaleAttrValueEntities = attr.stream().map(a -> {
SkuSaleAttrValueEntity skuSaleAttrValueEntity = new SkuSaleAttrValueEntity();
BeanUtils.copyProperties(a, skuSaleAttrValueEntity);
skuSaleAttrValueEntity.setSkuId(skuInfoEntity.getSkuId());
skuSaleAttrValueEntity.setAttrSort(0);
return skuSaleAttrValueEntity;
}).collect(Collectors.toList());
skuSaleAttrValueService.saveSkuSaleAttrValues(skuSaleAttrValueEntities);
4.重启测试
data:image/s3,"s3://crabby-images/67e87/67e8726fb69957b3d2a0943d80b704fb8e7047f3" alt="image-20240425094745439"
9.将vo转化为entity的总结
1.整体的 SpuSaveVO预览
data:image/s3,"s3://crabby-images/7ce7d/7ce7df06d1287de937bb576fee416091f25e26e0" alt="image-20240425095813804"
2.转换结构
3.转换规则
- 首先,一定是在Controller层,接收到一个完整的VO
- 将这个VO的基本属性,转换为一个主entity
- 将每个特殊属性再单独转为一个entity,需要与主entity的id关联,当然也可以关联其他属性
4.List类型的特殊属性细节说明
- 关于List类型的特殊属性,有两种选择,一种是将里面的内容,比如是String类型的图片url放到一个entity中使用逗号间隔,第二种是将每一个String都放到一个entity中,都是可以的
5.关于List里面还有多个特殊属性的处理
1.查看这里的 List
data:image/s3,"s3://crabby-images/923d2/923d2ec1562394f5959de6df7fbfad740bf273f9" alt="image-20240425100758080"
2.分析
- 可以看到一个SpuSaveVO中不仅有List类型的Skus,而且每个Skus中还有List类型的Attr
- 虽然看上去复杂,不过确实也复杂。
- 但是,关于List类型的属性,只需要记住一点,遍历出每一个元素,将其转化为entity,这个entity至少需要与上一层的entity的id关联