이 튜토리얼의 운영 환경: 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!