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

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

青灯夜游
青灯夜游원래의
2022-12-15 18:41:137074검색

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으로 문의하세요.