[go] Go 언어에서 데이터베이스 연동 시 쿼리 실행 방법

Go 언어는 강력한 데이터베이스 연동 기능을 제공하여, 다양한 데이터베이스와의 연동이 가능합니다. 이 글에서는 Go 언어로 데이터베이스를 연동하고 쿼리를 실행하는 방법에 대해 알아보겠습니다.

데이터베이스 연결하기

가장 먼저 해야 할 일은 Go 언어에서 데이터베이스에 연결하는 것입니다. 대부분의 데이터베이스 시스템은 Go 언어와 호환되는 드라이버를 제공하고 있으며, 이 드라이버들은 Go 언어의 표준 라이브러리에서 제공하는 database/sql 패키지를 이용하여 연동됩니다.

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

func main() {
    db, err := sql.Open("mysql", "user:password@tcp(127.0.0.1:3306)/dbname")
    if err != nil {
        panic(err.Error())
    }
    defer db.Close()
}

위의 예제는 MySQL 데이터베이스에 연결하는 방법을 보여줍니다.

쿼리 실행하기

데이터베이스에 연결했다면, 이제 쿼리를 실행할 준비가 되었습니다. Go 언어에서는 Prepare, Query, Exec 등의 메소드를 사용하여 쿼리를 실행할 수 있습니다.

func main() {
    // ... 데이터베이스 연결 코드
    
    // 쿼리 준비
    stmt, err := db.Prepare("SELECT name FROM users WHERE id = ?")
    if err != nil {
        panic(err.Error())
    }
    defer stmt.Close()

    // 쿼리 실행
    var name string
    err = stmt.QueryRow(1).Scan(&name)
    if err != nil {
        panic(err.Error())
    }
    fmt.Println(name)
}

위의 예제에서는 Prepare 메소드를 사용하여 쿼리를 준비하고, QueryRow 메소드를 사용하여 결과를 가져오는 방법을 보여줍니다.

마치며

이상으로 Go 언어에서 데이터베이스를 연동하고 쿼리를 실행하는 방법에 대해 알아보았습니다. 데이터베이스 연동은 실제 애플리케이션 개발에서 중요한 부분이므로, 실습을 통해 익숙해지는 것이 좋을 것입니다.

참고 자료