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 サイトの他の関連記事を参照してください。