백엔드 개발 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 도구

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

뜨거운 주제

PHP 튜토리얼
1538
276
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를 사용하는 것입니다 ...

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

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

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

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

GO 프로그래밍에서 MySQL과 Redis 간의 연결을 올바르게 관리하고 릴리스하는 방법은 무엇입니까? GO 프로그래밍에서 MySQL과 Redis 간의 연결을 올바르게 관리하고 릴리스하는 방법은 무엇입니까? Apr 02, 2025 pm 05:03 PM

GO 프로그래밍의 자원 관리 : MySQL 및 Redis는 특히 데이터베이스 및 캐시를 통해 리소스를 올바르게 관리하는 방법을 배우는 데 연결 및 릴리스 ...

Centos PostgreSQL 리소스 모니터링 Centos PostgreSQL 리소스 모니터링 Apr 14, 2025 pm 05:57 PM

CentOS 시스템 아래 PostgreSQL 데이터베이스 리소스 모니터링 체계에 대한 자세한 설명이 기사는 CentOS 시스템에서 PostgreSQL 데이터베이스 리소스를 모니터링하는 다양한 방법을 소개하여 잠재적 성능 문제를 적시에 발견하고 해결할 수 있도록 도와줍니다. 1. PostgreSQL 내장 도구 및보기 PostgreSQL에는 성능 및 상태 모니터링에 직접 사용할 수있는 풍부한 도구 및 뷰가 제공됩니다. PG_STAT_ACTIVITY : 현재 활성화 된 연결 및 쿼리 정보를보십시오. PG_STAT_STATEMENTS : SQL 문 통계를 수집하고 쿼리 성능 병목 현상을 분석하십시오. PG_STAT_DATABASE : 트랜잭션 카운트, 캐시 히트와 같은 데이터베이스 레벨 통계를 제공합니다.

GO 대 기타 언어 : 비교 분석 GO 대 기타 언어 : 비교 분석 Apr 28, 2025 am 12:17 AM

goistrongchoiceforprojectsneedingsimplicity, performance, and concurrency, butitmaylackinadvancedfeaturesandecosystemmaturity.1) go'ssyntaxissimpleandeasytolearn, go'ssyntaxissimpleandeasytolearn, theadtofewerbugsandmoremaintainablecode, theitlacksfeaturecomecemememecememememecememememememememememecemememememecemememecemememecemememecemecemecode

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

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

GO의 Init 기능에 대한 일반적인 사용 사례 GO의 Init 기능에 대한 일반적인 사용 사례 Apr 28, 2025 am 12:13 AM

theinitfunctioningoare에 대한 thecommonusecases : 1) loadingConfigurationFiles는 eprogramStarts, 2) 초기화 GlobalVaribles, 및 3) runningpre-checksorvalidationsforeprogramProeceeds

See all articles