sql >> Base de Datos >  >> RDS >> Mysql

Contar el número de filas en golang

La consulta devolverá una fila en la variable conteo. Entonces, lo siguiente que debe hacer es leer esta fila y asignar el resultado a una nueva variable, usando la función Scan() . Así es como funciona.

rows, err := db.Query("SELECT COUNT(*) FROM main_table")
if err != nil {
    log.Fatal(err)
}
defer rows.Close()

var count int

for rows.Next() {   
    if err := rows.Scan(&count); err != nil {
        log.Fatal(err)
    }
}

fmt.Printf("Number of rows are %s\n", count)

La mejor opción sería usar QueryRow() como esperas leer solo una fila. El código entonces será.

var count int

err := db.QueryRow("SELECT COUNT(*) FROM main_table").Scan(&count)
switch {    
case err != nil:
    log.Fatal(err)
default:
    fmt.Printf("Number of rows are %s\n", count)
}