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

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

PHPz
풀어 주다: 2023-04-28 09:58:06
앞으로
1882명이 탐색했습니다.

방법 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으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿