Python의 SQLAlchemy ORM에서는 다음 코드를 사용하여 데이터 모델 클래스의 테이블 이름을 동적으로 변경할 수 있습니다.
from sqlalchemy.ext.declarative import declarative_base Base = declarative_base() class MyModel(Base): __tablename__ = 'my_custom_table_name' id = Column(Integer, primary_key=True) name = Column(String) age = Column(Integer) #... 其它定义或使用... # 动态修改表名 MyModel.__table__.name = 'my_new_table_name'
이 예에서는 먼저 MyModel
data라는 파일을 정의합니다. 모델을 만들어 my_custom_table_name
테이블과 연결합니다. 그런 다음 필요한 경우 모델 클래스의 __table__
속성에 액세스하여 테이블 이름을 동적으로 변경할 수 있습니다. MyModel
的数据模型,并将其与my_custom_table_name
表相关联。然后,在必要时,我们可以通过访问模型类的__table__
属性来动态地更改表名。
这是因为ORM框架本身会自动为每个数据模型类创建一个对应的Table对象,并将其存储在该类的__table__
属性中。我们可以使用name
__table__
속성에 저장하기 때문입니다. name
속성을 사용하면 이 개체의 이름을 직접 업데이트하여 테이블 이름을 동적으로 변경할 수 있습니다. 동적으로 변경되는 테이블 이름은 애플리케이션의 정확성과 유지 관리 가능성에 영향을 미칠 수 있습니다. 따라서 실제로 이 작업을 수행해야 하는지 여부와 데이터베이스 스키마 변경을 계획하는 방법을 고려하십시오. 방법 2원래 클래스가 다음과 같다면:from sqlalchemy.ext.declarative import declarative_base Base = declarative_base() class MyModel(Base): __tablename__ = 'my_custom_table_name' id = Column(Integer, primary_key=True) name = Column(String) age = Column(Integer)추상 클래스를 정의할 수 있습니다:
class MyModelCls(Base): __abstract__ = True # 关键语句,定义所有数据库表对应的父类 __table_args__ = {"extend_existing": True} # 允许表已存在 id = Column(Integer, primary_key=True) name = Column(String) age = Column(Integer)그런 다음 함수를 통해 클래스 객체를 반환합니다🎜
def get_source_data_model_cls(cid, cid_class_dict={}): if cid not in cid_class_dict: cls_name = table_name = cid cls = type(cls_name, (MyModelCls, ), {'__tablename__': table_name}) cid_class_dict[cid] = cls return cid_class_dict[cid]
위 내용은 Python sqlalchemy에서 테이블 이름을 동적으로 수정하는 구현 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!