python 에서 SQLAlchemy 정렬 의 구 덩이 를 분석 합 니 다.

머리말
SQLAlchemy 는 Python 프로 그래 밍 언어 아래 의 ORM 프레임 워 크 입 니 다.이 프레임 워 크 는 데이터베이스 API 위 에 구축 되 어 관계 대상 맵 을 사용 하여 데이터 베 이 스 를 조작 합 니 다.즉,대상 을 SQL 로 변환 한 다음 데이터 API 를 사용 하여 SQL 을 실행 하고 실행 결 과 를 얻 습 니 다.최근 SQLAlchemy 정렬 을 사용 하 다가 구 덩이 를 만 났 습 니 다.그래서 정 리 를 해서 더 많은 친구 들 에 게 공유 하고 싶 습 니 다.다음은 함께 보 겠 습 니 다.
구덩이 의 코드

query = db_session.query(UserVideo.vid,
         UserVideo.uid,
         UserVideo.v_width,
         UserVideo.v_height,
         UserVideo.create_time,
         UserVideo.cover,
         UserVideo.source_url,
         UserVideo.v_type,
         UserVideo.category,
         User.username,
         User.sex,
         UserExtraInfo.avatar,
         UserExtraInfo.watermark)
  query = query.filter(UserVideo.status == 1,
        User.uid == UserVideo.uid,
        UserExtraInfo.uid == UserVideo.uid) 
  query = query.filter(UserVideo.status == 1)
  query = query.order_by(-UserVideo.vid)
  query = query.limit(20).all()
부호

query = db_session.query(UserVideo.vid,
         UserVideo.uid,
         UserVideo.v_width,
         UserVideo.v_height,
         UserVideo.create_time,
         UserVideo.cover,
         UserVideo.source_url,
         UserVideo.v_type,
         UserVideo.category,
         User.username,
         User.sex,
         UserExtraInfo.avatar,
         UserExtraInfo.watermark)
  query = query.filter(UserVideo.status == 1,
        User.uid == UserVideo.uid,
        UserExtraInfo.uid == UserVideo.uid) # .order_by(UserVideo.vid.desc()).limit(20).all()
  query = query.filter(UserVideo.status == 1)
  query = query.order_by(UserVideo.vid.desc())
  query = query.limit(20).all()
그래,네가 잘못 본 게 아니 야.바로 그 평행봉 이 야.속 도 를 늦 춰.함수 속도 10 배 증가
다음은 sqlalchemy 고성능 랜 덤 으로 몇 개의 데 이 터 를 추출 합 니 다.

query = db_session.query(UserVideo.vid,
          UserVideo.uid,
          UserVideo.v_width,
          UserVideo.v_height,
          UserVideo.create_time,
          UserVideo.cover,
          UserVideo.source_url,
          UserVideo.v_type,
          UserVideo.category,
          User.username,
          User.sex,
          UserExtraInfo.avatar,
          UserExtraInfo.watermark)
   query = query.filter(UserVideo.status == 1, User.uid == UserVideo.uid, UserExtraInfo.uid == UserVideo.uid)
rvid = db_session.query(func.round(random.random() * func.max(UserVideo.vid)).label('rvid')).subquery()
query = query.filter(UserVideo.category == category)
query_tail = query
query_tail = query_tail.join(rvid, UserVideo.vid > rvid.c.rvid).limit(20).all()
총결산
이상 은 이 글 의 전체 내용 입 니 다.본 논문 의 내용 이 여러분 의 학습 이나 업무 에 어느 정도 도움 이 되 기 를 바 랍 니 다.궁금 한 점 이 있 으 시 면 댓 글 을 남 겨 주 셔 서 저희 에 대한 지지 에 감 사 드 립 니 다.

좋은 웹페이지 즐겨찾기