kg_prop_service.py 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. import traceback
  2. from sqlalchemy.orm import Session
  3. from typing import List
  4. from model.kg_prop import KGProp
  5. from db.session import get_db
  6. import logging
  7. from sqlalchemy.exc import IntegrityError
  8. logger = logging.getLogger(__name__)
  9. class KGPropService:
  10. def __init__(self, db: Session):
  11. self.db = db
  12. def get_props_by_ref_id(self, ref_id: int, prop_names: List[str] = None) -> List[dict]:
  13. try:
  14. query = self.db.query(KGProp).filter(KGProp.ref_id == ref_id)
  15. if prop_names:
  16. #prop_names是一个列表,需要使用in_方法进行查询
  17. query = query.filter(KGProp.prop_name.in_(prop_names))
  18. props = query.all()
  19. return [{
  20. 'id': p.id,
  21. 'category': p.category,
  22. 'prop_name': p.prop_name,
  23. 'prop_value': p.prop_value,
  24. 'prop_title': p.prop_title,
  25. 'type': p.type
  26. } for p in props]
  27. except Exception as e:
  28. logger.error(f"根据ref_id查询属性失败: {str(e)}")
  29. raise ValueError("查询失败")
  30. def get_prop_by_ref_id(self, ref_id: int, prop_name: str = None) -> List[dict]:
  31. try:
  32. query = self.db.query(KGProp).filter(KGProp.ref_id == ref_id)
  33. if prop_name:
  34. query = query.filter(KGProp.prop_name == prop_name)
  35. props = query.first()
  36. if not props:
  37. return None
  38. return {
  39. 'id': props.id,
  40. 'category': props.category,
  41. 'prop_name': props.prop_name,
  42. 'prop_value': props.prop_value,
  43. 'prop_title': props.prop_title,
  44. 'type': props.type
  45. }
  46. except Exception as e:
  47. traceback.print_exc()
  48. logger.error(f"根据id查询属性失败: {str(e)}")
  49. raise ValueError("查询失败")
  50. def create_prop(self, prop_data: dict) -> KGProp:
  51. try:
  52. new_prop = KGProp(**prop_data)
  53. self.db.add(new_prop)
  54. self.db.commit()
  55. return new_prop
  56. except IntegrityError as e:
  57. self.db.rollback()
  58. logger.error(f"创建属性失败: {str(e)}")
  59. raise ValueError("数据库完整性错误")
  60. def update_prop(self, prop_id: int, update_data: dict) -> KGProp:
  61. prop = self.db.query(KGProp).get(prop_id)
  62. if not prop:
  63. raise ValueError("属性未找到")
  64. try:
  65. for key, value in update_data.items():
  66. setattr(prop, key, value)
  67. self.db.commit()
  68. return prop
  69. except Exception as e:
  70. self.db.rollback()
  71. logger.error(f"更新属性失败: {str(e)}")
  72. raise ValueError("更新失败")
  73. def delete_prop(self, prop_id: int) -> None:
  74. prop = self.db.query(KGProp).get(prop_id)
  75. if not prop:
  76. raise ValueError("属性未找到")
  77. try:
  78. self.db.delete(prop)
  79. self.db.commit()
  80. return None
  81. except Exception as e:
  82. self.db.rollback()
  83. logger.error(f"删除属性失败: {str(e)}")
  84. raise ValueError("删除失败")