그동안 동일한 SQL 문에 대해 db.Exec와 db.Query를 교대로 사용할 수 있지만 결과는 서로 다릅니다. db.Exec는 영향을 받은 행 수를 반환하고(드라이버에서 지원하는 경우) db.Query는 행 객체를 반환합니다.
예를 들어 DELETE 문에서 삭제된 행 수를 계산하려면 다음을 수행하세요.
res, err := db.Exec(`DELETE FROM my_table WHERE expires_at = `, time.Now()) numDeleted, err := res.RowsAffected() // Returns the number of deleted rows
또는(그러나 덜 효율적):
rows, err := db.Query(`DELETE FROM my_table WHERE expires_at = RETURNING *`, time.Now()) numDeleted := 0 for rows.Next() { numDeleted++ } // Iterate over deleted rows
db.Exec는 다음과 같은 경우에도 사용해야 합니다. 쿼리 결과는 필요하지 않고 오류 확인만 필요합니다.
if _, err := db.Exec(`<my_sql_query>`); err != nil { panic(err) }
Go가 항상 준비된 문을 내부적으로 사용한다는 문서의 주장은 그렇지 않을 수도 있습니다. 정확하다. 드라이버 구현은 각 db.Query 호출에 대해 새로운 준비된 문이 생성되는지 여부를 결정하는 것으로 보입니다.
그러나 db.Prepare를 수동으로 호출하고 결과 db.Stmt를 캐싱하면 자주 실행되는 쿼리의 성능을 향상시킬 수 있습니다. 자세한 내용은 PostgreSQL 설명서를 참조하세요: https://www.postgresql.org/docs/current/static/sql-prepare.html
위 내용은 Go에서 `db.Exec()` 및 준비된 명령문을 언제, 왜 사용해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!