백엔드 개발 파이썬 튜토리얼 Python을 사용하여 PostgreSQL의 새로운 기능 탐색

Python을 사용하여 PostgreSQL의 새로운 기능 탐색

Aug 25, 2024 am 06:00 AM

Exploring New Features in PostgreSQL with Python

PostgreSQL 17은 개발자, 데이터 과학자 및 데이터베이스 관리자를 위한 다양하고 흥미로운 새 기능과 향상된 기능을 제공합니다. 이 문서에서는 PostgreSQL 17의 가장 중요한 추가 사항 및 개선 사항 중 일부를 살펴보고 Python에서 이러한 기능을 사용하는 방법을 보여줍니다.

  1. 증분 정렬로 쿼리 성능 향상 PostgreSQL 17의 뛰어난 기능 중 하나는 이제 더 광범위한 사용 사례를 지원하는 증분 정렬 알고리즘의 향상입니다. 증분 정렬은 특히 정렬된 데이터를 처리할 때 대규모 데이터 세트가 포함된 쿼리를 실행하는 데 걸리는 시간을 크게 줄일 수 있습니다.

Python 예제: PostgreSQL 17을 사용한 증분 정렬

이 기능을 사용하려면 먼저 Python의 psycopg2 라이브러리를 사용하여 PostgreSQL 연결을 설정해 보겠습니다.

`psycopg2 가져오기

PostgreSQL 데이터베이스에 연결

콘 = psycopg2.connect(
호스트="localhost",
데이터베이스="test_db",
user="postgres",
비밀번호="귀하의_비밀번호"
)

커서 개체 만들기

cur = conn.cursor()

테이블 생성 및 데이터 삽입

cur.execute("""
존재하지 않는 경우 테이블 생성 Large_dataset(
ID 직렬 기본 키,
카테고리 VARCHAR(50),
INT 값
);
""")

샘플 데이터 삽입

cur.execute("""
INSERT INTO Large_dataset(범주, 값)
선택
'카테고리' || (i % 10),
무작위() * 1000
FROM generate_series(1, 1000000) i;
""")

conn.commit()

증분 정렬 사용

cur.execute("""
설명 분석
SELECT * FROM Large_dataset
카테고리별, 값별 정렬;
""")

쿼리 계획 가져오기 및 인쇄

query_plan = cur.fetchall()
query_plan의 줄:
인쇄(라인)

커서 및 연결을 닫습니다.

cur.close()
conn.close()
`

이 예에서 PostgreSQL 17의 향상된 증분 정렬은 ORDER BY 절을 효율적으로 처리하여 데이터를 증분 정렬하고 전체 쿼리 실행 시간을 줄입니다.

  1. JSON 경로 개선 PostgreSQL 17에는 JSONPath에 대한 향상된 기능이 도입되어 JSON 데이터를 더 쉽게 쿼리하고 조작할 수 있습니다. 이는 데이터 교환을 위해 JSON에 크게 의존하는 애플리케이션에 특히 유용합니다.

Python 예: JSONPath 개선 사항 사용
`## 데이터베이스에 다시 연결
conn = psycopg2.connect(
호스트="localhost",
데이터베이스="test_db",
user="postgres",
비밀번호="귀하의_비밀번호"
)
cur = conn.cursor()

JSON 데이터로 테이블 만들기

cur.execute("""
존재하지 않는 경우 테이블 생성 json_data(
ID 직렬 기본 키,
데이터 JSONB
);
""")

샘플 JSON 데이터 삽입

cur.execute("""
json_data(데이터)에 삽입
가치
('{"이름": "앨리스", "나이": 30, "기술": ["Python", "SQL"]}'),
('{"이름": "Bob", "나이": 25, "기술": ["Java", "C++"]}');
""")

conn.commit()

JSONPath를 사용하여 JSON 데이터 쿼리

cur.execute("""
데이터 선택 ->> 'name' AS 이름, 데이터 ->> '나이' AS나이
json_data에서
@ 데이터는 어디에 있나요? '$.스킬 ? (@ == "파이썬")';
""")

결과 가져오기 및 인쇄

결과 = cur.fetchall()
결과 행의 경우:
인쇄(행)

커서 및 연결을 닫습니다.

cur.close()
conn.close()
`

이 코드는 PostgreSQL 17의 향상된 JSONPath 기능이 복잡한 조건을 기반으로 JSON 필드에서 데이터 추출을 단순화하는 방법을 보여줍니다.

  1. 인덱스 생성을 위한 향상된 병렬성 향상된 병렬 처리로 인해 이제 PostgreSQL 17의 인덱스 생성이 더욱 효율적이 되어 대규모 데이터세트에서 더 빠른 인덱싱이 가능해졌습니다.

Python 예제: 병렬 인덱스 생성
`## 데이터베이스에 다시 연결
conn = psycopg2.connect(
호스트="localhost",
데이터베이스="test_db",
user="postgres",
비밀번호="귀하의_비밀번호"
)
cur = conn.cursor()

큰 테이블 만들기

cur.execute("""
존재하지 않는 경우 테이블 생성 Large_table(
ID 직렬 기본 키,
데이터 VARCHAR(255)
);
""")

많은 수의 행 삽입

cur.execute("""
INSERT INTO Large_table(데이터)
선택
md5(random()::text)
FROM generate_series(1, 5000000);
""")

conn.commit()

병렬성을 갖춘 인덱스 생성

cur.execute("""
대형_테이블(데이터)에 대해 동시에 인덱스 생성 Large_table_data_idx;
""")

conn.commit()

커서 및 연결을 닫습니다.

cur.close()
conn.close()
`

이 예에서는 여러 CPU 코어를 사용하여 인덱스를 동시에 생성하는 PostgreSQL 17의 향상된 기능을 보여줍니다. 이는 대규모 테이블 작업 시 매우 유용합니다.

  1. SQL/JSON 표준 준수 함수 PostgreSQL 17에는 더 많은 SQL/JSON 표준 호환 기능에 대한 지원이 추가되어 더 많은 SQL 표준 구문으로 JSON 데이터를 처리하는 기능이 향상되었습니다.

Python 예제: SQL/JSON 표준 함수
`## 데이터베이스에 다시 연결
conn = psycopg2.connect(
호스트="localhost",
데이터베이스="test_db",
user="postgres",
비밀번호="귀하의_비밀번호"
)
cur = conn.cursor()

JSON 데이터로 테이블 만들기

cur.execute("""
존재하지 않는 경우 테이블 생성 Employee_data(
ID 직렬 기본 키,
정보 JSONB
);
""")

샘플 JSON 데이터 삽입

cur.execute("""
직원_데이터에 삽입(정보)
가치
('{"이름": "John", "department": "매출", "급여": 5000}'),
('{"이름": "Jane", "부서": "IT", "급여": 7000}');
""")

conn.commit()

SQL/JSON 함수를 사용한 쿼리

cur.execute("""
SELECT jsonb_path_query_first(info, '$.department') AS 부서
직원_데이터에서
WHERE jsonb_path_exists(info, '$.salary ? (@ > 6000)');
""")

결과 가져오기 및 인쇄

결과 = cur.fetchall()
결과 행의 경우:
인쇄(행)

커서 및 연결을 닫습니다.

cur.close()
conn.close()
`

이 예에서는 SQL/JSON 표준 함수를 사용하여 JSON 데이터를 쿼리하는 방법을 보여주며 PostgreSQL 17이 새로운 SQL 표준을 준수함을 보여줍니다.

PostgreSQL 17 및 새로운 기능에 대한 자세한 내용은 공식 문서를 참조하세요.

위 내용은 Python을 사용하여 PostgreSQL의 새로운 기능 탐색의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

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

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

뜨거운 주제

PHP 튜토리얼
1543
276
완성 된 파이썬 블록버스터 온라인 시청 입구 Python 무료 완성 된 웹 사이트 컬렉션 완성 된 파이썬 블록버스터 온라인 시청 입구 Python 무료 완성 된 웹 사이트 컬렉션 Jul 23, 2025 pm 12:36 PM

이 기사는 여러 상위 Python "완성 된"프로젝트 웹 사이트 및 고급 "블록버스터"학습 리소스 포털을 선택했습니다. 개발 영감, 마스터 레벨 소스 코드 관찰 및 학습 또는 실제 기능을 체계적으로 개선하든, 이러한 플랫폼은 놓치지 않아야하며 파이썬 마스터로 빠르게 성장할 수 있도록 도울 수 있습니다.

파이썬 실행 쉘 명령 예제 파이썬 실행 쉘 명령 예제 Jul 26, 2025 am 07:50 AM

Subprocess.run ()을 사용하여 쉘 명령을 안전하게 실행하고 출력을 캡처하십시오. 주입 위험을 피하기 위해 목록에 매개 변수를 전달하는 것이 좋습니다. 2. 쉘 특성이 필요한 경우, shell = true를 설정할 수 있지만 명령 주입을 조심하십시오. 3. 하위 프로세스를 사용하여 실시간 출력 처리를 실현하십시오. 4. SET Check = 명령이 실패 할 때 예외를 던지기 위해 true; 5. 간단한 시나리오에서 체인을 직접 호출하여 출력을 얻을 수 있습니다. OS.System () 또는 더 이상 사용되지 않은 모듈을 사용하지 않으려면 일상 생활에서 Subprocess.run ()에 우선 순위를 부여해야합니다. 위의 방법은 파이썬에서 쉘 명령을 실행하는 핵심 사용을 무시합니다.

Python Seaborn ontorplot 예 Python Seaborn ontorplot 예 Jul 26, 2025 am 08:11 AM

Seaborn 's Loctplot을 사용하여 두 변수 간의 관계와 분포를 신속하게 시각화합니다. 2. 기본 산점도는 sns.jointPlot (data = tips, x = "total_bill", y = "tip", 종류 = "scatter")에 의해 구현됩니다. 중심은 산점도이며 히스토그램은 상단과 하단에 표시됩니다. 3. 회귀선과 밀도 정보를 친절한 = "reg"에 추가하고 marginal_kws를 결합하여 에지 플롯 스타일을 설정합니다. 4. 데이터 볼륨이 클 경우 "Hex"를 사용하는 것이 좋습니다.

Python HTTPX 비동기 클라이언트 예제 Python HTTPX 비동기 클라이언트 예제 Jul 29, 2025 am 01:08 AM

httpx.asyncclient를 사용하여 비동기 HTTP 요청을 효율적으로 시작하십시오. 1. 기본 GET 요청은 비동기를 통해 클라이언트를 관리하고 awaitclient.get를 사용하여 비 블로킹 요청을 시작합니다. 2. asyncio.gather를 결합하여 asyncio.gather를 결합하여 성능을 크게 향상시킬 수 있으며 총 시간은 가장 느린 요청과 같습니다. 3. 사용자 정의 헤더, 인증, Base_URL 및 시간 초과 설정을 지원합니다. 4. 사후 요청을 보내고 JSON 데이터를 전달할 수 있습니다. 5. 동기 비동기 코드를 혼합하지 않도록주의하십시오. 프록시 지원은 크롤러 또는 API 집계 및 기타 시나리오에 적합한 백엔드 호환성에주의를 기울여야합니다.

문자열 변환 예제에서 파이썬 목록 문자열 변환 예제에서 파이썬 목록 Jul 26, 2025 am 08:00 AM

문자열 목록은 ".join (Words)과 같은 join () 메소드와 병합 될 수 있습니다. 2. 숫자 목록은 결합하기 전에 MAP (str, 숫자) 또는 [str (x) forxinnumbers]가있는 문자열로 변환해야합니다. 3. 모든 유형 목록은 디버깅에 적합한 괄호와 따옴표가있는 문자열로 직접 변환 할 수 있습니다. 4. '|'.join (f "[{item}]"furiteminitems) 출력과 같은 join ()과 결합 된 생성기 표현식으로 사용자 정의 형식을 구현할 수 있습니다.

메모리 바운드 작업을위한 Python 최적화 메모리 바운드 작업을위한 Python 최적화 Jul 28, 2025 am 03:22 AM

pythontanbeoptimizedformemory-boundoperations는 Headgroughgenerations, 효율적 인 데이터 구조, 및 ManagingObjectLifetimes.first, usegeneratorsinsteadoflistStoprocessLargedAtasetSoneitematime, theintintomemory.second를 피하십시오

Python SQL Server PyODBC 예제에 연결됩니다 Python SQL Server PyODBC 예제에 연결됩니다 Jul 30, 2025 am 02:53 AM

PyoDBC 설치 : PipinStallPyODBC 명령을 사용하여 라이브러리를 설치하십시오. 2. SQLSERVER 연결 : PYODBC.connect () 메소드를 통해 드라이버, 서버, 데이터베이스, UID/PWD 또는 Trusted_Connection이 포함 된 연결 문자열을 사용하고 SQL 인증 또는 Windows 인증을 각각 지원합니다. 3. 설치된 드라이버를 확인하십시오 : pyodbc.drivers ()를 실행하고 'sqlserver'가 포함 된 드라이버 이름을 필터링하여 올바른 드라이버 이름이 'sqlserver 용 Odbcdriver17과 같은 올바른 드라이버 이름을 사용하는지 확인하십시오. 4. 연결 문자열의 키 매개 변수

Python shutil rmtree 예제 Python shutil rmtree 예제 Aug 01, 2025 am 05:47 AM

shutil.rmtree ()는 전체 디렉토리 트리를 재귀 적으로 삭제하는 파이썬의 함수입니다. 지정된 폴더와 모든 내용을 삭제할 수 있습니다. 1. 기본 사용법 : shutil.rmtree (Path)를 사용하여 디렉토리를 삭제하고 filenotfounderRor, AprismenterRor 및 기타 예외를 처리해야합니다. 2. 실제 응용 프로그램 : 임시 데이터 또는 캐시 디렉토리와 같은 한 번의 클릭으로 하위 디렉토리 및 파일을 포함하는 폴더를 지울 수 있습니다. 3. 참고 : 삭제 작업은 복원되지 않습니다. 경로가 존재하지 않을 때 filenotfounderror가 던져집니다. 권한이나 파일 직업으로 인해 실패 할 수 있습니다. 4. 선택적 매개 변수 : ingore_errors = true로 오류를 무시할 수 있습니다

See all articles