Django での複数の一時テーブルとのインターフェイス
同様のスキーマを共有しているが、名前が動的に割り当てられている一時テーブルを含む MySQL データベースを操作する場合、これらのテーブルと Django の間のインターフェイスを確立する必要があります。この記事では、単一の Django モデルを利用して、動的な名前を持つ複数のテーブルからデータを取得する実現可能性を検討します。
動的モデル ファクトリの作成
ベースのモデル クラスを動的に生成するにはデータベーステーブル名に基づいて、ファクトリ関数を作成できます。ファクトリ関数「getModel」は、テーブル名を引数として受け取り、動的な「db_table」属性を持つモデル クラスを返します。例:
def getModel(db_table): class MyClass(models.Model): # Define model fields here class Meta: db_table = db_table return MyClass
動的クラス名のメタクラス アプローチ
Django の 'Meta' クラス属性は、通常、特定のモデル クラスのすべてのインスタンス化にわたる共有インスタンスです。ただし、カスタム メタクラスを定義すると、実行時にクラス名を変更できます。これにより、動的テーブル名ごとに新しいクラスを作成できるようになります。
class MyClassMetaclass(models.base.ModelBase): def __new__(cls, name, bases, attrs): name = db_table return models.base.ModelBase.__new__(cls, name, bases, attrs) class MyClass(models.Model): __metaclass__ = MyClassMetaclass class Meta: db_table = db_table
「db_table」属性の動的変更
また、モデル クラスが定義された後でも、「db_table」属性を動的に変更できます。
MyModel._meta.db_table = '10293847_table'
これらの手法を利用すると、Django を使用して複数の一時テーブルとインターフェイスし、動的に名前が付けられたテーブルからデータを取得できるようになります。
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3