|
@@ -7,6 +7,7 @@ import (
|
|
|
"path/filepath"
|
|
|
|
|
|
"github.com/vladimirok5959/golang-sql/gosql"
|
|
|
+ "github.com/vladimirok5959/golang-sql/gosql/common"
|
|
|
)
|
|
|
|
|
|
func main() {
|
|
@@ -31,7 +32,7 @@ func main() {
|
|
|
}
|
|
|
|
|
|
// DB struct here ./db/migrations/20220527233113_test_migration.sql
|
|
|
- // Insert some data to users table:
|
|
|
+ // Insert some data to users table
|
|
|
if _, err := db.Exec(
|
|
|
context.Background(),
|
|
|
"INSERT INTO users (id, name) VALUES ($1, $2)",
|
|
@@ -40,10 +41,47 @@ func main() {
|
|
|
panic(fmt.Sprintf("%s", err))
|
|
|
}
|
|
|
|
|
|
- // Select all rows from users table:
|
|
|
+ // Select all rows from users table
|
|
|
if rows, err := db.Query(
|
|
|
context.Background(),
|
|
|
- "SELECT id, name FROM users ORDER BY id DESC",
|
|
|
+ "SELECT id, name FROM users ORDER BY id ASC",
|
|
|
+ ); err == nil {
|
|
|
+ type rowStruct struct {
|
|
|
+ ID int64
|
|
|
+ Name string
|
|
|
+ }
|
|
|
+ defer rows.Close()
|
|
|
+ for rows.Next() {
|
|
|
+ var row rowStruct
|
|
|
+ if err := rows.Scan(&row.ID, &row.Name); err != nil {
|
|
|
+ panic(fmt.Sprintf("%s", err))
|
|
|
+ }
|
|
|
+ fmt.Printf("ID: %d, Name: %s\n", row.ID, row.Name)
|
|
|
+ }
|
|
|
+ if err := rows.Err(); err != nil {
|
|
|
+ panic(fmt.Sprintf("%s", err))
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ panic(fmt.Sprintf("%s", err))
|
|
|
+ }
|
|
|
+
|
|
|
+ // Update inside transaction
|
|
|
+ if err := db.Transaction(context.Background(), func(ctx context.Context, tx *common.Tx) error {
|
|
|
+ if _, err := tx.Exec(ctx, "UPDATE users SET name=$1 WHERE id=$2", "John", 1); err != nil {
|
|
|
+ return err
|
|
|
+ }
|
|
|
+ if _, err := tx.Exec(ctx, "UPDATE users SET name=$1 WHERE id=$2", "Alice", 5); err != nil {
|
|
|
+ return err
|
|
|
+ }
|
|
|
+ return nil
|
|
|
+ }); err != nil {
|
|
|
+ panic(fmt.Sprintf("%s", err))
|
|
|
+ }
|
|
|
+
|
|
|
+ // Select all rows from users again
|
|
|
+ if rows, err := db.Query(
|
|
|
+ context.Background(),
|
|
|
+ "SELECT id, name FROM users ORDER BY id ASC",
|
|
|
); err == nil {
|
|
|
type rowStruct struct {
|
|
|
ID int64
|