> 데이터 베이스 > MySQL 튜토리얼 > MySQL 데이터베이스와 Go 언어: 데이터 쿼리를 수행하는 방법은 무엇입니까?

MySQL 데이터베이스와 Go 언어: 데이터 쿼리를 수행하는 방법은 무엇입니까?

PHPz
풀어 주다: 2023-06-17 08:37:02
원래의
1542명이 탐색했습니다.

인터넷과 데이터 처리 기술의 지속적인 발전으로 인해 데이터베이스는 데이터 저장 및 관리의 핵심 도구로서 점점 더 중요한 역할을 하고 있습니다. 현대 웹 개발에서 가장 널리 사용되는 관계형 데이터베이스 중 하나인 MySQL은 데이터를 저장하고 관리하는 데 자주 사용됩니다. Go 언어는 효율성, 속도, 단순성으로 인해 가장 인기 있는 프로그래밍 언어 중 하나가 되었습니다. 또한 데이터베이스 작업과 관련된 우수한 라이브러리와 프레임워크가 많이 있습니다. 그렇다면 MySQL 데이터베이스와 Go 언어에서 데이터 쿼리를 수행하는 방법은 무엇입니까? 이번 글에서는 이에 대해 자세히 소개하겠습니다.

1. Go 언어의 기초

우선 Go 언어에 대한 기본 지식을 어느 정도 습득해야 합니다. Go 언어는 SQL 데이터베이스의 액세스 및 운영을 지원하는 경량 데이터 액세스 계층인 데이터베이스/SQL 표준 라이브러리를 제공합니다. 데이터베이스/SQL 패키지를 이용하면 데이터베이스 연결, 쿼리, 업데이트 등의 작업을 쉽게 수행할 수 있습니다.

Go 언어의 데이터베이스/sql 표준 라이브러리를 사용한 데이터 쿼리의 기본 단계는 다음과 같습니다.

  1. 데이터베이스 연결 열기

sql.Open 함수를 호출하여 데이터베이스에 대한 연결을 만듭니다. 이 함수에는 드라이버 이름과 데이터 소스 이름이라는 두 가지 매개변수가 필요합니다. MySQL에서 드라이버 이름은 "mysql"입니다. 데이터 소스 이름에는 데이터베이스 IP 주소, 포트, 사용자 이름, 비밀번호, 데이터베이스 이름 등 데이터베이스에 연결하는 데 필요한 모든 정보가 포함됩니다.

샘플 코드는 다음과 같습니다.

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

func main() {
  db, err := sql.Open("mysql", "root:password@tcp(127.0.0.1:3306)/my_database")
  if err != nil {
    panic(err)
  }
  defer db.Close()
}
로그인 후 복사
  1. SQL 쿼리 문 작성

SQL 쿼리 문을 사용하여 수행할 작업을 정의합니다. Go 언어에서는 ?를 자리 표시자로 사용하여 쿼리의 매개변수를 바꿀 수 있습니다. 이러한 매개변수는 쿼리 실행 시 자동으로 실제 값으로 대체되므로 SQL 주입 공격을 방지할 수 있습니다.

샘플 코드는 다음과 같습니다.

stmt, err := db.Prepare("SELECT * FROM users WHERE age > ?")
if err != nil {
  panic(err)
}
defer stmt.Close()
로그인 후 복사
  1. 질의 연산 실행

stmt.Query 함수 또는 stmt.QueryRow 함수를 호출하여 SQL 질의문을 실행합니다. Query 함수는 결과 집합을 얻기 위해 탐색할 수 있는 행 집합 개체를 반환합니다. QueryRow 함수는 결과 집합의 단일 행만 반환합니다.

샘플 코드는 다음과 같습니다.

rows, err := stmt.Query(18)
if err != nil {
  panic(err)
}
defer rows.Close()

for rows.Next() {
  // 处理查询结果
}
로그인 후 복사
  1. 쿼리 결과를 구문 분석합니다

rows.Scan 함수 또는rows.Columns 함수를 사용하여 쿼리 결과를 처리합니다. Scan 함수는 현재 행의 값을 가져와 지정된 변수에 저장하는 반면, Columns 함수는 결과 집합의 열 이름을 반환합니다.

샘플 코드는 다음과 같습니다.

var id int
var name string

err := rows.Scan(&id, &name)
if err != nil {
  panic(err)
}
로그인 후 복사

2. MySQL 문 소개

Go 언어에 대한 기본 지식을 이해한 후에는 MySQL 문에 대한 지식도 어느 정도 습득해야 합니다. MySQL은 SELECT, INSERT, UPDATE, DELETE 등과 같은 다양한 쿼리문을 지원합니다. 이번 글에서는 MySQL에서 가장 많이 사용되는 쿼리문 중 하나인 SELECT 쿼리문을 소개하겠습니다.

  1. SELECT 문

SELECT 문은 하나 이상의 테이블에서 데이터를 선택하고 결과 집합을 클라이언트에 반환하는 데 사용됩니다. SELECT 문의 일반적인 형태는 다음과 같습니다.

SELECT 列名1, 列名2, ... FROM 表名 WHERE 条件;
로그인 후 복사

그 중 열 이름은 쿼리할 열 이름을 쉼표로 구분하여 나타내고, 테이블 이름은 WHERE 절을 나타냅니다. 선택 사항이며 데이터를 필터링하는 데 사용됩니다.

샘플 코드는 다음과 같습니다.

SELECT id, name, age FROM users WHERE age > 18;
로그인 후 복사
  1. WHERE 문

WHERE 문은 테이블에서 지정된 조건에 맞는 데이터를 선택하는 데 사용됩니다. WHERE 절에는 AND 또는 OR로 연결된 하나 이상의 조건이 포함될 수 있습니다. 조건은 일반적으로 비교 연산자(예: >, <, =, !=) 및 논리 연산자(AND 또는 OR)를 사용하여 정의됩니다.

샘플 코드는 다음과 같습니다.

SELECT id, name, age FROM users WHERE age > 18 AND name LIKE '%john%';
로그인 후 복사
  1. ORDER BY 문

ORDER BY 문은 하나 이상의 지정된 열에 따라 결과 집합을 정렬하는 데 사용됩니다. 기본적으로 ORDER BY 문은 오름차순으로 정렬됩니다.

샘플 코드는 다음과 같습니다.

SELECT id, name, age FROM users WHERE age > 18 ORDER BY age DESC;
로그인 후 복사
  1. LIMIT 문

LIMIT 문은 결과 집합에 반환되는 행 수를 제한하는 데 사용됩니다. OFFSET 절을 사용하여 반환을 시작할 위치를 지정할 수 있습니다.

샘플 코드는 다음과 같습니다.

SELECT id, name, age FROM users WHERE age > 18 LIMIT 5 OFFSET 10;
로그인 후 복사

3. MySQL 쿼리에 Go 언어 사용

  1. 단일 결과 쿼리

다음은 ID가 1인 사용자를 쿼리하는 예제 함수입니다.

func getUserByID(db *sql.DB) (User, error) {
  var user User
  err := db.QueryRow("SELECT id, name, age FROM users WHERE id = ?", 1).Scan(&user.ID, &user.Name, &user.Age)
  if err != nil {
    return User{}, err
  }
  return user, nil
}
로그인 후 복사

이 예제에서는 함수에서는 QueryRow 함수를 호출하여 ID가 ​​1인 사용자를 쿼리합니다. QueryRow 함수는 결과 집합에서 하나의 행만 반환하므로 Scan 함수를 사용하여 결과를 User 구조에 저장할 수 있습니다.

  1. 여러 결과 쿼리

다음은 18세 이상의 모든 사용자를 쿼리하는 예제 함수입니다.

func getUsersByAge(db *sql.DB, age int) ([]User, error) {
  var users []User
  rows, err := db.Query("SELECT id, name, age FROM users WHERE age > ?", age)
  if err != nil {
    return nil, err
  }
  defer rows.Close()

  for rows.Next() {
    var user User
    err := rows.Scan(&user.ID, &user.Name, &user.Age)
    if err != nil {
      return nil, err
    }
    users = append(users, user)
  }

  return users, nil
}
로그인 후 복사

이 예제 함수에서는 Query 함수를 호출하여 18세 이상의 모든 사용자를 쿼리하고 트래버스합니다. 모든 결과를 얻으려면 행 집합을 사용하세요. 행 집합을 반복하면서 Scan 함수를 통해 결과를 User 구조에 저장하고 이를 사용자 조각에 추가합니다.

4. 요약

이 기사에서는 Go 언어를 사용하여 MySQL 데이터를 쿼리하는 방법을 소개했습니다. 먼저 Go 언어에 대한 기본 지식을 소개한 후, MySQL에서 일반적으로 사용되는 쿼리문을 설명하고, 마지막으로 샘플 코드를 통해 Go 언어를 사용하여 MySQL 쿼리를 수행하는 방법을 시연했습니다.

위의 샘플 코드는 기본적인 쿼리 작업일 뿐이라는 점에 유의하세요. 실제 개발에서는 특정 요구 사항과 시나리오에 따라 다양한 쿼리 문과 애플리케이션 모델을 사용해야 합니다. 동시에 쿼리문의 성능도 고려해야 하며, 쿼리 성능을 향상시키기 위해 인덱스와 같은 최적화 방법을 사용하도록 노력해야 합니다.

위 내용은 MySQL 데이터베이스와 Go 언어: 데이터 쿼리를 수행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿