Go의 `database/sql`이 직접 PostgreSQL 쿼리보다 훨씬 느린 이유는 무엇입니까?
데이터베이스/sql 쿼리와 직접 데이터베이스 쿼리 간의 쿼리 실행 시간 불일치
Go 애플리케이션에서는 상당한 시간 차이가 관찰됩니다. psql을 통해 PostgreSQL 데이터베이스를 직접 쿼리하는 경우와 데이터베이스/sql 패키지를 사용하는 경우를 비교합니다. 동일한 쿼리를 실행하는 동안 Database/sql은 약 24ms가 걸리는 반면 psql은 단 1ms 만에 쿼리를 처리한다는 것을 알 수 있습니다.
차이점 이해:
The 불일치는 두 가지 주요 요인에 기인할 수 있습니다:
1. 데이터베이스 연결 생성 및 관리:
- psql: psql을 사용하여 직접 쿼리를 실행하면 열려 있는 상태로 유지되는 데이터베이스에 대한 단일 활성 연결이 설정됩니다. 세션 기간 동안.
- database/sql: 이와 대조적으로, Database/sql은 연결 풀은 데이터베이스에 대한 여러 연결을 관리합니다. 처음에는 풀에 활성 연결이 없습니다. 데이터베이스/SQL을 사용하여 쿼리를 실행하면 풀에서 새로운 연결을 설정합니다.
2. 준비된 명령문 실행:
- psql: psql을 통해 쿼리를 실행하는 경우 일반적으로 매개변수가 없는 "간단한 쿼리"입니다.
- database/sql: 기본적으로 Database/sql은 준비된 문을 사용합니다. 쿼리에 매개변수가 없지만 쿼리에서 $1을 사용하면 데이터베이스/sql이 준비된 문을 생성하고 실행합니다.
쿼리 성능 최적화:
시간 차이를 최소화하려면 다음 최적화를 고려하세요.
1. 연결 풀 초기화:
- 데이터베이스/SQL 연결을 초기화한 후 즉시 db.Ping() 메서드를 사용하여 풀에 하나 이상의 연결이 열려 있는지 확인하세요. 이렇게 하면 초기 연결 설정의 지연 시간이 줄어듭니다.
2. 연결 해제:
- db.Query를 사용하여 쿼리를 실행한 후 행.Close() 메서드를 호출하여 연결을 풀로 다시 해제합니다. 그렇지 않으면 연결이 열린 상태로 유지되어 잠재적인 리소스 유출이 발생할 수 있습니다.
3. 가능한 경우 간단한 쿼리를 사용하세요.
- 쿼리에 매개변수화가 필요하지 않은 경우 db.Query에서 직접 문자열로 지정하세요. 이렇게 하면 준비된 문을 생성하고 실행하는 오버헤드가 방지됩니다.
이러한 최적화를 구현하면 데이터베이스/SQL을 사용하는 쿼리 실행 시간을 대폭 줄이고 직접 데이터베이스 쿼리 성능에 더 가까워질 수 있습니다.
위 내용은 Go의 `database/sql`이 직접 PostgreSQL 쿼리보다 훨씬 느린 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











보안 통신에 널리 사용되는 오픈 소스 라이브러리로서 OpenSSL은 암호화 알고리즘, 키 및 인증서 관리 기능을 제공합니다. 그러나 역사적 버전에는 알려진 보안 취약점이 있으며 그 중 일부는 매우 유해합니다. 이 기사는 데비안 시스템의 OpenSSL에 대한 일반적인 취약점 및 응답 측정에 중점을 둘 것입니다. DebianopensSL 알려진 취약점 : OpenSSL은 다음과 같은 몇 가지 심각한 취약점을 경험했습니다. 심장 출혈 취약성 (CVE-2014-0160) :이 취약점은 OpenSSL 1.0.1 ~ 1.0.1F 및 1.0.2 ~ 1.0.2 베타 버전에 영향을 미칩니다. 공격자는이 취약점을 사용하여 암호화 키 등을 포함하여 서버에서 무단 읽기 민감한 정보를 사용할 수 있습니다.

Go Language의 부동 소수점 번호 작동에 사용되는 라이브러리는 정확도를 보장하는 방법을 소개합니다.

Go Crawler Colly의 대기열 스레딩 문제는 Colly Crawler 라이브러리를 GO 언어로 사용하는 문제를 탐구합니다. � ...

백엔드 학습 경로 : 프론트 엔드에서 백엔드 초보자로서 프론트 엔드에서 백엔드까지의 탐사 여행은 프론트 엔드 개발에서 변화하는 백엔드 초보자로서 이미 Nodejs의 기초를 가지고 있습니다.

Go Language의 문자열 인쇄의 차이 : println 및 String () 함수 사용 효과의 차이가 진행 중입니다 ...

Beegoorm 프레임 워크에서 모델과 관련된 데이터베이스를 지정하는 방법은 무엇입니까? 많은 Beego 프로젝트에서는 여러 데이터베이스를 동시에 작동해야합니다. Beego를 사용할 때 ...

Go Language에서 메시지 대기열을 구현하기 위해 Redisstream을 사용하는 문제는 Go Language와 Redis를 사용하는 것입니다 ...

골란드의 사용자 정의 구조 레이블이 표시되지 않으면 어떻게해야합니까? Go Language 개발을 위해 Goland를 사용할 때 많은 개발자가 사용자 정의 구조 태그를 만날 것입니다 ...
