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
Lepaskan: 2024-12-24 15:28:15
asal
376 orang telah melayarinya

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

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

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

Alternatif lain untuk menapis julat tarikh ialah fungsi antara:

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

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!

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