sqlalchemy查询json

第一种:字段op是json格式:

复制代码
{
        "uid": "cxb123456789",
        "role": 2,
        "op_start_time": 1743513707504,
        "op_end_time": 1743513707504,
        "op_start_id": "op_001",
        "op_end_id": "op_002",
        "op": {
          "ability_node": [{"id": "2c6adc22-e05a-4fe9-835f-ba5d7f8b303", "name": "连接数限制"}],
          "skill_node": [{"id": "cvlp6o324te32pj24teg", "name": "yyyy"}],
          "knowledge_node": [{"id": "cvlp6o324te32pj24teg", "name": "端到端加密"}],
          "op_id": "9131c441-4304-4101-b064-362352d26789",
          "op_name": "Initial Data Import",
          "pre_op": "",
          "next_op": "op_002",
          "dep_relationship": "",
          "op_result": 1,
          "op_score": 95.5,
          "op_count": 1
        }
      }

要求:查询op的json字段里面的op_id为传入的op_id

复制代码
from sqlalchemy.future import select

db_query = select(KnowledgeAiReport)
op_id = report.op.op_id
db_query = db_query.filter(KnowledgeAiReport.uid == report.uid).filter(KnowledgeAiReport.op.op('->>')('op_id') == op_id)
item = await db_session.execute(db_query)
report_db = item.scalars().first()

第二种:person_type也是json字段,

要求:存储的值是 ["1","2"],要求传入 "1"能查出对应的数据

实现代码:

复制代码
from sqlalchemy.dialects.postgresql import JSONB  # 使用JSONB,因为它支持全文搜索
from sqlalchemy import cast
from sqlalchemy.future import select


db_query = select(TbResident)
db_query = db_query.filter(cast(TbResident.illness_type, JSONB).op('@>')([f'{illness_type}']))
db_query = db_query.offset(page_no * page_size).limit(page_size).order_by(TbResident.created_at.desc())
    item = await db_session.execute(db_query)
    residents = item.scalars().all()
相关推荐
cooldream20095 分钟前
深度解析中秋节HTML5动画的实现
前端·html·html5
半旧夜夏24 分钟前
【设计模式】核心设计模式实战
java·spring boot·设计模式
半旧夜夏1 小时前
【Spring】AOP的核心原理配方
java·spring
qiuiuiu4131 小时前
CPrimer Plus第十六章C预处理器和C库总结2-qsort函数
java·c语言·算法
IT学长编程2 小时前
计算机毕设选题 基于SpringBoot的书店管理系统的设计与实现 网上书店系统 前后端分离 Java毕设项目 毕业设计选题 【附源码+文档报告+安装调试】
java·spring boot·毕业设计·课程设计·前后端分离·网上书店系统·书店管理系统
张较瘦_2 小时前
应用型本科计算机类专业毕业设计与论文选题指南
java·开发语言·课程设计
IT学长编程2 小时前
计算机毕设选题 基于SpringBoot的房产租赁管理系统 房屋租赁系统 前后端分离 Java毕设项目 毕业设计选题 【附源码+文档报告+安装调试】
java·spring boot·毕业设计·课程设计·房屋租赁系统·房产租赁系统·文档报告
jump_jump2 小时前
超长定时器 long-timeout
前端·javascript·node.js
Mintopia3 小时前
架构进阶 🏗 从 CRUD 升级到“大工程师视野”
前端·javascript·全栈