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

Bagaimana untuk Menapis Pengguna mengikut Julat Umur dengan Cekap Menggunakan Medan Tarikh SQLAlchemy?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-12-24 15:28:15521semak imbas

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

Menapis Medan Data SQL

Apabila bekerja dengan data dalam pangkalan data SQL, selalunya perlu menapis medan tertentu untuk mendapatkan maklumat yang disasarkan. Dalam kes ini, kami meneroka cara menapis medan yang mewakili tarikh menggunakan SQLAlchemy.

Memandangkan model berikut:

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

Matlamat kami adalah untuk menapis pengguna berdasarkan hari lahir mereka, khususnya yang berada dalam julat umur tertentu, cth., antara 18 dan 30 tahun.

Pada asalnya, anda cuba melaksanakan penapisan menggunakan:

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

Walau bagaimanapun, pertanyaan ini tidak betul kerana kesilapan menaip. Penapis yang betul hendaklah:

qry = DBSession.query(User).filter(
    and_(User.birthday <= '1988-01-17', User.birthday >= '1985-01-17')
)

Alternatif lain untuk menapis julat tarikh ialah fungsi antara:

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

Dengan menggunakan pertanyaan yang ditapis ini, anda boleh mendapatkan semula rekod pengguna tertentu berdasarkan mereka tarikh lahir, membolehkan anda melakukan operasi atau analisis selanjutnya pada data yang dipilih.

Atas ialah kandungan terperinci Bagaimana untuk Menapis Pengguna mengikut Julat Umur dengan Cekap Menggunakan Medan Tarikh SQLAlchemy?. 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