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!