목차
Background
초기화 작업
개인 디자인
매핑문(모델 소개)
세션 소개
백엔드 개발 파이썬 튜토리얼 SQL 사용을 위한 매우 편리한 Python 아티팩트!

SQL 사용을 위한 매우 편리한 Python 아티팩트!

Apr 18, 2023 pm 04:19 PM
python sql

SQL 사용을 위한 매우 편리한 Python 아티팩트!

Background

사실 처음에는 pymysql을 사용했는데 유지관리가 번거롭고 코드 인젝션의 위험이 있다는 것을 알고 그냥 ORM 프레임워크를 직접 사용했습니다.

ORM은 간단히 말해서 데이터베이스 테이블과 Python 클래스 간의 매핑으로 이해하면 되는 Object Relational Mapper입니다. Python 클래스를 조작하여 간접적으로 데이터베이스를 조작할 수 있습니다.

더 유명한 Python ORM 프레임워크는 SQLAlchemy와 Peewee입니다. 여기서는 비교하지 않고 SQLAlchemy의 개인적인 용도에 대해 간단히 설명하겠습니다.

  • sqlalchemy 버전: 1.3.15
  • pymysql 버전: 0.9.3
  • mysql 버전: 5.7

초기화 작업

일반적으로 ORM 프레임워크를 사용하면 데이터베이스 연결, 기본 매핑 정의 등

MySQL을 예로 들어 데이터베이스 연결을 생성하려면 DSN 문자열만 전달하면 됩니다. Echo는 해당 SQL 문을 출력할지 여부를 나타내며 이는 디버깅에 도움이 됩니다.

from sqlalchemy import create_engine
engine = create_engine('mysql+pymysql://$user:$password@$host:$port/$db?charset=utf8mb4', echo=True)
로그인 후 복사

개인 디자인

저는 개인적으로 ORM 프레임워크를 소개할 때 내 프로젝트에서 다음 디자인에 대해 MVC 패턴을 참조하게 됩니다. 그 중 모델은 일부 데이터베이스 모델을 저장합니다. 즉, 데이터베이스 테이블에 매핑된 Python 클래스는 호출자(예: main.py)에 해당하는 작업, 즉 추가, 삭제, 확인 및 수정을 저장합니다. 데이터베이스 작업을 수행하고, model_op 레이어만 호출하면 되며, 디커플링을 달성하기 위해 모델 레이어에 신경 쓸 필요가 없습니다.

├── main.py
├── model
│ ├── __init__.py
│ ├── base_model.py
│ ├── ddl.sql
│ └── py_orm_model.py
└── model_op
├── __init__.py
└── py_orm_model_op.py
로그인 후 복사

매핑문(모델 소개)

예를 들어 이런 테스트 테이블이 있다고 해보자.

create table py_orm (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '唯一id',
`name` varchar(255) NOT NULL DEFAULT '' COMMENT '名称',
`attr` JSON NOT NULL COMMENT '属性',
`ct` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`ut` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON update CURRENT_TIMESTAMP COMMENT '更新时间',
PRIMARY KEY(`id`)
)ENGINE=InnoDB COMMENT '测试表';
로그인 후 복사

ORM 프레임워크에서 매핑 결과는 아래 Python 클래스입니다.

# py_orm_model.py
from .base_model import Base
from sqlalchemy import Column, Integer, String, TIMESTAMP, text, JSON
class PyOrmModel(Base):
__tablename__ = 'py_orm'
id = Column(Integer, autoincrement=True, primary_key=True, comment='唯一id')
name = Column(String(255), nullable=False, default='', comment='名称')
attr = Column(JSON, nullable=False, comment='属性')
ct = Column(TIMESTAMP, nullable=False, server_default=text('CURRENT_TIMESTAMP'), comment='创建时间')
ut = Column(TIMESTAMP, nullable=False, server_default=text('CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP'), comment='更新时间')
로그인 후 복사

먼저 PyOrmModel이 sqlalchemy에서 제공하는 기본 클래스인 Base 클래스를 상속하는 것을 볼 수 있습니다. 이는 우리가 선언한 Python 클래스에 대해 몇 가지 검사를 수행하고 이를 base_model에 넣습니다.

# base_model.py
# 一般base_model做的都是一些初始化的工作
from sqlalchemy import create_engine
from sqlalchemy.ext.declarative import declarative_base
Base = declarative_base()
engine = create_engine("mysql+pymysql://root:123456@127.0.0.1:33306/orm_test?charset=utf8mb4", echo=False)
로그인 후 복사

두 번째로, 각 Python 클래스에는 __tablename__ 속성이 포함되어야 합니다. 그렇지 않으면 해당 테이블을 찾을 수 없습니다.

셋째, 데이터 테이블을 생성하는 방법에는 두 가지가 있습니다. 첫 번째는 물론 Python 클래스 정의에 문제가 없으면 정상적으로 작동할 수 있습니다. 아래와 같은 ORM 프레임워크를 통해.

# main.py
# 注意这里的导入路径,Base创建表时会寻找继承它的子类,如果路径不对,则无法创建成功
from sqlachlemy_lab import Base, engine
if __name__ == '__main__':
Base.metadata.create_all(engine)
로그인 후 복사

생성 효과:

...
2020-04-04 10:12:53,974 INFO sqlalchemy.engine.base.Engine
CREATE TABLE py_orm (
id INTEGER NOT NULL AUTO_INCREMENT,
name VARCHAR(255) NOT NULL DEFAULT '' COMMENT '名称',
attr JSON NOT NULL COMMENT '属性',
ct TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
ut TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
PRIMARY KEY (id)
)
로그인 후 복사

넷째, 필드 속성에 대해:

1.primary_key 및 자동 증가는 이해하기 쉽고 MySQL의 기본 키이자 증분 속성입니다.

2. int형일 경우 길이를 지정하지 않으셔도 되지만, varchar형일 경우 길이를 지정해주셔야 합니다.

3.nullable은 MySQL의 NULL 및 NOT NULL에 해당합니다

4. default 및 server_default 정보: default는 ORM 프레임워크 수준의 기본값을 나타냅니다. 즉, 삽입 시 필드에 값이 할당되지 않은 경우 정의는 기본값은 server_default로 데이터베이스 수준의 기본값, 즉 DDL 문의 기본 키워드를 나타냅니다.

세션 소개

SQLAlchemy 문서에는 데이터베이스에 대한 추가, 삭제, 수정이 세션을 통해 수행된다고 언급되어 있습니다.

>>> from sqlalchemy.orm import sessionmaker
>>> Session = sessionmaker(bind=engine)
>>> session = Session()
>>> orm = PyOrmModel(id=1, name='test', attr={})
>>> session.add(orm)
>>> session.commit()
>>> session.close()
로그인 후 복사

위와 같이 각 작업에 대해 세션을 획득, 제출 및 해제해야 함을 알 수 있습니다. 이는 너무 중복되고 번거롭기 때문에 일반적으로 캡슐화 계층을 수행합니다.

1. 비정상적인 롤백 및 세션 종료를 처리하려면 컨텍스트 관리자를 사용하세요. 이 부분은 참조된 기사와 거의 일치합니다.

# base_model.py
from contextlib import contextmanager
from sqlalchemy.orm import sessionmaker, scoped_session
def _get_session():
"""获取session"""
return scoped_session(sessionmaker(bind=engine, expire_on_commit=False))()
# 在这里对session进行统一管理,包括获取,提交,回滚和关闭
@contextmanager
def db_session(commit=True):
session = _get_session()
try:
yield session
if commit:
session.commit()
except Exception as e:
session.rollback()
raise e
finally:
if session:
session.close()
로그인 후 복사

2. 모델과 사전 간 변환을 위해 PyOrmModel에 두 가지 메서드를 추가합니다.

class PyOrmModel(Base):
...
@staticmethod
def fields():
return ['id', 'name', 'attr']
@staticmethod
def to_json(model):
fields = PyOrmModel.fields()
json_data = {}
for field in fields:
json_data[field] = model.__getattribute__(field)
return json_data
@staticmethod
def from_json(data: dict):
fields = PyOrmModel.fields()
model = PyOrmModel()
for field in fields:
if field in data:
model.__setattr__(field, data[field])
return model
로그인 후 복사

3. 데이터베이스 작업의 캡슐화. 참조 기사와 달리 세션을 직접 호출하므로 호출자가 모델 계층에 주의를 기울일 필요가 없으며 결합도가 줄어듭니다.

# py_orm_model_op.py
from sqlachlemy_lab.model import db_session
from sqlachlemy_lab.model import PyOrmModel
class PyOrmModelOp:
def __init__(self):
pass
@staticmethod
def save_data(data: dict):
with db_session() as session:
model = PyOrmModel.from_json(data)
session.add(model)
# 查询操作,不需要commit
@staticmethod
def query_data(pid: int):
data_list = []
with db_session(commit=False) as session:
data = session.query(PyOrmModel).filter(PyOrmModel.id == pid)
for d in data:
data_list.append(PyOrmModel.to_json(d))
return data_list
로그인 후 복사

4. 발신자:

# main.py
from sqlachlemy_lab.model_op import PyOrmModelOp
if __name__ == '__main__':
PyOrmModelOp.save_data({'id': 1, 'name': 'test', 'attr': {}})
로그인 후 복사
.

위 내용은 SQL 사용을 위한 매우 편리한 Python 아티팩트!의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

<gum> : Bubble Gum Simulator Infinity- 로얄 키를 얻고 사용하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
Nordhold : Fusion System, 설명
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora : 마녀 트리의 속삭임 - Grappling Hook 잠금 해제 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
<exp exp> 모호한 : 원정 33- 완벽한 크로마 촉매를 얻는 방법
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

PHP와 Python : 다른 패러다임이 설명되었습니다 PHP와 Python : 다른 패러다임이 설명되었습니다 Apr 18, 2025 am 12:26 AM

PHP는 주로 절차 적 프로그래밍이지만 객체 지향 프로그래밍 (OOP)도 지원합니다. Python은 OOP, 기능 및 절차 프로그래밍을 포함한 다양한 패러다임을 지원합니다. PHP는 웹 개발에 적합하며 Python은 데이터 분석 및 기계 학습과 같은 다양한 응용 프로그램에 적합합니다.

PHP와 Python 중에서 선택 : 가이드 PHP와 Python 중에서 선택 : 가이드 Apr 18, 2025 am 12:24 AM

PHP는 웹 개발 및 빠른 프로토 타이핑에 적합하며 Python은 데이터 과학 및 기계 학습에 적합합니다. 1.PHP는 간단한 구문과 함께 동적 웹 개발에 사용되며 빠른 개발에 적합합니다. 2. Python은 간결한 구문을 가지고 있으며 여러 분야에 적합하며 강력한 라이브러리 생태계가 있습니다.

숭고한 코드 파이썬을 실행하는 방법 숭고한 코드 파이썬을 실행하는 방법 Apr 16, 2025 am 08:48 AM

Sublime 텍스트로 Python 코드를 실행하려면 먼저 Python 플러그인을 설치 한 다음 .py 파일을 작성하고 코드를 작성한 다음 CTRL B를 눌러 코드를 실행하면 콘솔에 출력이 표시됩니다.

PHP와 Python : 그들의 역사에 깊은 다이빙 PHP와 Python : 그들의 역사에 깊은 다이빙 Apr 18, 2025 am 12:25 AM

PHP는 1994 년에 시작되었으며 Rasmuslerdorf에 의해 개발되었습니다. 원래 웹 사이트 방문자를 추적하는 데 사용되었으며 점차 서버 측 스크립팅 언어로 진화했으며 웹 개발에 널리 사용되었습니다. Python은 1980 년대 후반 Guidovan Rossum에 의해 개발되었으며 1991 년에 처음 출시되었습니다. 코드 가독성과 단순성을 강조하며 과학 컴퓨팅, 데이터 분석 및 기타 분야에 적합합니다.

Golang vs. Python : 성능 및 확장 성 Golang vs. Python : 성능 및 확장 성 Apr 19, 2025 am 12:18 AM

Golang은 성능과 확장 성 측면에서 Python보다 낫습니다. 1) Golang의 컴파일 유형 특성과 효율적인 동시성 모델은 높은 동시성 시나리오에서 잘 수행합니다. 2) 해석 된 언어로서 파이썬은 천천히 실행되지만 Cython과 같은 도구를 통해 성능을 최적화 할 수 있습니다.

메모장으로 파이썬을 실행하는 방법 메모장으로 파이썬을 실행하는 방법 Apr 16, 2025 pm 07:33 PM

메모장에서 Python 코드를 실행하려면 Python 실행 파일 및 NPPEXEC 플러그인을 설치해야합니다. Python을 설치하고 경로를 추가 한 후 nppexec 플러그인의 명령 "Python"및 매개 변수 "{current_directory} {file_name}"을 구성하여 Notepad의 단축키 "F6"을 통해 Python 코드를 실행하십시오.

Golang vs. Python : 주요 차이점과 유사성 Golang vs. Python : 주요 차이점과 유사성 Apr 17, 2025 am 12:15 AM

Golang과 Python은 각각 고유 한 장점이 있습니다. Golang은 고성능 및 동시 프로그래밍에 적합하지만 Python은 데이터 과학 및 웹 개발에 적합합니다. Golang은 동시성 모델과 효율적인 성능으로 유명하며 Python은 간결한 구문 및 풍부한 라이브러리 생태계로 유명합니다.

Python vs. C : 학습 곡선 및 사용 편의성 Python vs. C : 학습 곡선 및 사용 편의성 Apr 19, 2025 am 12:20 AM

Python은 배우고 사용하기 쉽고 C는 더 강력하지만 복잡합니다. 1. Python Syntax는 간결하며 초보자에게 적합합니다. 동적 타이핑 및 자동 메모리 관리를 사용하면 사용하기 쉽지만 런타임 오류가 발생할 수 있습니다. 2.C는 고성능 응용 프로그램에 적합한 저수준 제어 및 고급 기능을 제공하지만 학습 임계 값이 높고 수동 메모리 및 유형 안전 관리가 필요합니다.

See all articles