Rumah >pangkalan data >tutorial mysql >Bagaimana Menapis Pengguna SQLAlchemy mengikut Julat Umur Menggunakan Medan Tarikh?

Bagaimana Menapis Pengguna SQLAlchemy mengikut Julat Umur Menggunakan Medan Tarikh?

Barbara Streisand
Barbara Streisandasal
2024-12-16 05:33:13562semak imbas

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

SQLAlchemy: Penapisan Medan Tarikh

Menyiasat Pengguna Dalam Julat Umur Tertentu

Memandangkan definisi model di bawah:

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

Objektifnya adalah untuk mendapatkan semula semua pengguna dalam lingkungan umur, seperti mereka yang berumur antara 18 dan 30 tahun.

Pelaksanaan Penapis yang Betul

Untuk mencapai penapisan yang diingini, pertanyaan SQLAlchemy berikut boleh digunakan:

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

Penjelasan:

  • Pengendali antara() digunakan untuk menentukan sempadan bawah dan atas daripada julat tarikh.
  • Nilai tarikh diformatkan sebagai rentetan dalam format 'YYYY-MM-DD'.

Kaedah Penapisan Alternatif

Selain daripada menggunakan operator antara(), terdapat kaedah lain untuk menapis medan tarikh:

# 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')

Atas ialah kandungan terperinci Bagaimana Menapis Pengguna SQLAlchemy mengikut Julat Umur Menggunakan Medan Tarikh?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn