>백엔드 개발 >Golang >SQLx를 사용하여 PostgreSQL 데이터베이스에 구조체를 직접 삽입하려면 어떻게 해야 합니까?

SQLx를 사용하여 PostgreSQL 데이터베이스에 구조체를 직접 삽입하려면 어떻게 해야 합니까?

Linda Hamilton
Linda Hamilton원래의
2024-10-31 00:40:29741검색

How Can I Directly Insert a Struct into a PostgreSQL Database Using SQLx?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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