Mysql
 sql >> Database >  >> RDS >> Mysql

Conta il numero di righe in Golang

La query restituirà una riga nel conteggio delle variabili. Quindi la prossima cosa che devi fare è leggere questa riga e assegnare il risultato in una nuova variabile, usando la funzione Scan() . Ecco come funziona.

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)

L'opzione migliore sarebbe usare QueryRow() come ti aspetti di leggere solo una riga. Il codice allora sarà.

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)
}