ホームページ >データベース >mysql チュートリアル >SQLAlchemy の日付フィールドを使用して年齢層でユーザーを効率的にフィルタリングする方法は?

SQLAlchemy の日付フィールドを使用して年齢層でユーザーを効率的にフィルタリングする方法は?

Mary-Kate Olsen
Mary-Kate Olsenオリジナル
2024-12-24 15:28:15390ブラウズ

How to Efficiently Filter Users by Age Range Using SQLAlchemy Date Fields?

SQL データ フィールドのフィルタリング

SQL データベース内のデータを操作する場合、多くの場合、対象の情報を取得するために特定のフィールドをフィルタリングする必要があります。この場合、SQLAlchemy を使用して日付を表すフィールドをフィルタリングする方法を検討します。

次のモデルを想定します:

class User(Base):
    ...
    birthday = Column(Date, index=True)   #in database it's like '1987-01-17'
    ...

私たちの目標は、誕生日に基づいてユーザー、特に次の範囲内のユーザーをフィルタリングすることです。特定の年齢範囲 (例: 18 歳から 30 歳の間)。

元々、フィルタリングを実装しようとしました。 using:

query = DBSession.query(User).filter(
    and_(User.birthday >= '1988-01-17', User.birthday <= '1985-01-17')
)

ただし、このクエリはタイプミスのため正しくありません。適切なフィルターは次のとおりです。

qry = DBSession.query(User).filter(
    and_(User.birthday <= '1988-01-17', User.birthday >= '1985-01-17')
)

日付範囲をフィルターするもう 1 つの代替手段は between 関数です。

qry = DBSession.query(User).filter(User.birthday.between('1985-01-17', '1988-01-17'))

これらのフィルターされたクエリを利用すると、ユーザーのデータに基づいて特定のユーザー レコードを取得できます。生年月日を使用して、選択したデータに対してさらなる操作や分析を実行できるようにします。

以上がSQLAlchemy の日付フィールドを使用して年齢層でユーザーを効率的にフィルタリングする方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。