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

日付フィールドを使用して SQLAlchemy ユーザーを年齢範囲でフィルタリングする方法は?

Barbara Streisand
Barbara Streisandオリジナル
2024-12-16 05:33:13559ブラウズ

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

SQLAlchemy: 日付フィールドのフィルタリング

特定の年齢範囲内のユーザーのクエリ

以下のモデル定義があるとします:

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

目的は、18 歳から 18 歳までのユーザーなど、年齢範囲内のすべてのユーザーを取得することです。 30 歳。

正しいフィルタの実装

目的のフィルタリングを実現するには、次の SQLAlchemy クエリを使用できます:

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

説明:

  • between() 演算子は、下位と上位を指定するために使用されます。日付範囲の境界。
  • 日付値は、「YYYY-MM-DD」形式の文字列としてフォーマットされます。

代替フィルタリング方法

以外between() 演算子を使用すると、日付フィールドをフィルタリングする他の方法もあります:

# Filter by upper bound date
query = DBSession.query(User).filter(User.birthday <= '1988-01-17')
# Filter by lower bound date
query = DBSession.query(User).filter(User.birthday >= '1985-01-17')
# Filter by equality
query = DBSession.query(User).filter(User.birthday == '1987-01-17')

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

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