Aula 03 - Golang - Fiber - Banco de Dados MySQL
Nessa aula iremos criar o banco de dados e conectar usando gorm.
Se você não tiver o
mysql instalado no seu sistema, instale o
mysql workbench, segue o link:
Depois de instalado,
crie um
esquema para ser usado no
app.
Execute o seguinte comando
SQL, ou clique no
icone parecido com um
barril na interface gráfica do
mysql workbench.
CREATE SCHEMA `fluent_admin`;
Criamos com o comando acima, o esquema chamado
go_admin.
Instalação do Gorm
Agora vamos instalar o
gorm no projeto.
Ele vai nos ajudar na conexão com o
MySQL.
Para instalar, execute:
go get -u gorm.io/gorm
Agora instale o driver do
mysql.
go get -u gorm.io/driver/mysql
Em
Go não temos
try catch, e as
funções podem retornar múltiplos valores.
Esse recurso é explorado em
Go para
tratar eventuais
erros, por exemplo, o banco de dados pode tá fora do ar, e aí então uma função responsável por conectar ao banco vai retornar um erro na variável
err, ao invés de conexão bem sucedida.
Nesse caso a variável
db vai ter o valor
nil e
err tem um valor diferente de
nil.
Caso o banco esteja disponível e o
app conecte sem problema, será o contrário,
err vai ter
nil e
db um valor diferente de
nil, na verdade um ponteiro.
Ou seja,
err sempre vai receber um valor, ou
nil ou um valor diferente de
nil.
É por isso que temos ele na função
Get:
app.Get("/", func(c *fiber.Ctx) error { ...
Na string de conexão com o banco temos:
O
user em
lilás, o
password em
vermelho e o
banco em
verde.
Agora altere o
src/main.go para ficar assim:
fiber-project/src/main.go
package main
import (
"fmt"
"github.com/gofiber/fiber/v2"
"gorm.io/driver/mysql"
"gorm.io/gorm"
)
func main() {
var dsn = "root:mysql1234@/fluent_admin?charset=utf8mb4&parseTime=True&loc=Local"
var v = "Não conseguiu conectar ao banco de dados"
db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
if err != nil {
panic(v)
}
fmt.Println("conexão OK!")
fmt.Println(db)
app := fiber.New()
app.Get("/", home)
app.Listen(":3000")
}
func home(c *fiber.Ctx) error {
return c.SendString("Hello, World 👋!")
}
E para testar se conectou ao banco sem problema, execute:
go run main.go
Saída de sucesso será algo tipo:
Conexão OK!
&{0xc00029a2d0 0 0xc00035c000 1}
Ou se não consegui conectar ao banco mostrará a mensagem de erro:
Não conseguiu conectar ao banco de dados
Por agora é só, nos vemos na próxima, até lá!
Código da aula: Github
Se gostarem do conteúdo dêem um joinha 👍 na página do Código Fluente no
Facebook
Link do código fluente no Pinterest
Novamente deixo meus link de afiliados:
Obrigado, até a próxima e bons estudos. ;)