SQLAlchemy: Menapis Medan Tarikh
Dalam senario di mana model Pengguna mentakrifkan medan 'hari jadi' sebagai jenis data Tarikh, timbulkan perlu menapis pengguna berdasarkan julat umur. Untuk mencapai ini dengan SQLAlchemy, pada mulanya seseorang mungkin mempertimbangkan dan mencuba:
query = DBSession.query(User).filter( and_(User.birthday >= '1988-01-17', User.birthday <= '1985-01-17') )
Walau bagaimanapun, percubaan ini tidak mencapai ketepatan. Penapis yang diperbetulkan ialah:
qry = DBSession.query(User).filter( and_(User.birthday <= '1988-01-17', User.birthday >= '1985-01-17') )
atau yang setara:
qry = DBSession.query(User).filter(User.birthday <= '1988-01-17').\ filter(User.birthday >= '1985-01-17')
Sebagai alternatif, operator antara boleh digunakan untuk tujuan yang sama:
qry = DBSession.query(User).filter(User.birthday.between('1985-01-17', '1988-01-17'))
Pendekatan ini pastikan rekod dalam julat tarikh yang ditentukan dipilih dengan tepat.
Atas ialah kandungan terperinci Bagaimana untuk Menapis Pengguna dengan Betul mengikut Julat Umur Menggunakan Medan Tarikh SQLAlchemy?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!