"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > Go를 사용하여 데이터베이스 쿼리

Go를 사용하여 데이터베이스 쿼리

2024-08-16에 게시됨
검색:660

Query a database Using Go

1단계: MySQL 드라이버 설치
먼저 Go용 MySQL 드라이버를 설치해야 합니다. 널리 사용되는 것은 go-sql-driver/mysql입니다. 다음을 사용하여 설치할 수 있습니다:

go get -u github.com/go-sql-driver/mysql

2단계: Go 코드 작성
다음은 MySQL 데이터베이스에 연결하고 데이터를 쿼리하는 방법에 대한 예입니다.

package main

import (
    "database/sql"
    "fmt"
    "log"

    _ "github.com/go-sql-driver/mysql"
)

func main() {
    // Open the database connection
    db, err := sql.Open("mysql", "username:password@tcp(127.0.0.1:3306)/dbname")
    if err != nil {
        log.Fatal(err)
    }
    defer db.Close()

    // Ping the database to check if the connection is alive
    if err := db.Ping(); err != nil {
        log.Fatal(err)
    }

    // Define the query
    query := "SELECT id, name FROM users WHERE active = ?"
    active := true

    // Execute the query
    rows, err := db.Query(query, active)
    if err != nil {
        log.Fatal(err)
    }
    defer rows.Close()

    // Iterate through the result set
    for rows.Next() {
        var id int
        var name string
        if err := rows.Scan(&id, &name); err != nil {
            log.Fatal(err)
        }
        fmt.Printf("ID: %d, Name: %s\n", id, name)
    }

    // Check for errors from iterating over rows
    if err := rows.Err(); err != nil {
        log.Fatal(err)
    }
}

설명:
필요한 패키지 가져오기: 데이터베이스 상호 작용을 위한 데이터베이스/sql 패키지와 MySQL 드라이버를 가져옵니다(github.com/go-sql-driver/mysql).

데이터베이스 연결 열기: sql.Open을 사용하여 데이터베이스에 대한 연결을 엽니다. 연결 문자열 형식은 사용자 이름:password@tcp(호스트:포트)/dbname.

입니다.

데이터베이스 핑: 연결이 설정되었는지 확인하기 위해 데이터베이스를 핑하는 것이 좋습니다.

쿼리 실행: db.Query를 사용하여 쿼리를 실행합니다. Query 메서드는 결과 집합을 얻기 위해 반복할 수 있는 *sql.Rows 개체를 반환합니다.

결과 반복: 루프를 사용하여 행을 반복하고 각 행을 변수로 스캔합니다.

오류 처리: 쿼리 실행 또는 반복 중에 발생하는 모든 오류를 처리해야 합니다.

3단계: 코드 실행
사용자 이름, 비밀번호, 127.0.0.1:3306 및 dbname을 실제 MySQL 자격 증명 및 데이터베이스 세부 정보로 바꾸십시오.

Go 프로그램을 실행하면 쿼리 결과가 출력됩니다.

이 예는 드라이버와 연결 문자열을 적절하게 변경하여 다른 데이터베이스에 적용할 수 있습니다.

릴리스 선언문 이 글은 https://dev.to/sukmarizki04/query-a-database-using-go-5f41?1에서 복제됩니다.1 침해 내용이 있는 경우, [email protected]으로 연락하여 삭제하시기 바랍니다.
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3