mirror of git://gcc.gnu.org/git/gcc.git
				
				
				
			
		
			
				
	
	
		
			212 lines
		
	
	
		
			6.6 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			212 lines
		
	
	
		
			6.6 KiB
		
	
	
	
		
			Go
		
	
	
	
// Copyright 2011 The Go Authors. All rights reserved.
 | 
						|
// Use of this source code is governed by a BSD-style
 | 
						|
// license that can be found in the LICENSE file.
 | 
						|
 | 
						|
// Package driver defines interfaces to be implemented by database
 | 
						|
// drivers as used by package sql.
 | 
						|
//
 | 
						|
// Most code should use package sql.
 | 
						|
package driver
 | 
						|
 | 
						|
import "errors"
 | 
						|
 | 
						|
// Value is a value that drivers must be able to handle.
 | 
						|
// It is either nil or an instance of one of these types:
 | 
						|
//
 | 
						|
//   int64
 | 
						|
//   float64
 | 
						|
//   bool
 | 
						|
//   []byte
 | 
						|
//   string   [*] everywhere except from Rows.Next.
 | 
						|
//   time.Time
 | 
						|
type Value interface{}
 | 
						|
 | 
						|
// Driver is the interface that must be implemented by a database
 | 
						|
// driver.
 | 
						|
type Driver interface {
 | 
						|
	// Open returns a new connection to the database.
 | 
						|
	// The name is a string in a driver-specific format.
 | 
						|
	//
 | 
						|
	// Open may return a cached connection (one previously
 | 
						|
	// closed), but doing so is unnecessary; the sql package
 | 
						|
	// maintains a pool of idle connections for efficient re-use.
 | 
						|
	//
 | 
						|
	// The returned connection is only used by one goroutine at a
 | 
						|
	// time.
 | 
						|
	Open(name string) (Conn, error)
 | 
						|
}
 | 
						|
 | 
						|
// ErrSkip may be returned by some optional interfaces' methods to
 | 
						|
// indicate at runtime that the fast path is unavailable and the sql
 | 
						|
// package should continue as if the optional interface was not
 | 
						|
// implemented. ErrSkip is only supported where explicitly
 | 
						|
// documented.
 | 
						|
var ErrSkip = errors.New("driver: skip fast-path; continue as if unimplemented")
 | 
						|
 | 
						|
// ErrBadConn should be returned by a driver to signal to the sql
 | 
						|
// package that a driver.Conn is in a bad state (such as the server
 | 
						|
// having earlier closed the connection) and the sql package should
 | 
						|
// retry on a new connection.
 | 
						|
//
 | 
						|
// To prevent duplicate operations, ErrBadConn should NOT be returned
 | 
						|
// if there's a possibility that the database server might have
 | 
						|
// performed the operation. Even if the server sends back an error,
 | 
						|
// you shouldn't return ErrBadConn.
 | 
						|
var ErrBadConn = errors.New("driver: bad connection")
 | 
						|
 | 
						|
// Execer is an optional interface that may be implemented by a Conn.
 | 
						|
//
 | 
						|
// If a Conn does not implement Execer, the sql package's DB.Exec will
 | 
						|
// first prepare a query, execute the statement, and then close the
 | 
						|
// statement.
 | 
						|
//
 | 
						|
// Exec may return ErrSkip.
 | 
						|
type Execer interface {
 | 
						|
	Exec(query string, args []Value) (Result, error)
 | 
						|
}
 | 
						|
 | 
						|
// Queryer is an optional interface that may be implemented by a Conn.
 | 
						|
//
 | 
						|
// If a Conn does not implement Queryer, the sql package's DB.Query will
 | 
						|
// first prepare a query, execute the statement, and then close the
 | 
						|
// statement.
 | 
						|
//
 | 
						|
// Query may return ErrSkip.
 | 
						|
type Queryer interface {
 | 
						|
	Query(query string, args []Value) (Rows, error)
 | 
						|
}
 | 
						|
 | 
						|
// Conn is a connection to a database. It is not used concurrently
 | 
						|
// by multiple goroutines.
 | 
						|
//
 | 
						|
// Conn is assumed to be stateful.
 | 
						|
type Conn interface {
 | 
						|
	// Prepare returns a prepared statement, bound to this connection.
 | 
						|
	Prepare(query string) (Stmt, error)
 | 
						|
 | 
						|
	// Close invalidates and potentially stops any current
 | 
						|
	// prepared statements and transactions, marking this
 | 
						|
	// connection as no longer in use.
 | 
						|
	//
 | 
						|
	// Because the sql package maintains a free pool of
 | 
						|
	// connections and only calls Close when there's a surplus of
 | 
						|
	// idle connections, it shouldn't be necessary for drivers to
 | 
						|
	// do their own connection caching.
 | 
						|
	Close() error
 | 
						|
 | 
						|
	// Begin starts and returns a new transaction.
 | 
						|
	Begin() (Tx, error)
 | 
						|
}
 | 
						|
 | 
						|
// Result is the result of a query execution.
 | 
						|
type Result interface {
 | 
						|
	// LastInsertId returns the database's auto-generated ID
 | 
						|
	// after, for example, an INSERT into a table with primary
 | 
						|
	// key.
 | 
						|
	LastInsertId() (int64, error)
 | 
						|
 | 
						|
	// RowsAffected returns the number of rows affected by the
 | 
						|
	// query.
 | 
						|
	RowsAffected() (int64, error)
 | 
						|
}
 | 
						|
 | 
						|
// Stmt is a prepared statement. It is bound to a Conn and not
 | 
						|
// used by multiple goroutines concurrently.
 | 
						|
type Stmt interface {
 | 
						|
	// Close closes the statement.
 | 
						|
	//
 | 
						|
	// As of Go 1.1, a Stmt will not be closed if it's in use
 | 
						|
	// by any queries.
 | 
						|
	Close() error
 | 
						|
 | 
						|
	// NumInput returns the number of placeholder parameters.
 | 
						|
	//
 | 
						|
	// If NumInput returns >= 0, the sql package will sanity check
 | 
						|
	// argument counts from callers and return errors to the caller
 | 
						|
	// before the statement's Exec or Query methods are called.
 | 
						|
	//
 | 
						|
	// NumInput may also return -1, if the driver doesn't know
 | 
						|
	// its number of placeholders. In that case, the sql package
 | 
						|
	// will not sanity check Exec or Query argument counts.
 | 
						|
	NumInput() int
 | 
						|
 | 
						|
	// Exec executes a query that doesn't return rows, such
 | 
						|
	// as an INSERT or UPDATE.
 | 
						|
	Exec(args []Value) (Result, error)
 | 
						|
 | 
						|
	// Query executes a query that may return rows, such as a
 | 
						|
	// SELECT.
 | 
						|
	Query(args []Value) (Rows, error)
 | 
						|
}
 | 
						|
 | 
						|
// ColumnConverter may be optionally implemented by Stmt if the
 | 
						|
// statement is aware of its own columns' types and can convert from
 | 
						|
// any type to a driver Value.
 | 
						|
type ColumnConverter interface {
 | 
						|
	// ColumnConverter returns a ValueConverter for the provided
 | 
						|
	// column index.  If the type of a specific column isn't known
 | 
						|
	// or shouldn't be handled specially, DefaultValueConverter
 | 
						|
	// can be returned.
 | 
						|
	ColumnConverter(idx int) ValueConverter
 | 
						|
}
 | 
						|
 | 
						|
// Rows is an iterator over an executed query's results.
 | 
						|
type Rows interface {
 | 
						|
	// Columns returns the names of the columns. The number of
 | 
						|
	// columns of the result is inferred from the length of the
 | 
						|
	// slice.  If a particular column name isn't known, an empty
 | 
						|
	// string should be returned for that entry.
 | 
						|
	Columns() []string
 | 
						|
 | 
						|
	// Close closes the rows iterator.
 | 
						|
	Close() error
 | 
						|
 | 
						|
	// Next is called to populate the next row of data into
 | 
						|
	// the provided slice. The provided slice will be the same
 | 
						|
	// size as the Columns() are wide.
 | 
						|
	//
 | 
						|
	// The dest slice may be populated only with
 | 
						|
	// a driver Value type, but excluding string.
 | 
						|
	// All string values must be converted to []byte.
 | 
						|
	//
 | 
						|
	// Next should return io.EOF when there are no more rows.
 | 
						|
	Next(dest []Value) error
 | 
						|
}
 | 
						|
 | 
						|
// Tx is a transaction.
 | 
						|
type Tx interface {
 | 
						|
	Commit() error
 | 
						|
	Rollback() error
 | 
						|
}
 | 
						|
 | 
						|
// RowsAffected implements Result for an INSERT or UPDATE operation
 | 
						|
// which mutates a number of rows.
 | 
						|
type RowsAffected int64
 | 
						|
 | 
						|
var _ Result = RowsAffected(0)
 | 
						|
 | 
						|
func (RowsAffected) LastInsertId() (int64, error) {
 | 
						|
	return 0, errors.New("no LastInsertId available")
 | 
						|
}
 | 
						|
 | 
						|
func (v RowsAffected) RowsAffected() (int64, error) {
 | 
						|
	return int64(v), nil
 | 
						|
}
 | 
						|
 | 
						|
// ResultNoRows is a pre-defined Result for drivers to return when a DDL
 | 
						|
// command (such as a CREATE TABLE) succeeds. It returns an error for both
 | 
						|
// LastInsertId and RowsAffected.
 | 
						|
var ResultNoRows noRows
 | 
						|
 | 
						|
type noRows struct{}
 | 
						|
 | 
						|
var _ Result = noRows{}
 | 
						|
 | 
						|
func (noRows) LastInsertId() (int64, error) {
 | 
						|
	return 0, errors.New("no LastInsertId available after DDL statement")
 | 
						|
}
 | 
						|
 | 
						|
func (noRows) RowsAffected() (int64, error) {
 | 
						|
	return 0, errors.New("no RowsAffected available after DDL statement")
 | 
						|
}
 |