Package structdbpostgres
is meant to map structs to PostgreSQL tables (like ORM).
Go through *_test.go
files, starting with main_test.go
to get working examples. The tests should be covering all the use cases.
Models are defined with structs as follows (take a closer look at the tags):
type User struct {
ID int `json:"user_id"`
Flags int `json:"flags"`
Name string `json:"name" 2db:"req lenmin:2 lenmax:50"`
Email string `json:"email" 2db:"req"`
Password string `json:"password"`
EmailActivationKey string `json:"email_activation_key" 2db:""`
CreatedAt int `json:"created_at"`
CreatedByUserID int `json:"created_by_user_id"`
}
type Session struct {
ID int `json:"session_id"`
Flags int `json:"flags"`
Key string `json:"key" 2db:"uniq lenmin:32 lenmax:50"`
ExpiresAt int `json:"expires_at"`
UserID int `json:"user_id" 2db:"req"`
}
type Something struct {
ID int `json:"something_id"`
Flags int `json:"flags"`
Email string `json:"email" 2db:"req"`
Age int `json:"age" 2db:"req valmin:18 valmax:130 val:18"`
Price int `json:"price" 2db:"req valmin:0 valmax:9900 val:100"`
CurrencyRate int `json:"currency_rate" 2db:"req valmin:40000 valmax:61234 val:10000"`
PostCode string `json:"post_code" 2db:"req val:32-600"`
}
Struct tags define ORM behaviour. structdbpostgres
parses tags such as 2db
and various tags starting with
2db_
. Apart from the last one, a tag define many properties which are separated with space char, and if they
contain a value other than bool (true, false), it is added after semicolon char.
See below list of all the tags with examples.
Tag | Example | Explanation |
---|---|---|
2db |
2db:"req valmin:0 valmax:130 val:18" |
Struct field properties defining its valid value for model. See Field Properties for more info |
2db_regexp |
validation_regexp:"^[0-9]{2}\\-[0-9]{3}$" |
Regular expression that struct field must match |
Possible properties in the 2db
tag are as follows.
Property | Explanation |
---|---|
req |
Field is required |
uniq |
Field has to be unique (like UNIQUE on the database column) |
valmin |
If field is numeric, this is minimal value for the field |
valmax |
If field is numeric, this is maximal value for the field |
lenmin |
If field is string, this is a minimal length of the field value |
lenmax |
If field is string, this is a maximal length of the field value |
Fields that are of string type are represented by VARCHAR(255)
database column by default. This can be overwritten with a data_type
field.
Check README of structsqlpostgres
module to view all supported values.
To perform model database actions, a Controller
object must be created. See below example that modify object(s)
in the database.
import (
stdb "github.com/mikolajgs/prototyping/pkg/struct-db-postgres"
)
// Create connection with sql
conn, _ := sql.Open("postgres", fmt.Sprintf("host=%s port=%s user=%s password=%s dbname=%s sslmode=disable", dbHost, dbPort, dbUser, dbPass, dbName))
defer conn.Close()
// Create a database controller and an instance of a struct
c := stdb.NewController(conn, "app1_", nil)
user := &User{}
err = c.CreateTable(user) // Run 'CREATE TABLE'
user.Email = "[email protected]"
user.Name = "Jane Doe"
user.CreatedAt = time.Now().Unix()
err = c.Save(user) // Insert object to database table
user.Email = "[email protected]"
err = c.Save(user) // Update object in the database table
err = c.Delete(user) // Delete object from the database table
err = c.DropTable(user) // Run 'DROP TABLE'
A different than 2db
tag can be used. See example below.
c := stdb.NewController(conn, "app1_", &stdb.ControllerConfig{
TagName: "mytag",
})