diff options
author | Matthew Lemon <matt@matthewlemon.com> | 2020-08-06 15:40:00 +0100 |
---|---|---|
committer | Matthew Lemon <matt@matthewlemon.com> | 2020-08-06 15:40:00 +0100 |
commit | a19f1c7ad36d469f6749733525ab50b6550e6bdc (patch) | |
tree | 50fa3d2f4b743d33fef271ff2289d1345f4dd7c8 /pkg/datamaps/db.go | |
parent | 0bb7c2b3ac9f8bbc148c3fbfca59fe9f600babf6 (diff) |
improved error handling
Diffstat (limited to 'pkg/datamaps/db.go')
-rw-r--r-- | pkg/datamaps/db.go | 16 |
1 files changed, 8 insertions, 8 deletions
diff --git a/pkg/datamaps/db.go b/pkg/datamaps/db.go index 2a63a11..296b1b2 100644 --- a/pkg/datamaps/db.go +++ b/pkg/datamaps/db.go @@ -183,7 +183,7 @@ func importXLSXtoDB(dmName string, returnName string, file string, db *sql.DB) e // If there is already a return with a matching name, use that. rtnQuery, err := db.Prepare("select id from return where (return.name=?)") if err != nil { - log.Fatal(err) + fmt.Errorf("cannot create a query to get the return - %v", err) } defer rtnQuery.Close() @@ -196,7 +196,7 @@ func importXLSXtoDB(dmName string, returnName string, file string, db *sql.DB) e if retID == 0 { stmtReturn, err := db.Prepare("insert into return(name, date_created) values(?,?)") if err != nil { - log.Fatal(err) + fmt.Errorf("cannot prepare a statement to create a new return - %v", err) } defer stmtReturn.Close() @@ -209,14 +209,14 @@ func importXLSXtoDB(dmName string, returnName string, file string, db *sql.DB) e retID, err = res.LastInsertId() if err != nil { - log.Fatal(err) + fmt.Errorf("cannot get id of return - %v", err) } } // We're going to need a transaction for the big stuff tx, err := db.Begin() if err != nil { - return err + fmt.Errorf("cannot start a database transaction - %v", err) } for sheetName, sheetData := range d { @@ -225,7 +225,7 @@ func importXLSXtoDB(dmName string, returnName string, file string, db *sql.DB) e dmlQuery, err := db.Prepare("select id from datamap_line where (sheet=? and cellref=?)") if err != nil { - log.Fatal(err) + fmt.Errorf("cannot prepare a statement to get the datamap line - %v", err) } defer dmlQuery.Close() dmlIDRow := dmlQuery.QueryRow(sheetName, cellRef) @@ -239,7 +239,7 @@ func importXLSXtoDB(dmName string, returnName string, file string, db *sql.DB) e insertStmt, err := db.Prepare("insert into return_data (dml_id, ret_id, filename, value, numfmt, vFormatted) values(?,?,?,?,?,?)") if err != nil { - log.Fatal(err) + fmt.Errorf("cannot insert row into return_data - %v", err) } defer insertStmt.Close() @@ -249,12 +249,12 @@ func importXLSXtoDB(dmName string, returnName string, file string, db *sql.DB) e } fValue, err := cellData.FormattedValue() if err != nil { - return err + fmt.Errorf("cannot get the formatted value for %#v, %v", cellData, err) } _, err = insertStmt.Exec(dmlID, retID, filename, cellData.Value, cellData.NumFmt, fValue) if err != nil { - log.Fatal(err) + fmt.Errorf("cannot execute statement to insert return data - %v", err) } } } |