版本变更V3.35将图像的处理统一更换到新表当中
This commit is contained in:
@ -561,13 +561,20 @@ class MaterialBaseService:
|
||||
db.session.add(new_material)
|
||||
db.session.flush() # 获取 new_material.id
|
||||
|
||||
# 提取产品图向量到独立表(失败不影响业务)
|
||||
# 先提交主事务,图片向量异步后台提取
|
||||
db.session.commit()
|
||||
|
||||
image_list = data.get('generalImage', [])
|
||||
if isinstance(image_list, list) and image_list:
|
||||
ImageEmbeddingService.save_embeddings(
|
||||
ImageEmbeddingService.MODULE_MATERIAL_BASE, new_material.id, image_list
|
||||
from flask import current_app
|
||||
from app.utils.executor import run_embedding_task
|
||||
run_embedding_task(
|
||||
ImageEmbeddingService.save_embeddings_background,
|
||||
current_app._get_current_object(),
|
||||
ImageEmbeddingService.MODULE_MATERIAL_BASE,
|
||||
new_material.id,
|
||||
image_list
|
||||
)
|
||||
db.session.commit()
|
||||
return new_material
|
||||
|
||||
except Exception as e:
|
||||
@ -597,10 +604,17 @@ class MaterialBaseService:
|
||||
if 'generalImage' in data:
|
||||
new_photo_list = data['generalImage']
|
||||
material.product_image = json.dumps(new_photo_list)
|
||||
# 保存向量到独立表(全量替换)
|
||||
ImageEmbeddingService.save_embeddings(
|
||||
ImageEmbeddingService.MODULE_MATERIAL_BASE, material.id, new_photo_list
|
||||
)
|
||||
# 立即触发异步向量提取,不阻塞主事务提交
|
||||
if isinstance(new_photo_list, list) and new_photo_list:
|
||||
from flask import current_app
|
||||
from app.utils.executor import run_embedding_task
|
||||
run_embedding_task(
|
||||
ImageEmbeddingService.save_embeddings_background,
|
||||
current_app._get_current_object(),
|
||||
ImageEmbeddingService.MODULE_MATERIAL_BASE,
|
||||
material.id,
|
||||
new_photo_list
|
||||
)
|
||||
else:
|
||||
material.product_image = None
|
||||
ImageEmbeddingService.delete_embeddings(
|
||||
|
||||
Reference in New Issue
Block a user