mirror of https://github.com/jackc/pgx.git
Document interfaces that may have methods added in the future
parent
143bc3165d
commit
15ea38aae5
10
rows.go
10
rows.go
|
@ -16,6 +16,11 @@ import (
|
||||||
// Rows is the result set returned from *Conn.Query. Rows must be closed before
|
// Rows is the result set returned from *Conn.Query. Rows must be closed before
|
||||||
// the *Conn can be used again. Rows are closed by explicitly calling Close(),
|
// the *Conn can be used again. Rows are closed by explicitly calling Close(),
|
||||||
// calling Next() until it returns false, or when a fatal error occurs.
|
// calling Next() until it returns false, or when a fatal error occurs.
|
||||||
|
//
|
||||||
|
// Rows is an interface instead of a struct to allow tests to mock Query. However,
|
||||||
|
// adding a method to an interface is technically a breaking change. Because of this
|
||||||
|
// the Rows interface is partially excluded from semantic version requirements.
|
||||||
|
// Methods will not be removed or changed, but new methods may be added.
|
||||||
type Rows interface {
|
type Rows interface {
|
||||||
// Close closes the rows, making the connection ready for use again. It is safe
|
// Close closes the rows, making the connection ready for use again. It is safe
|
||||||
// to call Close after rows is already closed.
|
// to call Close after rows is already closed.
|
||||||
|
@ -49,6 +54,11 @@ type Rows interface {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Row is a convenience wrapper over Rows that is returned by QueryRow.
|
// Row is a convenience wrapper over Rows that is returned by QueryRow.
|
||||||
|
//
|
||||||
|
// Row is an interface instead of a struct to allow tests to mock QueryRow. However,
|
||||||
|
// adding a method to an interface is technically a breaking change. Because of this
|
||||||
|
// the Row interface is partially excluded from semantic version requirements.
|
||||||
|
// Methods will not be removed or changed, but new methods may be added.
|
||||||
type Row interface {
|
type Row interface {
|
||||||
// Scan works the same as Rows. with the following exceptions. If no
|
// Scan works the same as Rows. with the following exceptions. If no
|
||||||
// rows were found it returns ErrNoRows. If multiple rows are returned it
|
// rows were found it returns ErrNoRows. If multiple rows are returned it
|
||||||
|
|
7
tx.go
7
tx.go
|
@ -85,6 +85,13 @@ func (c *Conn) BeginTx(ctx context.Context, txOptions TxOptions) (Tx, error) {
|
||||||
return &dbTx{conn: c}, nil
|
return &dbTx{conn: c}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Tx represents a database transaction.
|
||||||
|
//
|
||||||
|
// Tx is an interface instead of a struct to enable connection pools to be implemented without relying on internal pgx
|
||||||
|
// state, to support psuedo-nested transactions with savepoints, and to allow tests to mock transactions. However,
|
||||||
|
// adding a method to an interface is technically a breaking change. If new methods are added to Conn it may be
|
||||||
|
// desirable to add them to Tx as well. Because of this the Tx interface is partially excluded from semantic version
|
||||||
|
// requirements. Methods will not be removed or changed, but new methods may be added.
|
||||||
type Tx interface {
|
type Tx interface {
|
||||||
// Begin starts a pseudo nested transaction.
|
// Begin starts a pseudo nested transaction.
|
||||||
Begin(ctx context.Context) (Tx, error)
|
Begin(ctx context.Context) (Tx, error)
|
||||||
|
|
Loading…
Reference in New Issue