J'essaie d'insérer des données dans POSTGRES à partir d'un .csv (largeur/tabulaire pré-fixe) avec GO.
Ce que j'ai fait:
package main
import (
"bufio"
"database/sql"
"encoding/csv"
"encoding/json"
"fmt"
"io"
"log"
"os"
)
type Consumidor struct {
CPF string `json:"CPF"`
Private string `json:"Private"`
Incompleto string `json:"Incompleto"`
Compras *Compras `json:"Compras,omitempty"`
}
type Compras struct {
DataUltimacompra string `json:"DataUltimacompra"`
TicketMedio string `json:"TicketMedio"`
TicketUltimaCompra string `json:"TicketUltimaCompra"`
LojaMaisFrequente string `json:"LojaMaisFrequente"`
LojaUltimaCompra string `json:"LojaUltimaCompra"`
}
const (
Host = "localhost"
port = 5432
user = "postgres"
password = ""
dbname = "neoway"
)
func main() {
csvFile, _ := os.Open("data.csv")
reader := csv.NewReader(bufio.NewReader(csvFile))
var dadosinsert []Consumidor
for {
line, error := reader.Read()
if error == io.EOF {
break
} else if error != nil {
log.Fatal(error)
}
dadosinsert = append(dadosinsert, Consumidor{
CPF: line[0],
Private: line[1],
Incompleto: line[2],
Compras: &Compras{
DataUltimacompra: line[3],
TicketMedio: line[4],
TicketUltimaCompra: line[5],
LojaMaisFrequente: line[6],
LojaUltimaCompra: line[7],
},
})
}
peopleJson, _ := json.Marshal(dadosinsert)
fmt.Println(string(peopleJson))
psqlInfo := fmt.Sprintf("Host=%s port=%d user=%s "+
"password=%s dbname=%s sslmode=disable",
Host, port, user, password, dbname)
db, err := sql.Open("postgres", psqlInfo)
if err != nil {
panic(err)
}
defer db.Close()
sqlStatement := `
INSERT INTO base_teste (CPF,"PRIVATE","INCOMPLETO","DATA DA ÚLTIMA COMPRA","TICKET MÉDIO","TICKET DA ÚLTIMA COMPRA","LOJA MAIS FREQUÊNTE","LOJA DA ÚLTIMA COMPRA")
)
VALUES ($1, $2, $3, $4, $5, $6, 7$, 8$)
RETURNING id`
id := 0
err = db.QueryRow(sqlStatement, 30, "a", "b", "c").Scan(&id)
if err != nil {
panic(err)
}
fmt.Println("New record ID is:", id)
}
quand je cours, je reçois cette erreur
[{"CPF": "xxxxx", "Private": "TRUE", "Incompleto": "FALSE", "Compras": {"DataUltimacompra": "12/10/2018", "TicketMedio": "200" , "TicketUltimaCompra": "250", "LojaMaisFrequente": "111.111.111-99", "LojaUltimaCompra": "111.111.111-88"}}] panique: sql: pilote inconnu "postgres" (importation oubliée?)
goroutine 1 [en cours d'exécution]: main.main () C:/Users/Willian/Desktop/NEOWAY PROJECT/neoway csv prefixed width importer/main.go: 70 + 0xbed
Processus terminé avec le code de sortie 2
Vous avez importé le sql/database
, Un package contient une interface générique pour les opérations liées à SQL.
Comme il ne s'agit que d'une interface générique , vous devez importer l'implémentation concrète de l'interface, dans ce contexte, c'est le pilote de base de données.
A partir de votre code: sql.Open("postgres", psqlInfo)
, je suppose que vous utilisez la base de données postgresql. Il existe quelques pilotes postgresql pour golang disponibles, l'un d'eux est https://github.com/lib/pq driver. Ajoutez-le donc sur l'instruction d'importation.
package main
import (
"bufio"
"database/sql"
"encoding/csv"
"encoding/json"
"fmt"
"io"
"log"
"os"
_ "github.com/lib/pq" // here
)
Le pilote de base de données a été importé avec le caractère _
, Car nous n'interagissons pas directement avec le package. Related SO topic Que signifie un trait de soulignement devant une instruction d'importation? .
Plus d'informations sur golang sql: https://godoc.org/database/sql . .