> 백엔드 개발 > 파이썬 튜토리얼 > js의 sqlalchemy 예제에 대한 자세한 설명

js의 sqlalchemy 예제에 대한 자세한 설명

零下一度
풀어 주다: 2017-07-20 20:17:35
원래의
2038명이 탐색했습니다.

SQLalchemy에는 두 가지 반환 유형이 있습니다. 하나는 Model 개체이고 다른 하나는 쿼리 컬렉션(일부 필드만 쿼리)입니다.

이 두 가지 반환 결과는 모두 동일한 sqlalchemy.orm.query.Query 유형에서 나온 것입니다.

그래서 Query에 대해 해당 처리를 수행하고 dict

class AlchemyJsonEncoder(json.JSONEncoder):
    def default(self, obj):
        # 判断是否是Query
        if isinstance(obj, Query):
            # 定义一个字典数组
            fields = []
            # 定义一个字典对象
            record = {}
            # 检索结果集的行记录
            for rec in obj.all():
                # 检索记录中的成员
                for field in [x for x in dir(rec) if
                              # 过滤属性
                              not x.startswith('_')
                              # 过滤掉方法属性
                              and hasattr(rec.__getattribute__(x), '__call__') == False
                              # 过滤掉不需要的属性
                              and x != 'metadata']:
                    data = rec.__getattribute__(field)
                    try:
                        record[field] = data
                    except TypeError:
                        record[field] = None
                fields.append(record)
            # 返回字典数组
            return fields
        # 其他类型的数据按照默认的方式序列化成JSON
        return json.JSONEncoder.default(self, obj)
로그인 후 복사

 

이렇게 하면 됩니다. 매번 직렬화할 때

json.dumps(result1, cls=AlchemyJsonEncoder)
로그인 후 복사

를 사용하여 결과 집합의 json 직렬화를 달성할 수 있습니다.

위 내용은 js의 sqlalchemy 예제에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿