찾다
백엔드 개발GolangGo 언어가 탑재된 데이터베이스는 무엇인가요?
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으로 문의하세요.
go语言有没有缩进go语言有没有缩进Dec 01, 2022 pm 06:54 PM

go语言有缩进。在go语言中,缩进直接使用gofmt工具格式化即可(gofmt使用tab进行缩进);gofmt工具会以标准样式的缩进和垂直对齐方式对源代码进行格式化,甚至必要情况下注释也会重新格式化。

go语言为什么叫gogo语言为什么叫goNov 28, 2022 pm 06:19 PM

go语言叫go的原因:想表达这门语言的运行速度、开发速度、学习速度(develop)都像gopher一样快。gopher是一种生活在加拿大的小动物,go的吉祥物就是这个小动物,它的中文名叫做囊地鼠,它们最大的特点就是挖洞速度特别快,当然可能不止是挖洞啦。

一文详解Go中的并发【20 张动图演示】一文详解Go中的并发【20 张动图演示】Sep 08, 2022 am 10:48 AM

Go语言中各种并发模式看起来是怎样的?下面本篇文章就通过20 张动图为你演示 Go 并发,希望对大家有所帮助!

【整理分享】一些GO面试题(附答案解析)【整理分享】一些GO面试题(附答案解析)Oct 25, 2022 am 10:45 AM

本篇文章给大家整理分享一些GO面试题集锦快答,希望对大家有所帮助!

go语言是否需要编译go语言是否需要编译Dec 01, 2022 pm 07:06 PM

go语言需要编译。Go语言是编译型的静态语言,是一门需要编译才能运行的编程语言,也就说Go语言程序在运行之前需要通过编译器生成二进制机器码(二进制的可执行文件),随后二进制文件才能在目标机器上运行。

tidb是go语言么tidb是go语言么Dec 02, 2022 pm 06:24 PM

是,TiDB采用go语言编写。TiDB是一个分布式NewSQL数据库;它支持水平弹性扩展、ACID事务、标准SQL、MySQL语法和MySQL协议,具有数据强一致的高可用特性。TiDB架构中的PD储存了集群的元信息,如key在哪个TiKV节点;PD还负责集群的负载均衡以及数据分片等。PD通过内嵌etcd来支持数据分布和容错;PD采用go语言编写。

go语言能不能编译go语言能不能编译Dec 09, 2022 pm 06:20 PM

go语言能编译。Go语言是编译型的静态语言,是一门需要编译才能运行的编程语言。对Go语言程序进行编译的命令有两种:1、“go build”命令,可以将Go语言程序代码编译成二进制的可执行文件,但该二进制文件需要手动运行;2、“go run”命令,会在编译后直接运行Go语言程序,编译过程中会产生一个临时文件,但不会生成可执行文件。

golang map怎么删除元素golang map怎么删除元素Dec 08, 2022 pm 06:26 PM

删除map元素的两种方法:1、使用delete()函数从map中删除指定键值对,语法“delete(map, 键名)”;2、重新创建一个新的map对象,可以清空map中的所有元素,语法“var mapname map[keytype]valuetype”。

See all articles

핫 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. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전