PostgreSQL 데이터베이스에 구조체 직접 삽입
소개
귀하의 시나리오에서 구조체에는 수많은 필드가 있으므로 데이터를 하나씩 수동으로 삽입하는 것은 지루할 수 있습니다. 이 문서에서는 "sqlx" 라이브러리를 사용하여 전체 구조체를 PostgreSQL 데이터베이스에 직접 삽입하는 방법을 살펴봅니다.
SQLx를 사용하여 구조체 삽입
"sqlx" 라이브러리 데이터베이스와 상호 작용하는 편리한 방법을 제공합니다. 데이터 삽입을 위해 구조체를 인수로 쉽게 전달할 수 있는 "NamedExec" 기능을 지원합니다.
데이터베이스 태그 정의
"NamedExec"를 사용하려면 구조체의 각 필드에 대해 "db" 태그를 정의해야 합니다. 이러한 태그는 데이터베이스 테이블의 해당 열 이름을 지정합니다.
예:
<code class="go">type ApplyLeave1 struct { LeaveId int `db:"leaveid"` EmpId string `db:"empid"` SupervisorEmpId string `db:"supervisorid"` }</code>
구조체 삽입
태그가 정의되면 "NamedExec"를 사용하여 데이터를 삽입할 수 있습니다.
<code class="go">db, err := sqlx.Connect("postgres", "user=foo dbname=bar sslmode=disable") if err != nil { log.Fatalln(err) } query := `INSERT INTO TABLENAME(leaveid, empid, supervisorid) VALUES(:leaveid, :empid, :supervisorid)` var leave1 ApplyLeave1 _, err = db.NamedExec(query, leave1) if err != nil { log.Fatalln(err) }</code>
"NamedExec"을 사용하면 전체 구조를 한 번에 데이터베이스에 편리하게 삽입할 수 있으므로 반복적인 수동 삽입.
위 내용은 SQLx를 사용하여 PostgreSQL 데이터베이스에 구조체를 직접 삽입하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!