Skip to content
This repository has been archived by the owner on Jan 5, 2022. It is now read-only.
/ ezsqlx Public archive

✨Simplify postgres in Golang with helpers for sqlx

License

Notifications You must be signed in to change notification settings

charlieparkes/ezsqlx

Repository files navigation

ezsqlx

ezsqlx is a library which provides helpers for jmoiron/sqlx. It's goal is to improve your experience without incurring the penalties of an ORM.

Features
  • Insert
  • Update
  • Connection management
  • Get database fields from a struct

Examples

Given a basic model struct, ezsqlx simplifies basic operations.

type FooBar struct {
    Id      int        `db:"id"`
    Message string     `db:"message"`
    Flip    bool       `db:"flip"`
    Created *time.Time `db:"created"`
}

Insert

Interface
Insert(
    db *sqlx.DB,
    table string,
    model interface{},
    excludedFields []string
) (*sqlx.Rows, error)
Example
newRow := &FooBar{Message: "confused unga bunga"}
rows, err := Insert(db, "foobar", newRow, []string{"id", "created"})

Update

Interface
Update(
    db *sqlx.DB,
    table string,
    model interface{},
    where string,
    excludedFields []string
) (sql.Result, error) 
Example
updatedRow := &FooBar{Id: 1, Message: "pc master race", Flip: true}
where := fmt.Sprintf("id=%v", updatedRow.Id)
_, err = Update(db, "foobar", updatedRow, where, []string{"id", "created"})

Fields

Interface
Fields(
    values interface{}
) []string
Example
fields := Fields(model)

Connections

ezsqlx.ConnectionSettings abstracts away basic Postgres connection operations. Check connections.go for a full list of helpers.

Example
cs := &ConnectionSettings{
    Host: "localhost",
    Port: "1234",
    User: "postgres",
    Password: "postgres",
    Database: "my_database"
}

db := cs.Open()
defer db.Close()

About

✨Simplify postgres in Golang with helpers for sqlx

Resources

License

Stars

Watchers

Forks

Packages

No packages published