백엔드 개발 파이썬 튜토리얼 Python의 ORM 프레임워크인 Pony ORM에 대한 자세한 설명

Python의 ORM 프레임워크인 Pony ORM에 대한 자세한 설명

Jun 10, 2023 pm 09:30 PM
python Orm 프레임워크 pony orm

Python은 웹 개발, 과학 컴퓨팅, 데이터 처리 및 기타 분야에서 널리 사용되는 고급 프로그래밍 언어입니다. Python 개발에서 ORM(Object-Relational Mapping) 프레임워크는 관계형 데이터베이스와 객체 지향 프로그래밍 언어 사이에 일관된 브리지를 설정하고 Python 프로그래머의 개발 작업을 용이하게 할 수 있는 중요한 구성 요소입니다.

많은 Python ORM 프레임워크 중에서 Pony ORM은 Python 언어의 자연스럽고 간단한 구문을 사용하고 Python 개체를 관계형 데이터베이스에 빠르게 매핑할 수 있는 풍부한 기능을 제공하는 경량 개체 관계형 매핑 도구입니다.

  1. Installation

먼저 pip 패키지 관리 도구를 통해 설치해야 합니다.

pip install pony

  1. 빠른 시작

2.1 데이터베이스에 연결

먼저, Pony ORM은 MySQL, PostgreSQL, SQLite, Oracle, MS SQL을 포함한 다양한 관계형 데이터베이스에 연결해야 합니다. 서버 등 SQLite를 예로 들어보겠습니다.

from pony.orm import *

db = Database()

db.bind(provider='sqlite', filename='database.sqlite', create_db=True)

데이터베이스에 연결하기 전에 데이터베이스 인스턴스를 정의한 다음, 바인딩() 메서드를 통해 데이터베이스 유형과 데이터베이스 이름을 지정해야 합니다. 데이터베이스가 존재하지 않는 경우 create_db=True 옵션을 사용하여 데이터베이스를 자동으로 생성할 수 있습니다.

2.2 엔터티 클래스 정의

다음으로 Python 클래스를 정의하고 db.Entity() 데코레이터를 통해 이를 엔터티 클래스로 변환해야 합니다. 엔터티 클래스의 속성은 데이터베이스의 테이블 열에 매핑되고 엔터티 클래스의 인스턴스는 테이블의 행에 해당합니다.

class Customer(db.Entity):

name = Required(str)
age = Required(int)
address = Optional(str)
로그인 후 복사

위 코드에서는 Customer 엔터티 클래스와 이름, 나이, 주소라는 세 가지 속성을 정의합니다. 그 중 이름, 나이는 필수속성(Required)이고, 주소는 선택속성(Optional)이다.

2.3 테이블 생성

엔티티 클래스를 생성한 후 데이터베이스에 해당 테이블 구조를 생성해야 합니다. 이는 db.generate_mapping() 메서드를 통해 수행할 수 있습니다.

db.generate_mapping(create_tables=True)

위 단계를 거쳐 성공적으로 데이터베이스에 연결하고 엔터티 클래스를 정의하고 데이터베이스에 해당 테이블을 생성했습니다.

  1. 추가, 삭제, 수정 및 확인

3.1 데이터 삽입

데이터 삽입은 일반적인 작업입니다. Pony ORM을 통해 우리는 쉽게 데이터를 삽입할 수 있습니다.

with db_session:

c1 = Customer(name='Tom', age=20)
c2 = Customer(name='Jerry', age=25, address='New York')
flush()
로그인 후 복사

위 코드에서는 with db_session 키워드를 사용하여 세션을 선언한 다음 Customer 엔터티 클래스를 인스턴스화하여 두 개의 Customer 인스턴스 c1 및 c2를 생성하고 이를 변수에 할당합니다. 다음으로, 플러시() 메서드를 호출하여 인스턴스 c1 및 c2를 데이터베이스에 삽입합니다.

3.2 데이터 쿼리

데이터 쿼리는 ORM 프레임워크에서 가장 일반적으로 사용되는 기능 중 하나입니다. Pony ORM을 통해 쿼리 표현식이나 ORM 개체를 사용하여 데이터를 쿼리할 수 있습니다.

쿼리 표현식:

select(c for c in Customer if c.age > 20)

위 코드에서는 select() 함수를 사용하여 쿼리할 엔터티 클래스를 지정합니다. 여기서는 20년이 넘은 Customer 테이블의 레코드를 쿼리하도록 지정합니다. 마지막으로 쿼리 작업을 수행하기 위해 select() 함수가 포함된 db_session 컨텍스트를 사용합니다.

ORM 객체:

with db_session:

customers = Customer.select(lambda c:c.age > 20)
for c in customers:
    print(c.name, c.age, c.address)
로그인 후 복사

위 코드에서는 with db_session 키워드를 사용하여 세션을 선언하고 Customer.select()를 사용하여 20년이 넘은 Customer 테이블의 레코드를 쿼리합니다. 오래된. 쿼리 결과는 ORM 개체로 표시되며 Python 개체와 마찬가지로 해당 속성과 메서드에 액세스할 수 있습니다. 마지막으로 for 루프를 사용하여 쿼리 결과를 출력합니다.

3.3 데이터 업데이트

데이터 업데이트 작업은 매우 간단합니다. 먼저 업데이트해야 하는 레코드를 쿼리한 다음 해당 속성 값을 수정하고 마지막으로 플러시() 메서드를 호출하여 수정된 데이터를 저장하면 됩니다. .

with db_session:

customer = Customer.get(name='Tom')
customer.address = 'Beijing'
flush()
로그인 후 복사

위 코드에서는 Customer.get() 문을 사용하여 Tom이라는 고객 레코드를 쿼리한 다음 해당 주소를 베이징으로 수정합니다. 마지막으로, 플러시() 메소드를 호출하여 업데이트된 데이터를 데이터베이스에 저장합니다.

3.4 데이터 삭제

데이터 삭제도 매우 간단합니다. 먼저 삭제해야 하는 레코드를 쿼리한 다음 해당 레코드의 delete() 메서드를 호출하기만 하면 됩니다.

with db_session:

customer = Customer.get(name='Tom')
customer.delete()
로그인 후 복사

위 코드에서는 Customer.get() 문을 사용하여 Tom이라는 고객 레코드를 쿼리한 다음 해당 delete() 메서드를 호출하여 데이터베이스에서 레코드를 삭제합니다.

  1. 요약

Pony ORM은 지속성을 위해 Python 개체를 관계형 데이터베이스에 빠르게 매핑할 수 있는 간단하고 사용하기 쉽고 기능이 풍부한 Python ORM 프레임워크입니다. 포니 ORM을 사용하려면 먼저 데이터베이스에 연결한 후 엔터티 클래스를 정의하고 테이블을 생성한 다음 마지막으로 쿼리 표현식이나 ORM 객체를 통해 추가, 삭제, 수정, 쿼리 등의 작업을 구현해야 합니다. 초보자에게 Pony ORM은 학습 비용이 저렴하고 빠르게 시작할 수 있는 매우 친숙한 ORM 프레임워크입니다.

위 내용은 Python의 ORM 프레임워크인 Pony ORM에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 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 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

C 언어 합계의 기능은 무엇입니까? C 언어 합계의 기능은 무엇입니까? Apr 03, 2025 pm 02:21 PM

C 언어에는 내장 합계 기능이 없으므로 직접 작성해야합니다. 합계는 배열 및 축적 요소를 가로 질러 달성 할 수 있습니다. 루프 버전 : 루프 및 배열 길이를 사용하여 계산됩니다. 포인터 버전 : 포인터를 사용하여 배열 요소를 가리키며 효율적인 합계는 자체 증가 포인터를 통해 달성됩니다. 동적으로 배열 버전을 할당 : 배열을 동적으로 할당하고 메모리를 직접 관리하여 메모리 누출을 방지하기 위해 할당 된 메모리가 해제되도록합니다.

휴대 전화에서 XML을 PDF로 변환하는 방법은 무엇입니까? 휴대 전화에서 XML을 PDF로 변환하는 방법은 무엇입니까? Apr 02, 2025 pm 10:18 PM

휴대 전화에서 XML을 PDF로 직접 변환하는 것은 쉽지 않지만 클라우드 서비스를 통해 달성 할 수 있습니다. 가벼운 모바일 앱을 사용하여 XML 파일을 업로드하고 생성 된 PDF를 수신하고 클라우드 API로 변환하는 것이 좋습니다. Cloud API는 Serverless Computing Services를 사용하고 올바른 플랫폼을 선택하는 것이 중요합니다. XML 구문 분석 및 PDF 생성을 처리 할 때 복잡성, 오류 처리, 보안 및 최적화 전략을 고려해야합니다. 전체 프로세스에는 프론트 엔드 앱과 백엔드 API가 함께 작동해야하며 다양한 기술에 대한 이해가 필요합니다.

XML을 그림으로 변환하는 방법 XML을 그림으로 변환하는 방법 Apr 03, 2025 am 07:39 AM

XSLT 변환기 또는 이미지 라이브러리를 사용하여 XML을 이미지로 변환 할 수 있습니다. XSLT 변환기 : XSLT 프로세서 및 스타일 시트를 사용하여 XML을 이미지로 변환합니다. 이미지 라이브러리 : Pil 또는 Imagemagick와 같은 라이브러리를 사용하여 XML 데이터에서 이미지를 그리기 및 텍스트 그리기와 같은 이미지를 만듭니다.

누가 더 많은 파이썬이나 자바 스크립트를 지불합니까? 누가 더 많은 파이썬이나 자바 스크립트를 지불합니까? Apr 04, 2025 am 12:09 AM

기술 및 산업 요구에 따라 Python 및 JavaScript 개발자에 대한 절대 급여는 없습니다. 1. 파이썬은 데이터 과학 및 기계 학습에서 더 많은 비용을 지불 할 수 있습니다. 2. JavaScript는 프론트 엔드 및 풀 스택 개발에 큰 수요가 있으며 급여도 상당합니다. 3. 영향 요인에는 경험, 지리적 위치, 회사 규모 및 특정 기술이 포함됩니다.

XML을 MP3로 변환하는 방법 XML을 MP3로 변환하는 방법 Apr 03, 2025 am 09:00 AM

XML을 MP3로 변환하는 단계에는 다음이 포함됩니다. XML에서 오디오 데이터 추출 : XML 파일을 구문 분석하고, 오디오 데이터가 포함 된 Base64 인코딩 문자열을 찾아 이진 형식으로 디코딩하십시오. 오디오 데이터를 MP3로 인코딩합니다. MP3 인코더를 설치하고 인코딩 매개 변수를 설정하고 이진 오디오 데이터를 MP3 형식으로 인코딩 한 다음 파일에 저장하십시오.

XML 형식을 변경하는 방법 XML 형식을 변경하는 방법 Apr 03, 2025 am 08:42 AM

XML 형식을 수정하는 방법에는 여러 가지가 있습니다. Notepad와 같은 텍스트 편집기로 수동으로 편집; XMLBeautifier와 같은 온라인 또는 데스크탑 XML 서식 도구와 자동 포맷; XSLT와 같은 XML 변환 도구를 사용하여 변환 규칙을 정의합니다. 또는 Python과 같은 프로그래밍 언어를 사용하여 구문 분석하고 작동합니다. 원본 파일을 수정하고 백업 할 때주의하십시오.

별개의 구별이 관련되어 있습니까? 별개의 구별이 관련되어 있습니까? Apr 03, 2025 pm 10:30 PM

구별되고 구별되는 것은 구별과 관련이 있지만, 다르게 사용됩니다. 뚜렷한 (형용사)는 사물 자체의 독창성을 묘사하고 사물 사이의 차이를 강조하는 데 사용됩니다. 뚜렷한 (동사)는 구별 행동이나 능력을 나타내며 차별 과정을 설명하는 데 사용됩니다. 프로그래밍에서 구별은 종종 중복 제거 작업과 같은 컬렉션에서 요소의 독창성을 나타내는 데 사용됩니다. 홀수 및 짝수 숫자를 구별하는 것과 같은 알고리즘이나 함수의 설계에 별개가 반영됩니다. 최적화 할 때 별도의 작업은 적절한 알고리즘 및 데이터 구조를 선택해야하며, 고유 한 작업은 논리 효율성의 구별을 최적화하고 명확하고 읽을 수있는 코드 작성에주의를 기울여야합니다.

XML에서 데이터를 수정하는 방법 XML에서 데이터를 수정하는 방법 Apr 03, 2025 am 08:12 AM

XML 데이터 수정은 수동으로 수행하거나 프로그래밍 언어 및 라이브러리를 사용하여 수행 할 수 있습니다. 수동 수정은 요소 및 속성 추가, 수정 또는 삭제를 포함하여 작은 문서에 대한 소량의 수정에 적합합니다. 보다 복잡한 수정, Python 's XML.Dom 및 Java's Javax.xml.parsers와 같은 프로그래밍 언어 및 라이브러리를 위해 XML 데이터를 처리하는 도구를 제공합니다. XML 데이터를 수정할 때 유효성을 확인하고 백업을 생성하며 올바른 태그 및 속성을 포함하여 XML 구문 규칙을 따르십시오.

See all articles