Inicio rápido: Uso del lenguaje Go para conectarse y consultar datos en Azure Database for MySQL
SE APLICA A: Azure Database for MySQL: servidor flexible
En este tutorial rápido se muestra cómo conectarse a una instancia de Azure Database for MySQL mediante código escrito en el lenguaje Go desde las plataformas Windows, Ubuntu Linux y macOS de Apple. Se indica cómo usar instrucciones SQL para consultar, insertar, actualizar y eliminar datos en la base de datos. En este artículo se da por hecho que está familiarizado con el desarrollo mediante Go, pero que nunca ha usado Azure Database for MySQL.
Prerrequisitos
En este tutorial rápido se usan como punto de partida los recursos creados en una de estas guías:
- Crear una instancia de servidor flexible de Azure Database for MySQL mediante Azure Portal
- Crear una instancia de servidor flexible de Azure Database for MySQL mediante la CLI de Azure
Importante
Se recomienda usar un servidor con acceso público (direcciones IP permitidas) habilitada para este inicio rápido. El uso de un servidor con acceso privado (integración con red virtual) habilitado para completar este inicio rápido podría implicar pasos adicionales que no están cubiertos.
Asegúrese de que a la dirección IP desde la que se conecta se le han agregado las reglas de firewall del servidor desde Azure Portal o la CLI de Azure
Instalación de Go y el conector de MySQL
Instale Go y go-sql-driver for MySQL en su propio equipo. Dependiendo de la plataforma, siga estos pasos de la sección que proceda:
Descargue e instale Go para Microsoft Windows de acuerdo con las instrucciones de instalación.
En el menú Inicio, inicie el símbolo del sistema.
Cree una carpeta para su proyecto, como
mkdir %USERPROFILE%\go\src\mysqlgo
.Cambie el directorio a la carpeta de proyecto, por ejemplo
cd %USERPROFILE%\go\src\mysqlgo
.Establezca la variable de entorno para GOPATH con el fin de que apunte al directorio de código fuente:
set GOPATH=%USERPROFILE%\go
.Ejecute go mod init para crear un módulo en el directorio actual. Por ejemplo:
go mod init mysqlgo
.- El parámetro
<module_path>
suele ser una ubicación en un repositorio de GitHub, comogithub.com/<your_github_account_name>/<directory>
. - Al crear una aplicación de línea de comandos como prueba, si no va a publicar la aplicación, no es necesario que
<module_path>
haga referencia a una ubicación real. Por ejemplo,mysqlgo
.
- El parámetro
Instale go-sql-driver for mysql mediante la ejecución del comando
go get github.com/go-sql-driver/mysql
.En resumen, instale Go y después ejecute estos comandos en el símbolo del sistema:
mkdir %USERPROFILE%\go\src\mysqlgo cd %USERPROFILE%\go\src\mysqlgo set GOPATH=%USERPROFILE%\go go mod init mysqlgo go get github.com/go-sql-driver/mysql
Obtención de información sobre la conexión
Obtenga la información de conexión necesaria para conectarse a Azure Database for MySQL. Necesitará el nombre completo del servidor y las credenciales de inicio de sesión.
- Inicie sesión en Azure Portal.
- En el menú izquierdo de Azure Portal, haga clic en Todos los recursos y, luego, busque el servidor que ha creado, por ejemplo, mydemoserver.
- Haga clic en el nombre del servidor.
- En el panel Información general del servidor, anote el nombre del servidor y el nombre de inicio de sesión del administrador del servidor. Si olvida la contraseña, puede restablecerla en este panel.
Compilación y ejecución del código de Go
- Para escribir código Golang, utilice un editor de texto simple, como el Bloc de notas en Microsoft Windows, vi o Nano en Ubuntu, o TextEdit en macOS. Si prefiere un entorno de desarrollo integrado (IDE) más enriquecido, pruebe Gogland de Jetbrains, Visual Studio Code de Microsoft o Atom.
- Pegue el código de Go de las secciones siguientes en archivos de texto y guárdelos en la carpeta del proyecto con la extensión de archivo *.go, como la ruta de acceso de Windows
%USERPROFILE%\go\src\mysqlgo\createtable.go
o la de Linux~/go/src/mysqlgo/createtable.go
. - Busque las constantes
host
,database
,user
ypassword
en el código y reemplace los valores de ejemplo con los suyos propios. Se crea una base de datos denominada flexibleserverdb cuando crea su instancia de servidor de Azure Database for MySQL. Puede usar esa base de datos u otra que haya creado. - Inicie el símbolo del sistema o el shell de Bash. Cambie el directorio a la carpeta de proyecto. Por ejemplo, en Windows
cd %USERPROFILE%\go\src\mysqlgo\
. En Linuxcd ~/go/src/mysqlgo/
. Algunos de los editores de IDE mencionados ofrecen funcionalidades de depuración y de tiempo de ejecución sin necesidad de comandos de shell. - Ejecute el código escribiendo el comando
go run createtable.go
para compilar la aplicación y ejecútela. - Además, para compilar el código en una aplicación nativa,
go build createtable.go
, iniciecreatetable.exe
para ejecutar la aplicación.
Conexión, creación de una tabla e inserción de datos
Use el código siguiente para conectarse al servidor, crear una tabla y cargar los datos mediante una instrucción SQL INSERT.
El código importa tres paquetes: el paquete sql, el paquete go sql driver for mysql como controlador para la comunicación con Azure Database for MySQL y el paquete fmt para la entrada y salida impresas en la línea de comandos.
El código llama al método sql.Open() para conectarse a Azure Database for MySQL y comprueba la conexión mediante el método db.Ping(). Durante todo el proceso se usa un identificador de base de datos, que contiene el grupo de conexiones del servidor de base de datos. El código llama al método Exec() varias veces para ejecutar varios comandos DDL. El código también usa los métodos Prepare() y Exec() para ejecutar instrucciones preparadas con diferentes parámetros para insertar tres filas. En cada una de las veces se usa un método checkError() personalizado para comprobar si se ha producido un error y, en caso afirmativo, avisa para salir.
Reemplace las constantes host
, database
, user
y password
por sus propios valores.
package main
import (
"database/sql"
"fmt"
_ "github.com/go-sql-driver/mysql"
)
const (
host = "mydemoserver.mysql.database.azure.com"
database = "flexibleserverdb"
user = "myadmin"
password = "yourpassword"
)
func checkError(err error) {
if err != nil {
panic(err)
}
}
func main() {
// Initialize connection string.
var connectionString = fmt.Sprintf("%s:%s@tcp(%s:3306)/%s?allowNativePasswords=true&tls=true", user, password, host, database)
// Initialize connection object.
db, err := sql.Open("mysql", connectionString)
checkError(err)
defer db.Close()
err = db.Ping()
checkError(err)
fmt.Println("Successfully created connection to database.")
// Drop previous table of same name if one exists.
_, err = db.Exec("DROP TABLE IF EXISTS inventory;")
checkError(err)
fmt.Println("Finished dropping table (if existed).")
// Create table.
_, err = db.Exec("CREATE TABLE inventory (id serial PRIMARY KEY, name VARCHAR(50), quantity INTEGER);")
checkError(err)
fmt.Println("Finished creating table.")
// Insert some data into table.
sqlStatement, err := db.Prepare("INSERT INTO inventory (name, quantity) VALUES (?, ?);")
res, err := sqlStatement.Exec("banana", 150)
checkError(err)
rowCount, err := res.RowsAffected()
fmt.Printf("Inserted %d row(s) of data.\n", rowCount)
res, err = sqlStatement.Exec("orange", 154)
checkError(err)
rowCount, err = res.RowsAffected()
fmt.Printf("Inserted %d row(s) of data.\n", rowCount)
res, err = sqlStatement.Exec("apple", 100)
checkError(err)
rowCount, err = res.RowsAffected()
fmt.Printf("Inserted %d row(s) of data.\n", rowCount)
fmt.Println("Done.")
}
Lectura de datos
Use el código siguiente para conectarse y leer los datos mediante la instrucción SQL SELECT.
El código importa tres paquetes: el paquete sql, el paquete go sql driver for mysql como controlador para la comunicación con Azure Database for MySQL y el paquete fmt para la entrada y salida impresas en la línea de comandos.
El código llama al método sql.Open() para conectarse a Azure Database for MySQL y comprueba la conexión mediante el método db.Ping(). Durante todo el proceso se usa un identificador de base de datos, que contiene el grupo de conexiones del servidor de base de datos. El código llama al método Query() para ejecutar el comando select. A continuación, ejecuta Next() para recorrer en iteración el conjunto de resultados y Scan() para analizar los valores de columna y guardar el valor en variables. En cada una de las veces se usa un método checkError() personalizado para comprobar si se ha producido un error y, en caso afirmativo, avisa para salir.
Reemplace las constantes host
, database
, user
y password
por sus propios valores.
package main
import (
"database/sql"
"fmt"
_ "github.com/go-sql-driver/mysql"
)
const (
host = "mydemoserver.mysql.database.azure.com"
database = "flexibleserverdb"
user = "myadmin"
password = "yourpassword"
)
func checkError(err error) {
if err != nil {
panic(err)
}
}
func main() {
// Initialize connection string.
var connectionString = fmt.Sprintf("%s:%s@tcp(%s:3306)/%s?allowNativePasswords=true&tls=true", user, password, host, database)
// Initialize connection object.
db, err := sql.Open("mysql", connectionString)
checkError(err)
defer db.Close()
err = db.Ping()
checkError(err)
fmt.Println("Successfully created connection to database.")
// Variables for printing column data when scanned.
var (
id int
name string
quantity int
)
// Read some data from the table.
rows, err := db.Query("SELECT id, name, quantity from inventory;")
checkError(err)
defer rows.Close()
fmt.Println("Reading data:")
for rows.Next() {
err := rows.Scan(&id, &name, &quantity)
checkError(err)
fmt.Printf("Data row = (%d, %s, %d)\n", id, name, quantity)
}
err = rows.Err()
checkError(err)
fmt.Println("Done.")
}
Actualización de datos
Use el código siguiente para conectarse y actualizar los datos mediante la instrucción SQL UPDATE.
El código importa tres paquetes: el paquete sql, el paquete go sql driver for mysql como controlador para la comunicación con Azure Database for MySQL y el paquete fmt para la entrada y salida impresas en la línea de comandos.
El código llama al método sql.Open() para conectarse a Azure Database for MySQL y comprueba la conexión mediante el método db.Ping(). Durante todo el proceso se usa un identificador de base de datos, que contiene el grupo de conexiones del servidor de base de datos. El código llama al método Exec() para ejecutar el comando update. En cada una de las veces se usa un método checkError() personalizado para comprobar si se ha producido un error y, en caso afirmativo, avisa para salir.
Reemplace las constantes host
, database
, user
y password
por sus propios valores.
package main
import (
"database/sql"
"fmt"
_ "github.com/go-sql-driver/mysql"
)
const (
host = "mydemoserver.mysql.database.azure.com"
database = "flexibleserverdb"
user = "myadmin"
password = "yourpassword"
)
func checkError(err error) {
if err != nil {
panic(err)
}
}
func main() {
// Initialize connection string.
var connectionString = fmt.Sprintf("%s:%s@tcp(%s:3306)/%s?allowNativePasswords=true&tls=true", user, password, host, database)
// Initialize connection object.
db, err := sql.Open("mysql", connectionString)
checkError(err)
defer db.Close()
err = db.Ping()
checkError(err)
fmt.Println("Successfully created connection to database.")
// Modify some data in table.
rows, err := db.Exec("UPDATE inventory SET quantity = ? WHERE name = ?", 200, "banana")
checkError(err)
rowCount, err := rows.RowsAffected()
fmt.Printf("Updated %d row(s) of data.\n", rowCount)
fmt.Println("Done.")
}
Eliminación de datos
Use el código siguiente para conectarse y eliminar datos mediante la instrucción SQL DELETE.
El código importa tres paquetes: el paquete sql, el paquete go sql driver for mysql como controlador para la comunicación con Azure Database for MySQL y el paquete fmt para la entrada y salida impresas en la línea de comandos.
El código llama al método sql.Open() para conectarse a Azure Database for MySQL y comprueba la conexión mediante el método db.Ping(). Durante todo el proceso se usa un identificador de base de datos, que contiene el grupo de conexiones del servidor de base de datos. El código llama al método Exec() para ejecutar el comando delete. En cada una de las veces se usa un método checkError() personalizado para comprobar si se ha producido un error y, en caso afirmativo, avisa para salir.
Reemplace las constantes host
, database
, user
y password
por sus propios valores.
package main
import (
"database/sql"
"fmt"
_ "github.com/go-sql-driver/mysql"
)
const (
host = "mydemoserver.mysql.database.azure.com"
database = "flexibleserverdb"
user = "myadmin"
password = "yourpassword"
)
func checkError(err error) {
if err != nil {
panic(err)
}
}
func main() {
// Initialize connection string.
var connectionString = fmt.Sprintf("%s:%s@tcp(%s:3306)/%s?allowNativePasswords=true&tls=true", user, password, host, database)
// Initialize connection object.
db, err := sql.Open("mysql", connectionString)
checkError(err)
defer db.Close()
err = db.Ping()
checkError(err)
fmt.Println("Successfully created connection to database.")
// Modify some data in table.
rows, err := db.Exec("DELETE FROM inventory WHERE name = ?", "orange")
checkError(err)
rowCount, err := rows.RowsAffected()
fmt.Printf("Deleted %d row(s) of data.\n", rowCount)
fmt.Println("Done.")
}
Limpieza de recursos
Para limpiar todos los recursos utilizados durante esta guía de inicio rápido, elimine el grupo de recursos con el siguiente comando:
az group delete \
--name $AZ_RESOURCE_GROUP \
--yes