백엔드 개발 Golang Go 언어가 탑재된 데이터베이스는 무엇인가요?

Go 언어가 탑재된 데이터베이스는 무엇인가요?

Dec 15, 2022 pm 06:41 PM
golang 데이터 베이스 언어로 가다

Go 언어가 탑재된 데이터베이스는 무엇인가요?

이 튜토리얼의 운영 환경: Windows 7 시스템, GO 버전 1.18, Dell G3 컴퓨터.

golang은 다양한 데이터베이스를 지원합니다

1. MySQL

MySQL은 관계형 데이터베이스 관리 시스템으로, 서로 다른 테이블에 데이터를 저장할 수 있어 데이터베이스 속도가 향상됩니다. 작은 크기, 빠른 속도, 낮은 총 소유 비용을 특징으로 하는 유연성을 제공합니다.

2. Oracle

oracle은 데이터베이스 분야에서 선도적인 위치를 차지하고 있는 관계형 데이터베이스 관리 시스템입니다. 선도적인 위치는 우수한 이식성, 사용 용이성 및 강력한 기능을 갖추고 있습니다. , 중형, 소형 및 마이크로 컴퓨터 환경은 고효율, 우수한 신뢰성 및 높은 처리량을 갖춘 데이터베이스입니다.

3. SQLite

SQLite는 ACID 관계형 데이터베이스 관리 시스템을 따르는 경량 데이터베이스입니다. SQLite는 많은 임베디드 제품에서 사용할 수 있으며 C#, PHP, Java 등과 함께 사용할 수 있습니다. 프로그래밍 언어와 결합하여.

4. MongoDB

MongoDB는 분산 파일 저장 기반의 데이터베이스입니다. 그 목적은 WEB 애플리케이션을 위한 확장 가능한 고성능 데이터 저장 솔루션을 제공하는 것입니다. MongoDB가 지원하는 데이터 구조는 매우 느슨하며 여러 쿼리 언어를 지원합니다. 그리고 인덱싱.

5. PostgreSQL

PostgreSQL은 오픈 소스 코드를 갖춘 강력한 객체 관계형 데이터베이스 관리 시스템으로, 복잡한 쿼리, 외래 키, 트리거, 보기, 트랜잭션 무결성 및 다중 버전 동시성 제어가 가능합니다. 데이터베이스 서버 측에서 명령어 프로그램을 실행하는 기능으로, 사용자가 인덱스 방식을 맞춤화할 수 있다.

6. SQL Sever

SQL Sever는 사용이 간편하고 확장성이 뛰어나며, 관련 소프트웨어와의 통합성이 높다는 장점이 있습니다. 를 사용하면 비즈니스를 위한 고가용성과 성능의 데이터 애플리케이션을 구축하고 관리할 수 있습니다.

golang은 MySQL 데이터베이스를 운영합니다

다음은 Go 언어에서 mysql의 사용을 추가, 삭제, 수정 등의 측면에서 주로 소개합니다

1 데이터베이스에 연결합니다

sql을 사용합니다. 데이터베이스 연결을 여는 Open() 함수는 데이터베이스 연결 문자열(dsn) 형식은 다음과 같습니다.

admin:123456@tcp(10.2.1.5)/irisapp
로그인 후 복사

코드는 다음과 같습니다.

func (f *mysql_db) mysql_open() {
    db, err := sql.Open("mysql", dbusername+":"+dbpassword+"@tcp("+dbhostsip+")/"+dbname)
    if err != nil {
        fmt.Println("链接失败")
    }
    fmt.Println("链接成功")
    f.db = db
}
로그인 후 복사

2.

func (f *mysql_db) mysql_insert() { //insert  添加数据
    fmt.Println("开始插入")
    stmt, err := f.db.Prepare("INSERT INTO depart(departName,memo) VALUES(?,?)")
    //defer stmt.Close()
    if err != nil {
        fmt.Println("插入失败")
        return
    }
    stmt.Exec("dd", "adadcccda")
    fmt.Println("插入成功")
}
로그인 후 복사

를 삽입합니다. 3. 쿼리

func (f *mysql_db) mysql_select(sql_data string) {   //select 查询数据
    fmt.Println("sql:", sql_data)
    rows, err := f.db.Query(sql_data)
    if err != nil {
        fmt.Println("查询失败")
    }
    for rows.Next() {
        var departID int
        var departName string
        var memo string
        err = rows.Scan(&departID, &departName, &memo)
        if err != nil {
            panic(err)
        }
        fmt.Println("departName:", departName)
    }
}
로그인 후 복사

4. 업데이트

func (f *mysql_db) mysql_update() { //update  修改数据
    stmt, err := f.db.Prepare("update depart set departName=?,memo =? where departId=?")
    //defer stmt.Close()
    if err != nil {
        //错误处理
    }
    result,_ := stmt.Exec("aa","asdfadsadsfa",1)
    if result == nil {
        fmt.Println("修改失败")
    }
    affect_count,_ := result.RowsAffected()    //返回影响的条数,注意有两个返回值
    fmt.Println("%v",affect_count)
}
로그인 후 복사

5. 삭제

func (f *mysql_db) mysql_delete() { //delete  删除数据
    stmt, err := f.db.Prepare("delete from depart where departId=?")
    //defer stmt.Close()
    if err != nil {
        //错误处理
    }
    stmt.Exec(2)     //不返回任何结果
    fmt.Println("删除成功")
}
로그인 후 복사

6. Things

func (f *mysql_db) mysql_tran(){
    //事务
    tx,err := f.db.Begin()        //声明一个事务的开始
    if err != nil {
        fmt.Println(err)
        return
    }
    insert_sql := "insert into depart (departName,memo) VALUES(?,?)"
    insert_stmt,insert_err := tx.Prepare(insert_sql)
    if insert_err != nil {
        fmt.Println(insert_err)
        return
    }
    insert_res,insert_err := insert_stmt.Exec("ff","ff")
    last_insert_id,_ := insert_res.LastInsertId()
    fmt.Println(last_insert_id)
    // defer tx.Rollback()            //回滚之前上面的last_login_id是有的,但在回滚后该操作没有被提交,被回滚了,所以上面打印的Last_login_id的这条数据是不存在与数据库表中的
    tx.Commit()                        //这里提交了上面的操作,所以上面的执行的sql 会在数据库中产生一条数据
}
로그인 후 복사

Call

func main() {
    db := &mysql_db{}
    db.mysql_open()
    db.mysql_insert()
    db.mysql_update()
    db.mysql_delete()
    db.mysql_tran()
    db.mysql_select("select departID,departName,memo from depart")
    db.mysql_close() //关闭
}
로그인 후 복사

시작 후 출력은 다음과 같습니다. 전체 코드

D:\Go_Path\go\src\mysqldemo>go run mysqldemo.go
链接成功
开始插入
插入成功
0
删除成功
10
sql: select departID,departName,memo from depart
departName: aa
departName: dd
departName: dd
departName: dd
departName: dd
departName: dd
departName: ff
departName: dd
departName: ff
로그인 후 복사

요약

1 SQL 쿼리를 최적화하여 성능을 향상하고 SQL 삽입 위험을 줄이는 데 사용할 수 있는 준비 표현식을 지원합니다. db.Prepare() 및 tx.Prepare는 모두 준비된 표현식을 지원합니다.

2.LastInsertId() 첫 번째 삽입된 항목의 ID를 가져옵니다

3.RowsAffected() 영향/삽입된 항목 수를 가져옵니다

4. Go 언어 개발에서 mysql의 기본 사용법을 간략하게 소개합니다. 실제로 실제 개발 과정에서는 여전히 ORM 관련 타사 프레임워크가 주로 사용되지만 기본 원칙은 여전히 ​​학습해야 합니다.

더 많은 Go 언어 지식을 알고 싶다면 PHP 중국어 웹사이트의

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. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. 크로스 플레이가 있습니까?
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

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

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

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

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

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

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

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를 사용할 때 많은 개발자가 사용자 정의 구조 태그를 만날 것입니다 ...

MySQL : 쉽게 학습하기위한 간단한 개념 MySQL : 쉽게 학습하기위한 간단한 개념 Apr 10, 2025 am 09:29 AM

MySQL은 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 1) 데이터베이스 및 테이블 작성 : CreateAbase 및 CreateTable 명령을 사용하십시오. 2) 기본 작업 : 삽입, 업데이트, 삭제 및 선택. 3) 고급 운영 : 가입, 하위 쿼리 및 거래 처리. 4) 디버깅 기술 : 확인, 데이터 유형 및 권한을 확인하십시오. 5) 최적화 제안 : 인덱스 사용, 선택을 피하고 거래를 사용하십시오.

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

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

다중 프로세스 로그를 작성할 때 동시성이 안전하고 효율적인지 확인하는 방법은 무엇입니까? 다중 프로세스 로그를 작성할 때 동시성이 안전하고 효율적인지 확인하는 방법은 무엇입니까? Apr 02, 2025 pm 03:51 PM

다중 프로세스 로그 쓰기에서 동시성 보안 문제를 효율적으로 처리합니다. 여러 프로세스는 동시에 동일한 로그 파일을 작성합니다. 동시성을 안전하고 효율적으로 보장하는 방법은 무엇입니까? 이것은 ...

See all articles