>웹 프론트엔드 >JS 튜토리얼 >pg-promise를 사용하여 다중 행 삽입을 효율적으로 수행하려면 어떻게 해야 합니까?

pg-promise를 사용하여 다중 행 삽입을 효율적으로 수행하려면 어떻게 해야 합니까?

DDD
DDD원래의
2024-10-30 06:29:02495검색

How can I perform multi-row inserts efficiently with pg-promise?

pg-promise를 사용한 다중 행 삽입

문제:
단일 객체의 매개변수를 사용하는 삽입 pg-promise를 사용하면 쉽게 수행할 수 있지만 다중 행 삽입에는 더 복잡한 기술이 필요합니다. 단일 쿼리로 여러 행을 삽입하는 간단한 방법이 있습니까?

해결책:

최신 버전의 pg-promise에서는 helpers 네임스페이스가 최적화되고 유연한 방법을 제공합니다. 다중 행 삽입의 경우. 쿼리 문자열을 수동으로 구성하는 대신 도우미 네임스페이스 내에서 삽입 함수를 사용할 수 있습니다.

const pgp = require('pg-promise')({
    capSQL: true // capitalize all SQL
});
const db = pgp(/*connection*/);
const {ColumnSet, insert} = pgp.helpers;

const cs = new ColumnSet(['col_a', 'col_b'], {table: 'tmp'});
const values = [{col_a: 'a1', col_b: 'b1'}, {col_a: 'a2', col_b: 'b2'}];
const query = insert(values, cs);

await db.none(query);

이 코드는 다음 SQL을 생성합니다.

<code class="sql">INSERT INTO "tmp"("col_a","col_b") VALUES('a1', 'b1'),('a2', 'b2')</code>

이 접근 방식은 몇 가지 장점을 제공합니다.

  • 성능 최적화
  • SQL 삽입 방지
  • 단일 행 및 다중 행 삽입 또는 업데이트를 위한 중앙 집중식 쿼리 생성

부차 질문:

매개변수 표기법을 사용한 삽입은 매개변수 이름이 올바르게 인용되면 SQL 삽입으로부터 보호됩니다. 그러나 컬럼이나 테이블 이름을 동적으로 삽입해야 하는 경우 추가 보호를 위해 SQL 이름을 사용해야 합니다.

위 내용은 pg-promise를 사용하여 다중 행 삽입을 효율적으로 수행하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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