중소기업을 위한 MySQL 데이터베이스: Go 언어를 사용한 신속한 개발
인터넷의 대중화로 인해 점점 더 많은 중소기업이 온라인 사업을 시작하고 있습니다. 이러한 비즈니스에 관련된 데이터의 양은 일반적으로 그다지 크지 않지만 소규모 비즈니스의 경우 데이터 저장 및 처리는 여전히 매우 중요한 문제입니다. MySQL 데이터베이스는 현재 데이터 저장 및 처리에 사용되는 가장 널리 사용되는 데이터베이스 중 하나이며 많은 중소기업이 가장 먼저 선택하는 데이터베이스이기도 합니다. 이 기사에서는 Go 언어를 사용하여 MySQL 데이터베이스를 빠르게 개발하고 관리하는 방법을 소개합니다.
- MySQL 데이터베이스 설치
MySQL을 사용하기 전에 먼저 MySQL을 설치해야 합니다. MySQL 공식 웹사이트에서 귀하의 기기에 적합한 버전을 찾아 필요에 따라 다운로드하여 설치할 수 있습니다. 설치가 완료되면 MySQL 루트 사용자 비밀번호 설정, 새 사용자 생성 및 권한 할당을 포함하여 몇 가지 기본 구성이 필요합니다.
- Go 언어 설치
Go 언어는 인터넷 애플리케이션 개발에 널리 사용되는 비교적 새로운 프로그래밍 언어입니다. 공식 웹사이트에서 Go 언어 설치 패키지를 다운로드한 후 안내에 따라 설치하세요. 설치가 완료되면 Go 언어의 환경 변수와 GOPATH 경로를 설정해야 합니다.
- MySQL용 Go 라이브러리 설치
Go 언어에서는 MySQL 데이터베이스를 연결하고 운영하려면 타사 라이브러리를 사용해야 합니다. 현재 널리 사용되는 라이브러리에는 go-sql-driver/mysql 및 jmoiron/sqlx가 있습니다. 이러한 라이브러리를 설치하려면 Go 언어와 함께 제공되는 패키지 관리 도구인 go get을 사용할 수 있습니다.
go-sql-driver/mysql 설치:
go get -u github.com/go-sql-driver/mysql
jmoiron/sqlx 설치:
go get -u github.com/jmoiron/sqlx
- MySQL 데이터베이스에 연결
MySQL 데이터베이스에 연결하려면 데이터베이스 연결 정보 및 인증 정보를 지정해야 합니다. Go 언어를 사용하여 MySQL 데이터베이스에 연결하려면 Database/sql 및 go-sql-driver/mysql 라이브러리가 필요합니다. MySQL 데이터베이스에 연결할 때 주의할 점:
import ( "database/sql" _ "github.com/go-sql-driver/mysql" ) func main() { db, err := sql.Open("mysql", "root:123456@tcp(127.0.0.1:3306)/test?charset=utf8") if err != nil { log.Fatalln(err) } defer db.Close() // 测试连接 if err := db.Ping(); err != nil { log.Fatalln(err) } // 进行操作 // ... }
위 코드는 MySQL 데이터베이스에 대한 연결과 가장 기본적인 테스트 연결을 구현합니다.
MySQL 데이터베이스에 연결한 후 쿼리, 삽입, 업데이트 등과 같은 몇 가지 일반적인 데이터베이스 작업을 수행할 수 있습니다.
- Go 언어의 MySQL 트랜잭션
MySQL 데이터베이스에서 트랜잭션은 작업 단위로 정의된 SQL 문 집합이거나 전체적으로 실행되는 하나 이상의 문일 수 있습니다. Go 언어에서는 Begin, Commit 및 Rollback 함수를 사용하여 트랜잭션을 구현할 수 있습니다.
func transactionTx() error { tx, err := db.Begin() if err != nil { return err } defer func() { if p := recover(); p != nil { tx.Rollback() // 捕获错误回滚 } }() stmt, err := tx.Prepare("INSERT INTO users(name, age) VALUES(?, ?)") if err != nil { return err } defer stmt.Close() _, err = stmt.Exec("user1", 20) if err != nil { return err } _, err = stmt.Exec("user2", 21) if err != nil { return err } err = tx.Commit() if err != nil { return err } return nil }
- sqlx를 사용하여 MySQL 운영
Go 언어의 SQL 문에서 특정 매개변수 값을 바꾸려면 "?"를 사용하세요. 이는 일부 복잡한 SQL 문을 실행하는 것이 불편할 수 있다는 것입니다. 따라서 sqlx 라이브러리를 이용하여 MySQL을 실행함으로써 데이터베이스를 보다 직관적이고 유연하게 운영할 수 있다.
sqlx는 SQL 문을 수동으로 준비할 필요가 없습니다. SQL 문과 바인딩된 매개 변수를 설명하기 위해 구조와 구조 필드를 사용합니다. 예를 들면 다음과 같습니다.
type User struct { ID int64 `db:"id"` Name string `db:"name"` Age int `db:"age"` } user := &User{Name: "Alice", Age: 25} tx := db.MustBegin() tx.NamedExec("INSERT INTO users (name, age) VALUES (:name, :age)", user) tx.Commit()
위 코드는 sqlx의 NamedExec 함수를 사용하여 MySQL을 작동하는데, 여기서 ":name"과 ":age"는 바인딩된 매개변수의 이름이고 user는 구조체로 표현되는 매개변수입니다.
- MySQL 개발에 ORM 프레임워크 사용
ORM(Object Relational Mapping) 프레임워크를 사용하면 데이터베이스를 보다 편리하게 운영 및 관리할 수 있으며 SQL 문을 수동으로 작성하는 작업을 줄일 수 있습니다. Go 언어에서 가장 널리 사용되는 ORM 프레임워크는 GORM입니다.
GORM을 사용하여 MySQL 작업을 수행하는 것은 매우 간단합니다. 다음은 사용자 테이블을 생성하는 예입니다. 코드는 다음과 같습니다.
import ( "github.com/jinzhu/gorm" _ "github.com/jinzhu/gorm/dialects/mysql" ) type User struct { gorm.Model Name string Age int } func main() { db, err := gorm.Open("mysql", "root:123456@/test?charset=utf8&parseTime=True&loc=Local") if err != nil { panic(err) } defer db.Close() db.AutoMigrate(&User{}) // 自动创建user表 // 添加新用户 db.Create(&User{Name: "Alice", Age: 25}) // 查询用户信息 var user User db.Where("name = ?", "Alice").First(&user) fmt.Println(user) }
데이터베이스에서 사용자 테이블을 나타내기 위해 사용자 구조만 정의하면 됩니다. 데이터베이스 테이블을 코드에서 자동으로 생성하고, 새로운 사용자를 추가하고, 사용자 정보를 쿼리할 수 있습니다.
요약
이 글에서는 Go 언어를 사용하여 MySQL 데이터베이스를 효율적으로 개발하고 관리하는 방법을 소개합니다. 먼저 MySQL 데이터베이스, Go 언어 및 관련 라이브러리를 설치해야 합니다. 둘째, MySQL에 연결하여 기본 데이터베이스 작업을 수행합니다. 마지막으로 MySQL 개발을 위한 sqlx 및 ORM 프레임워크를 사용하는 구체적인 작업을 소개합니다. 이 글이 MySQL 개발을 위해 Go 언어를 사용하려는 학생들에게 도움과 지침이 되기를 바랍니다.
위 내용은 중소기업을 위한 MySQL 데이터베이스: Go 언어를 사용한 신속한 개발의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











MySQL 데이터베이스에서 사용자와 데이터베이스 간의 관계는 권한과 테이블로 정의됩니다. 사용자는 데이터베이스에 액세스 할 수있는 사용자 이름과 비밀번호가 있습니다. 권한은 보조금 명령을 통해 부여되며 테이블은 Create Table 명령에 의해 생성됩니다. 사용자와 데이터베이스 간의 관계를 설정하려면 데이터베이스를 작성하고 사용자를 생성 한 다음 권한을 부여해야합니다.

MySQL은 설치가 간단하고 강력하며 데이터를 쉽게 관리하기 쉽기 때문에 초보자에게 적합합니다. 1. 다양한 운영 체제에 적합한 간단한 설치 및 구성. 2. 데이터베이스 및 테이블 작성, 삽입, 쿼리, 업데이트 및 삭제와 같은 기본 작업을 지원합니다. 3. 조인 작업 및 하위 쿼리와 같은 고급 기능을 제공합니다. 4. 인덱싱, 쿼리 최적화 및 테이블 파티셔닝을 통해 성능을 향상시킬 수 있습니다. 5. 데이터 보안 및 일관성을 보장하기위한 지원 백업, 복구 및 보안 조치.

Navicat 자체는 데이터베이스 비밀번호를 저장하지 않으며 암호화 된 암호 만 검색 할 수 있습니다. 솔루션 : 1. 비밀번호 관리자를 확인하십시오. 2. Navicat의 "비밀번호 기억"기능을 확인하십시오. 3. 데이터베이스 비밀번호를 재설정합니다. 4. 데이터베이스 관리자에게 문의하십시오.

Navicat Premium을 사용하여 데이터베이스 생성 : 데이터베이스 서버에 연결하고 연결 매개 변수를 입력하십시오. 서버를 마우스 오른쪽 버튼으로 클릭하고 데이터베이스 생성을 선택하십시오. 새 데이터베이스의 이름과 지정된 문자 세트 및 Collation의 이름을 입력하십시오. 새 데이터베이스에 연결하고 객체 브라우저에서 테이블을 만듭니다. 테이블을 마우스 오른쪽 버튼으로 클릭하고 데이터 삽입을 선택하여 데이터를 삽입하십시오.

다음 명령으로 MySQL 데이터베이스를보십시오. 서버에 연결하십시오. mysql -u username -p password run show database; 기존의 모든 데이터베이스를 가져 오려는 명령 데이터베이스 선택 : 데이터베이스 이름 사용; 보기 테이블 : 테이블 표시; 테이블 구조보기 : 테이블 이름을 설명합니다. 데이터보기 : 테이블 이름에서 *를 선택하십시오.

MySQL에서 테이블을 복사하려면 새 테이블을 만들고, 데이터를 삽입하고, 외래 키 설정, 인덱스 복사, 트리거, 저장된 절차 및 기능이 필요합니다. 특정 단계에는 다음이 포함됩니다 : 동일한 구조를 가진 새 테이블 작성. 원래 테이블의 데이터를 새 테이블에 삽입하십시오. 동일한 외래 키 제약 조건을 설정하십시오 (원래 테이블에 하나가있는 경우). 동일한 색인을 만듭니다. 동일한 트리거를 만듭니다 (원래 테이블에 하나가있는 경우). 동일한 저장된 절차 또는 기능을 만듭니다 (원래 테이블이 사용되는 경우).

MariaDB 용 Navicat은 암호가 암호화 된 양식으로 저장되므로 데이터베이스 비밀번호를 직접 볼 수 없습니다. 데이터베이스 보안을 보장하려면 비밀번호를 재설정하는 세 가지 방법이 있습니다. Navicat을 통해 비밀번호를 재설정하고 복잡한 비밀번호를 설정하십시오. 구성 파일을 봅니다 (권장되지 않음, 위험이 높음). 시스템 명령 줄 도구를 사용하십시오 (권장되지 않으면 명령 줄 도구에 능숙해야 함).

MySQL에서 복사 및 붙여 넣기 단계는 다음 단계가 포함됩니다. 데이터를 선택하고 CTRL C (Windows) 또는 CMD C (MAC)로 복사; 대상 위치를 마우스 오른쪽 버튼으로 클릭하고 페이스트를 선택하거나 Ctrl V (Windows) 또는 CMD V (Mac)를 사용하십시오. 복사 된 데이터는 대상 위치에 삽입되거나 기존 데이터를 교체합니다 (데이터가 이미 대상 위치에 존재하는지 여부에 따라).
