database/sql을 사용하여 쿼리하는 것이 데이터베이스를 직접 쿼리하는 것보다 훨씬 느립니다.
동일한 쿼리를 사용하더라도 실행 간에 눈에 띄는 성능 차이가 있습니다. Postgres의 psql 유틸리티를 사용하고 Go 애플리케이션에서 데이터베이스/sql 패키지를 사용하여 직접 쿼리합니다. psql에서는 밀리초가 걸리는 쿼리가 Go에서는 수십 밀리초가 걸리는 이러한 불일치는 구현의 특정 요인에 기인할 수 있습니다.
데이터베이스/sql 연결 이해
Database/sql은 단일 연결을 생성하는 대신 데이터베이스에 대한 연결을 설정하기 위해 연결 풀을 초기화합니다. 데이터베이스/sql에서 쿼리 실행의 초기 지연은 풀이 열려 있는 연결이 없는 상태에서 시작되기 때문입니다. 첫 번째 쿼리는 SQL 문을 실행하기 전에 서버에 대한 연결을 설정해야 합니다.
첫 번째 쿼리의 연결이 풀로 다시 해제되지 않았기 때문에 후속 쿼리도 지연이 발생합니다. 즉, 각 후속 쿼리는 쿼리를 실행하기 전에 새 연결을 생성해야 합니다.
풀로 다시 연결 해제
성능 불일치를 해결하려면 연결이 각 쿼리 후에 풀로 다시 해제됩니다. 연결을 해제하려면 db.Query의 기본 반환 값을 유지한 후 해당 값에 대해 Close 메서드를 호출해야 합니다.
열린 연결로 풀 초기화
초기 지연, 초기화 직후 연결 풀에서 Ping을 호출합니다. 이렇게 하면 풀에 하나 이상의 연결이 사용 가능하게 됩니다.
준비된 명령문
인수 없는 단순 쿼리는 예상대로 실행되지만 데이터베이스/sql에서는 인수가 있는 쿼리가 실행됩니다. 실제로 내부적으로 준비된 명령문을 만들고 실행합니다. 준비된 문은 서로 다른 인수를 사용하여 동일한 쿼리를 여러 번 실행할 때 성능상의 이점을 제공합니다.
추가 지연 문제 해결
연결 관리 및 준비된 문 외에도 추가 지연 요인이 있을 수 있습니다. 고려해야 할 사항:
- 네트워크 지연 시간: 데이터 전송으로 인한 지연 애플리케이션과 데이터베이스 간의 네트워크를 통해.
- 서버 부하: 데이터베이스 서버의 작업 부하가 쿼리 실행 시간에 영향을 줄 수 있습니다.
이러한 요소를 해결하고 구현함으로써 제공된 권장 사항에 따라 데이터베이스/SQL을 사용한 쿼리 성능이 크게 향상되어 데이터베이스를 직접 쿼리하는 것과 비슷할 수 있습니다.
위 내용은 내 Go 데이터베이스/sql 쿼리가 Direct Postgres psql 쿼리보다 현저히 느린 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

C는 하드웨어 리소스 및 고성능 최적화가 직접 제어되는 시나리오에 더 적합하지만 Golang은 빠른 개발 및 높은 동시성 처리가 필요한 시나리오에 더 적합합니다. 1.C의 장점은 게임 개발과 같은 고성능 요구에 적합한 하드웨어 특성 및 높은 최적화 기능에 가깝습니다. 2. Golang의 장점은 간결한 구문 및 자연 동시성 지원에 있으며, 이는 동시성 서비스 개발에 적합합니다.

Golang은 실제 응용 분야에서 탁월하며 단순성, 효율성 및 동시성으로 유명합니다. 1) 동시 프로그래밍은 Goroutines 및 채널을 통해 구현됩니다. 2) Flexible Code는 인터페이스 및 다형성을 사용하여 작성됩니다. 3) NET/HTTP 패키지로 네트워크 프로그래밍 단순화, 4) 효율적인 동시 크롤러 구축, 5) 도구 및 모범 사례를 통해 디버깅 및 최적화.

GO의 핵심 기능에는 쓰레기 수집, 정적 연결 및 동시성 지원이 포함됩니다. 1. Go Language의 동시성 모델은 고루틴 및 채널을 통한 효율적인 동시 프로그래밍을 실현합니다. 2. 인터페이스 및 다형성은 인터페이스 방법을 통해 구현되므로 서로 다른 유형을 통일 된 방식으로 처리 할 수 있습니다. 3. 기본 사용법은 기능 정의 및 호출의 효율성을 보여줍니다. 4. 고급 사용에서 슬라이스는 동적 크기 조정의 강력한 기능을 제공합니다. 5. 레이스 조건과 같은 일반적인 오류는 Getest-race를 통해 감지 및 해결할 수 있습니다. 6. 성능 최적화는 sync.pool을 통해 개체를 재사용하여 쓰레기 수집 압력을 줄입니다.

Go Language는 효율적이고 확장 가능한 시스템을 구축하는 데 잘 작동합니다. 장점은 다음과 같습니다. 1. 고성능 : 기계 코드로 컴파일, 빠른 달리기 속도; 2. 동시 프로그래밍 : 고어 라틴 및 채널을 통한 멀티 태스킹 단순화; 3. 단순성 : 간결한 구문, 학습 및 유지 보수 비용 절감; 4. 크로스 플랫폼 : 크로스 플랫폼 컴파일, 쉬운 배포를 지원합니다.

SQL 쿼리 결과의 정렬에 대해 혼란스러워합니다. SQL을 학습하는 과정에서 종종 혼란스러운 문제가 발생합니다. 최근 저자는 "Mick-SQL 기본 사항"을 읽고 있습니다.

기술 스택 컨버전스와 기술 선택의 관계, 소프트웨어 개발에서 기술 스택의 선택 및 관리는 매우 중요한 문제입니다. 최근에 일부 독자들은 ...

골란 ...

GO 언어로 세 가지 구조를 비교하고 처리하는 방법. GO 프로그래밍에서는 때때로 두 구조의 차이점을 비교하고 이러한 차이점을 ...에 적용해야합니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

Dreamweaver Mac版
시각적 웹 개발 도구
