Categorygithub.com/gui774ume/pg
modulepackage
8.0.7+incompatible
Repository: https://github.com/gui774ume/pg.git
Documentation: pkg.go.dev

# README

PostgreSQL client and ORM for Golang

Build Status GoDoc

Features:

Get Started

go get -u github.com/go-pg/pg

Look & Feel

package pg_test

import (
    "fmt"

    "github.com/go-pg/pg"
    "github.com/go-pg/pg/orm"
)

type User struct {
    Id     int64
    Name   string
    Emails []string
}

func (u User) String() string {
    return fmt.Sprintf("User<%d %s %v>", u.Id, u.Name, u.Emails)
}

type Story struct {
    Id       int64
    Title    string
    AuthorId int64
    Author   *User
}

func (s Story) String() string {
    return fmt.Sprintf("Story<%d %s %s>", s.Id, s.Title, s.Author)
}

func ExampleDB_Model() {
    db := pg.Connect(&pg.Options{
        User: "postgres",
    })
    defer db.Close()

    err := createSchema(db)
    if err != nil {
        panic(err)
    }

    user1 := &User{
        Name:   "admin",
        Emails: []string{"admin1@admin", "admin2@admin"},
    }
    err = db.Insert(user1)
    if err != nil {
        panic(err)
    }

    err = db.Insert(&User{
        Name:   "root",
        Emails: []string{"root1@root", "root2@root"},
    })
    if err != nil {
        panic(err)
    }

    story1 := &Story{
        Title:    "Cool story",
        AuthorId: user1.Id,
    }
    err = db.Insert(story1)
    if err != nil {
        panic(err)
    }

    // Select user by primary key.
    user := &User{Id: user1.Id}
    err = db.Select(user)
    if err != nil {
        panic(err)
    }

    // Select all users.
    var users []User
    err = db.Model(&users).Select()
    if err != nil {
        panic(err)
    }

    // Select story and associated author in one query.
    story := new(Story)
    err = db.Model(story).
        Relation("Author").
        Where("story.id = ?", story1.Id).
        Select()
    if err != nil {
        panic(err)
    }

    fmt.Println(user)
    fmt.Println(users)
    fmt.Println(story)
    // Output: User<1 admin [admin1@admin admin2@admin]>
    // [User<1 admin [admin1@admin admin2@admin]> User<2 root [root1@root root2@root]>]
    // Story<1 Cool story User<1 admin [admin1@admin admin2@admin]>>
}

func createSchema(db *pg.DB) error {
    for _, model := range []interface{}{(*User)(nil), (*Story)(nil)} {
        err := db.CreateTable(model, &orm.CreateTableOptions{
            Temp: true,
        })
        if err != nil {
            return err
        }
    }
    return nil
}

See also

# Packages

No description provided by the author
No description provided by the author
No description provided by the author

# Functions

Array accepts a slice and returns a wrapper for working with PostgreSQL array data type.
Connect connects to a database using provided options.
F quotes a SQL identifier such as a table or column name replacing any placeholders found in the field.
Hstore accepts a map and returns a wrapper for working with hstore data type.
In accepts a slice and returns a wrapper that can be used with PostgreSQL IN operator: Where("id IN (?)", pg.In([]int{1, 2, 3, 4})) produces WHERE id IN (1, 2, 3, 4).
InMulti accepts multiple values and returns a wrapper that can be used with PostgreSQL IN operator: Where("(id1, id2) IN (?)", pg.InMulti([]int{1, 2}, []int{3, 4})) produces WHERE (id1, id2) IN ((1, 2), (3, 4)).
Model returns new query for the optional model.
No description provided by the author
ParseURL parses an URL into options that can be used to connect to PostgreSQL.
Q replaces any placeholders found in the query.
Scan returns ColumnScanner that copies the columns in the row into the values.
No description provided by the author

# Variables

Discard is used with Query and QueryOne to discard rows.
ErrMultiRows is returned by QueryOne and ExecOne when query returned multiple rows but exactly one row is expected.
ErrNoRows is returned by QueryOne and ExecOne when query returned zero rows but at least one row is expected.

# Structs

Conn represents a single database connection rather than a pool of database connections.
DB is a database handle representing a pool of zero or more underlying connections.
Listener listens for notifications sent with NOTIFY command.
Notification which is received with LISTEN command.
Database connection options.
No description provided by the author
Stmt is a prepared statement.
Tx is an in-progress database transaction.

# Interfaces

Error represents an error returned by PostgreSQL server using PostgreSQL ErrorResponse protocol.
No description provided by the author

# Type aliases

No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author
No description provided by the author