백엔드 개발 Golang Go 언어 시작하기: 데이터베이스 연결의 기본 개념

Go 언어 시작하기: 데이터베이스 연결의 기본 개념

Jan 23, 2024 am 08:17 AM
언어로 가다 기본 지식 데이터베이스에 연결

Go 언어 시작하기: 데이터베이스 연결의 기본 개념

Go 언어 배우기: 데이터베이스 연결에 대한 기본 지식, 특정 코드 예제가 필요합니다

Go语言是一种开源的编程语言,其简洁、高效的特性让越来越多的开发者喜爱和使用。在开发过程中,经常需要与数据库建立连接,进行数据的读取、写入、更新和删除等操作。因此,学会如何在Go语言中连接数据库是非常重要的技能。
로그인 후 복사
  1. 데이터베이스 드라이버
    Go 언어에서 데이터베이스에 연결하려면 데이터베이스 드라이버를 사용해야 합니다. 현재 Go 언어의 주요 데이터베이스 드라이버는 다음과 같습니다.

    • database/sql: Go 언어 표준 패키지에서 제공하는 데이터베이스 드라이버 인터페이스로 MySQL, PostgreSQL, SQLite 등 다양한 데이터베이스를 지원합니다. .
    • go-sqlite3: SQLite 데이터베이스용 드라이버로, SQLite 데이터베이스를 연결하고 운영하는 데 사용됩니다.
    • pq: PostgreSQL 데이터베이스를 연결하고 작동하는 데 사용되는 PostgreSQL 데이터베이스용 드라이버입니다.
    • go-mysql-driver: MySQL 데이터베이스를 연결하고 운영하는 데 사용되는 MySQL 데이터베이스용 드라이버입니다.

    이 글에서는 MySQL 데이터베이스를 예로 들어 설명하겠습니다.

  2. 데이터베이스 드라이버 설치
    go-mysql-driver를 사용하여 MySQL 데이터베이스에 연결하기 전에 먼저 드라이버를 설치해야 합니다. 다음 명령을 사용하여 설치할 수 있습니다.

    go get github.com/go-sql-driver/mysql
    로그인 후 복사

    설치가 완료된 후 Go 프로그램에서 패키지를 가져오고 그 안에 있는 기능과 구조를 사용할 수 있습니다.

  3. Connect to the 데이터베이스
    Go 언어에서 MySQL 데이터베이스에 연결하는 단계는 다음과 같습니다.

    • 데이터베이스 드라이버 패키지 가져오기: 가져올 코드에서 import 키워드를 사용하세요. "go-sql-driver/mysql "가방. import关键字导入"go-sql-driver/mysql"包。
    • 使用sql.Open()函数打开数据库连接,该函数的参数为数据库的驱动名称和连接字符串。例如,sql.Open("mysql", "用户名:密码@tcp(localhost:3306)/数据库名称")
    • 调用数据库连接的Ping()方法,判断连接是否成功,即是否能够成功连通数据库。

    下面是一个示例代码:

    package main
    
    import (
        "database/sql"
        "fmt"
    
        _ "github.com/go-sql-driver/mysql"
    )
    
    func main() {
        // 打开数据库连接
        db, err := sql.Open("mysql", "用户名:密码@tcp(localhost:3306)/数据库名称")
        if err != nil {
            fmt.Println("数据库连接失败:", err)
            return
        }
        defer db.Close()
    
        // 测试连接
        err = db.Ping()
        if err != nil {
            fmt.Println("连接失败:", err)
            return
        }
    
        fmt.Println("连接成功!")
    }
    로그인 후 복사
  4. 查询数据
    连接成功后,可以进行数据库操作。下面是一个查询数据的示例代码:

    rows, err := db.Query("SELECT * FROM table_name")
    if err != nil {
        fmt.Println("查询失败:", err)
        return
    }
    defer rows.Close()
    
    for rows.Next() {
        var id int
        var name string
        err := rows.Scan(&id, &name)
        if err != nil {
            fmt.Println("扫描行失败:", err)
            return
        }
        fmt.Println("ID:", id, "Name:", name)
    }
    
    if err = rows.Err(); err != nil {
        fmt.Println("遍历结果集失败:", err)
        return
    }
    로그인 후 복사

    上述代码通过db.Query()方法查询数据库中的数据,然后使用rows.Next()循环遍历查询结果。在循环内部,通过rows.Scan()方法扫描行数据,并将结果存储到变量中。

  5. 插入数据
    除了查询数据,Go语言还可以通过db.Exec()方法向数据库中插入数据。下面是一个插入数据的示例代码:

    result, err := db.Exec("INSERT INTO table_name (name) VALUES (?)", "John")
    if err != nil {
        fmt.Println("插入数据失败:", err)
        return
    }
    
    affectedRows, _ := result.RowsAffected()
    fmt.Println("插入成功,影响的行数为:", affectedRows)
    로그인 후 복사

    通过db.Exec()方法执行SQL插入语句,其中?表示参数占位符,可以使用具体的值进行替换,例如"John"。

  6. 更新和删除数据
    在Go语言中,可以使用db.Exec()方法更新和删除数据库中的数据。下面是一个更新数据的示例代码:

    result, err := db.Exec("UPDATE table_name SET name = ? WHERE id = ?", "Tom", 1)
    if err != nil {
        fmt.Println("更新数据失败:", err)
        return
    }
    
    affectedRows, _ := result.RowsAffected()
    fmt.Println("更新成功,影响的行数为:", affectedRows)
    로그인 후 복사

    通过db.Exec()方法执行SQL更新语句,其中?表示参数占位符,可以使用具体的值进行替换。

    同样,可以使用db.Exec()方法执行SQL删除语句,例如:

    result, err := db.Exec("DELETE FROM table_name WHERE id = ?", 1)
    로그인 후 복사

    上述代码删除table_name

    sql.Open() 함수를 사용하여 데이터베이스 연결을 엽니다. 이 함수의 매개변수는 데이터베이스의 드라이버 이름과 연결 문자열입니다. 예를 들어 sql.Open("mysql", "사용자 이름:password@tcp(localhost:3306)/데이터베이스 이름")입니다. 데이터베이스 연결의 Ping() 메서드를 호출하여 연결 성공 여부, 즉 데이터베이스 연결에 성공할 수 있는지 확인합니다.

    🎜다음은 샘플 코드입니다. 🎜rrreee🎜🎜🎜Query data🎜 연결이 성공한 후 데이터베이스 작업을 수행할 수 있습니다. 다음은 데이터 조회를 위한 샘플 코드입니다. 🎜rrreee🎜위 코드는 db.Query() 메서드를 통해 데이터베이스에 있는 데이터를 조회한 후, rows.Next() 검색 결과를 반복합니다. 루프 내에서 행 데이터는 <code>rows.Scan() 메서드를 통해 스캔되고 결과가 변수에 저장됩니다. 🎜🎜🎜🎜데이터 삽입🎜 Go 언어는 데이터 쿼리 외에도 db.Exec() 메서드를 통해 데이터베이스에 데이터를 삽입할 수도 있습니다. 다음은 데이터 삽입을 위한 샘플 코드입니다. 🎜rrreee🎜 db.Exec() 메서드를 통해 SQL 삽입 문을 실행합니다. 여기서 ?는 매개변수 자리 표시자를 나타내며, "John"과 같은 특정 값을 사용할 수 있습니다. 🎜🎜🎜🎜데이터 업데이트 및 삭제🎜 Go 언어에서는 db.Exec() 메서드를 사용하여 데이터베이스의 데이터를 업데이트하고 삭제할 수 있습니다. 다음은 데이터 업데이트를 위한 샘플 코드입니다. 🎜rrreee🎜 db.Exec() 메서드를 통해 SQL 업데이트 문을 실행합니다. 여기서 ?는 매개변수 자리 표시자를 나타내고, 특정 값을 사용할 수 있습니다. 🎜🎜마찬가지로 db.Exec() 메서드를 사용하여 SQL 삭제 문을 실행할 수 있습니다. 예: 🎜rrreee🎜위 코드는 table_name에서 ID가 1인 데이터를 삭제합니다. 코드> 테이블. 🎜🎜🎜🎜이 글의 서문을 통해 독자들은 Go 언어로 데이터베이스에 연결하는 기본 지식을 기본적으로 이해했다고 믿습니다. 데이터베이스 운용은 실제 개발에서 자주 사용되는 기술입니다. 이 글의 내용이 독자들에게 도움이 되고 실제 프로젝트에 적용해 볼 수 있기를 바랍니다. 🎜

    위 내용은 Go 언어 시작하기: 데이터베이스 연결의 기본 개념의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Go 's Crawler Colly의 큐 스레드의 문제는 무엇입니까? Go 's Crawler Colly의 큐 스레드의 문제는 무엇입니까? Apr 02, 2025 pm 02:09 PM

Go Crawler Colly의 대기열 스레딩 문제는 Colly Crawler 라이브러리를 GO 언어로 사용하는 문제를 탐구합니다. � ...

GO에서 플로팅 포인트 번호 작업에 어떤 라이브러리가 사용됩니까? GO에서 플로팅 포인트 번호 작업에 어떤 라이브러리가 사용됩니까? Apr 02, 2025 pm 02:06 PM

Go Language의 부동 소수점 번호 작동에 사용되는 라이브러리는 정확도를 보장하는 방법을 소개합니다.

골란드의 사용자 정의 구조 레이블이 표시되지 않으면 어떻게해야합니까? 골란드의 사용자 정의 구조 레이블이 표시되지 않으면 어떻게해야합니까? Apr 02, 2025 pm 05:09 PM

골란드의 사용자 정의 구조 레이블이 표시되지 않으면 어떻게해야합니까? Go Language 개발을 위해 Goland를 사용할 때 많은 개발자가 사용자 정의 구조 태그를 만날 것입니다 ...

이동 중에 왜 println 및 string () 함수로 문자열이 다른 효과를 갖는 이유는 무엇입니까? 이동 중에 왜 println 및 string () 함수로 문자열이 다른 효과를 갖는 이유는 무엇입니까? Apr 02, 2025 pm 02:03 PM

Go Language의 문자열 인쇄의 차이 : println 및 String () 함수 사용 효과의 차이가 진행 중입니다 ...

GO의 어떤 라이브러리가 대기업에서 개발하거나 잘 알려진 오픈 소스 프로젝트에서 제공합니까? GO의 어떤 라이브러리가 대기업에서 개발하거나 잘 알려진 오픈 소스 프로젝트에서 제공합니까? Apr 02, 2025 pm 04:12 PM

GO의 어떤 라이브러리가 대기업이나 잘 알려진 오픈 소스 프로젝트에서 개발 했습니까? GO에 프로그래밍 할 때 개발자는 종종 몇 가지 일반적인 요구를 만납니다.

Redis Stream을 사용하여 GO Language에서 메시지 대기열을 구현할 때 User_ID 유형 변환 문제를 해결하는 방법은 무엇입니까? Redis Stream을 사용하여 GO Language에서 메시지 대기열을 구현할 때 User_ID 유형 변환 문제를 해결하는 방법은 무엇입니까? Apr 02, 2025 pm 04:54 PM

Go Language에서 메시지 대기열을 구현하기 위해 Redisstream을 사용하는 문제는 Go Language와 Redis를 사용하는 것입니다 ...

GO 언어에서 'var'와 'type` 키워드 정의 구조의 차이점은 무엇입니까? GO 언어에서 'var'와 'type` 키워드 정의 구조의 차이점은 무엇입니까? Apr 02, 2025 pm 12:57 PM

GO 언어에서 구조를 정의하는 두 가지 방법 : VAR과 유형 키워드의 차이. 구조를 정의 할 때 Go Language는 종종 두 가지 다른 글쓰기 방법을 본다 : 첫째 ...

Go 및 Viper 라이브러리를 사용할 때 포인터를 전달 해야하는 이유는 무엇입니까? Go 및 Viper 라이브러리를 사용할 때 포인터를 전달 해야하는 이유는 무엇입니까? Apr 02, 2025 pm 04:00 PM

Go Pointer Syntax 및 Viper Library 사용의 문제 해결 GO 언어로 프로그래밍 할 때 특히 포인터의 구문 및 사용법을 이해하는 것이 중요합니다.

See all articles