집 >데이터 베이스 >MySQL 튜토리얼 >Golang을 사용하여 MySQL 애플리케이션을 작성하는 방법
1단계: MySQL 데이터베이스 설치 및 설정
먼저 MySQL 데이터베이스를 설치하고 설정해야 합니다. MySQL은 다음 링크를 통해 다운로드하고 설치할 수 있습니다:
https://www.mysql.com/downloads/
설치가 완료되면 데이터베이스와 사용자도 생성해야 합니다. MySQL 콘솔을 열고 다음 명령을 실행합니다:
$ mysql -u root -p
그러면 콘솔에 비밀번호를 묻는 메시지가 표시됩니다. 비밀번호를 입력하고 Enter를 누르세요. 이제 애플리케이션에서 새 데이터베이스와 새 사용자를 사용할 수 있습니다. 생성하기만 하면 됩니다.
mysql> CREATE DATABASE mydatabase; mysql> CREATE USER 'myuser'@'localhost' IDENTIFIED BY 'mypassword'; mysql> GRANT ALL ON mydatabase.* TO 'myuser'@'localhost'; mysql> FLUSH PRIVILEGES;
다음으로 MySQL 데이터베이스에 연결하기 위해 Golang MySQL 라이브러리를 설치합니다.
2단계: Golang MySQL 라이브러리 설치
Go에는 사용 가능한 MySQL 라이브러리가 많지만 가장 인기 있는 라이브러리는 go-sql-driver/mysql 라이브러리입니다.
다음 명령을 사용하여 라이브러리를 설치합니다.
$ go get -u github.com/go-sql-driver/mysql
3단계: Golang 애플리케이션 작성
이 예에서는 Golang을 사용하여 MySQL 데이터베이스에 연결하고 쿼리하는 간단한 애플리케이션을 만듭니다. 아래 단계를 따르십시오.
필요한 라이브러리 가져오기:
import (
<code> "database/sql" "fmt" _ "github.com/go-sql-driver/mysql" </code>
)
데이터베이스에 연결:
db, err := sql.Open("mysql", "myuser:mypassword @ tcp (127.0.0.1:3306)/mydatabase "))
if err! = nil {
<code> panic(err.Error()) </code>
}
defer db.close ()
execute query :
rows, err : = d b .Query("SELECT * FROM mytable")
if err != nil {
<code> panic(err.Error()) </code>
}
결과를 반복하고 인쇄합니다.
forrows.Next() {
var id int var name string err := rows.Scan(&id, &name) if err != nil { panic(err.Error()) } fmt.Println(id, name)
}
전체 코드는 다음과 같습니다.
package main
import (
<code> "database/sql" "fmt" _ "github.com/go-sql-driver/mysql" </code>
)
func main() {
db, err := sql.Open("mysql", "myuser:mypassword@tcp(127.0.0.1:3306)/mydatabase") if err != nil { panic(err.Error()) } defer db.Close() rows, err := db.Query("SELECT * FROM mytable") if err != nil { panic(err.Error()) } for rows.Next() { var id int var name string err := rows.Scan(&id, &name) if err != nil { panic(err.Error()) } fmt.Println(id, name) }
}
코드를 저장하고 애플리케이션을 실행합니다.
$ go run main.go
출력에는 MySQL 데이터베이스에서 검색한 ID와 이름이 포함되어야 합니다.
위 내용은 Golang을 사용하여 MySQL 애플리케이션을 작성하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!