「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > Django ORM で CharField を整数にキャストする方法は?

Django ORM で CharField を整数にキャストする方法は?

2024 年 11 月 10 日に公開
ブラウズ:237

How to Cast a CharField to an Integer in Django ORM?

Django ORM で Char フィールドを整数にキャストする

Django ORM でクエリを実行する場合、文字フィールドをキャストする必要があるシナリオが発生する可能性があります。整数に。これは、フィールドが CharField として保存されているが、整数値を使用して計算または比較を実行したい場合に発生する可能性があります。

CAST が使用できない理由

以前のバージョンではこのようなシナリオには、Django、生の SQL クエリ、またはデータベース関数が必要でした。ただし、Django 1.10 での Cast 関数の導入により、ORM 自体内でこのキャストを実行できるようになりました。

キャスト関数の使用

CharField を整数の場合は、次の構文を使用します:

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')

これにより、クエリセットに Student_id_int という新しいフィールドの注釈が付けられ、整数型にキャストされます。この新しいフィールドを使用して、必要に応じてフィルタリングや並べ替えを行うことができます。

Cast を使用する利点

Cast を使用すると、次のような利点があります。

  • ]タイプセーフ: 結果の値が指定された値であることを保証します。 type.
  • 生のクエリを回避します: クエリを ORM 内に保持し、メンテナンスを簡素化し、SQL インジェクションのリスクを軽減します。
  • 効率的: 実行します。データベースでの効率的なキャスティングlevel.

リファレンス

Django ORM でのキャストの詳細については、ドキュメントを参照してください:

  • [データベース関数] :キャスト](https://docs.djangoproject.com/en/stable/ref/models/database-functions/#cast)
最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3