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
Lepaskan: 2024-12-16 05:33:13
asal
558 orang telah melayarinya

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
    ...
Salin selepas log masuk

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')
)
Salin selepas log masuk

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')
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan