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

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

DDD
DDDasal
2024-12-27 18:54:13745semak imbas

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

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!

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