Django ORM で Char フィールドを整数にキャストする
Django ORM でクエリを実行する場合、文字フィールドをキャストする必要があるシナリオが発生する場合があります。整数に。これは、フィールドが CharField として保存されているが、整数値を使用して計算または比較を実行したい場合に発生する可能性があります。
CAST が使用できない理由
以前のバージョンではこのようなシナリオには、Django、生の SQL クエリ、またはデータベース関数が必要でした。ただし、Django 1.10 での Cast 関数の導入により、ORM 自体内でこのキャストを実行できるようになりました。
Cast 関数の使用
CharField を整数の場合は、次の構文を使用します。
<code class="python">from django.db.models import Cast, IntegerField students.objects.annotate( student_id_int=Cast('student_id', IntegerField()) ).filter(student_id_int__contains=97318).order_by('-student_id_int')</code>
これにより、クエリセットに Student_id_int という新しいフィールドの注釈が付けられ、整数型にキャストされます。その後、この新しいフィールドを使用して、必要に応じてフィルタリングや並べ替えを行うことができます。
Cast を使用する利点
Cast を使用すると、次のような利点があります。
参照
Django ORM でのキャストの詳細については、ドキュメントを参照してください:
以上がDjango ORM で CharField を整数にキャストする方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。