데이터베이스/SQL SQL 문 일괄 처리
질문:
Java에서 SQL 문 일괄 처리 데이터베이스/SQL 패키지를 사용하는 것은 간단합니다. Go에서 유사한 기능을 어떻게 얻을 수 있습니까?
: 답변:
Go의 데이터베이스/sql 패키지를 사용하면 db.Exec 함수를 사용하여 SQL 문을 일괄 처리할 수 있습니다. 이는 다양한 수의 인수를 취합니다. Go에서 일괄 처리를 구현하는 방법은 다음과 같습니다.
SQL 문 구성:
자리 표시자와 함께 SQL 문이 포함된 문자열을 만듭니다. 삽입하려는 값입니다. 예:
stmt := "INSERT INTO my_table (field1, field2, field3) VALUES (?, ?, ?)"
인수 분해:
삽입하려는 값에 대해 별도의 조각을 만듭니다. 각 행에 대해 이러한 조각에 값을 추가합니다.
valueStrings := make([]string, 0, len(unsavedRows)) valueArgs := make([]interface{}, 0, len(unsavedRows) * 3) for _, post := range unsavedRows { valueStrings = append(valueStrings, "(?, ?, ?)") valueArgs = append(valueArgs, post.Field1) valueArgs = append(valueArgs, post.Field2) valueArgs = append(valueArgs, post.Field3) }
배치 실행:
db.Exec 함수를 사용하여 실행 인수를 전달하는 일괄처리된 SQL 문
_, err := db.Exec(stmt, valueArgs...)
이 방법은 단일 네트워크 왕복으로 일괄 작업을 수행하므로 많은 양의 데이터를 삽입하는 데 효율적입니다.
위 내용은 Go의 `database/sql` 패키지에서 SQL 문을 일괄 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!