Home > Database > Mysql Tutorial > How to Filter SQLAlchemy Users by Age Range Using Date Fields?

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

Barbara Streisand
Release: 2024-12-16 05:33:13
Original
621 people have browsed it

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

SQLAlchemy: Filtration of Date Fields

Querying Users Within a Specific Age Range

Given the model definition below:

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

The objective is to retrieve all users within an age range, such as those between 18 and 30 years old.

Correct Filter Implementation

To achieve the desired filtering, the following SQLAlchemy query can be employed:

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

Explanation:

  • The between() operator is used to specify the lower and upper bounds of the date range.
  • The date values are formatted as strings in the format 'YYYY-MM-DD'.

Alternative Filtering Methods

Aside from using the between() operator, there are other methods for filtering date fields:

# 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')
Copy after login

The above is the detailed content of How to Filter SQLAlchemy Users by Age Range Using Date Fields?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template