mirror of
https://git.mirrors.martin98.com/https://github.com/infiniflow/ragflow.git
synced 2025-07-31 20:41:58 +08:00

### What problem does this PR solve? 1. Add delete_by_ids method 2. Add get_doc_ids_by_doc_names 3. Improve user_canvan_version's logic (avoid O(n) db IO) 4. Improve document delete logic (avoid O(n) db IO) ### Type of change - [x] Performance Improvement
47 lines
1.5 KiB
Python
47 lines
1.5 KiB
Python
from api.db.db_models import UserCanvasVersion, DB
|
|
from api.db.services.common_service import CommonService
|
|
from peewee import DoesNotExist
|
|
|
|
class UserCanvasVersionService(CommonService):
|
|
model = UserCanvasVersion
|
|
|
|
|
|
@classmethod
|
|
@DB.connection_context()
|
|
def list_by_canvas_id(cls, user_canvas_id):
|
|
try:
|
|
user_canvas_version = cls.model.select(
|
|
*[cls.model.id,
|
|
cls.model.create_time,
|
|
cls.model.title,
|
|
cls.model.create_date,
|
|
cls.model.update_date,
|
|
cls.model.user_canvas_id,
|
|
cls.model.update_time]
|
|
).where(cls.model.user_canvas_id == user_canvas_id)
|
|
return user_canvas_version
|
|
except DoesNotExist:
|
|
return None
|
|
except Exception:
|
|
return None
|
|
|
|
@classmethod
|
|
@DB.connection_context()
|
|
def delete_all_versions(cls, user_canvas_id):
|
|
try:
|
|
user_canvas_version = cls.model.select().where(cls.model.user_canvas_id == user_canvas_id).order_by(cls.model.create_time.desc())
|
|
if user_canvas_version.count() > 20:
|
|
delete_ids = []
|
|
for i in range(20, user_canvas_version.count()):
|
|
delete_ids.append(user_canvas_version[i].id)
|
|
|
|
cls.delete_by_ids(delete_ids)
|
|
return True
|
|
except DoesNotExist:
|
|
return None
|
|
except Exception:
|
|
return None
|
|
|
|
|
|
|