>  기사  >  백엔드 개발  >  Python sqlalchemy에서 테이블 이름을 동적으로 수정하는 구현 방법은 무엇입니까?

Python sqlalchemy에서 테이블 이름을 동적으로 수정하는 구현 방법은 무엇입니까?

PHPz
PHPz앞으로
2023-04-28 09:58:061790검색

방법 1

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

이것은 ORM 프레임워크 자체가 각 데이터 모델 클래스에 해당하는 Table 객체를 자동으로 생성하고 이를 클래스의 __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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제