diff options
| author | Brad Fitzpatrick <bradfitz@golang.org> | 2013-03-14 14:06:46 -0700 |
|---|---|---|
| committer | Brad Fitzpatrick <bradfitz@golang.org> | 2013-03-14 14:06:46 -0700 |
| commit | a4a8651419af7864996b904203cc3496416a6ac8 (patch) | |
| tree | 45dbbafd6a167eff117937f431b38571a8d0b805 /src/pkg/database/sql/sql.go | |
| parent | cf46e561b2be3b15649fe029ffa8dc02fca6459a (diff) | |
| download | go-a4a8651419af7864996b904203cc3496416a6ac8.tar.xz | |
database/sql: document non-open of Open; add Ping
Fixes #4804
R=golang-dev, r
CC=golang-dev
https://golang.org/cl/7819043
Diffstat (limited to 'src/pkg/database/sql/sql.go')
| -rw-r--r-- | src/pkg/database/sql/sql.go | 20 |
1 files changed, 18 insertions, 2 deletions
diff --git a/src/pkg/database/sql/sql.go b/src/pkg/database/sql/sql.go index 6d52d2986d..d351fbc243 100644 --- a/src/pkg/database/sql/sql.go +++ b/src/pkg/database/sql/sql.go @@ -258,13 +258,15 @@ func (db *DB) removeDep(x finalCloser, dep interface{}) error { // // Most users will open a database via a driver-specific connection // helper function that returns a *DB. +// +// Open may just validate its arguments without creating a connection +// to the database. To verify that the data source name is valid, call +// Ping. func Open(driverName, dataSourceName string) (*DB, error) { driveri, ok := drivers[driverName] if !ok { return nil, fmt.Errorf("sql: unknown driver %q (forgotten import?)", driverName) } - // TODO: optionally proactively connect to a Conn to check - // the dataSourceName: golang.org/issue/4804 db := &DB{ driver: driveri, dsn: dataSourceName, @@ -275,6 +277,20 @@ func Open(driverName, dataSourceName string) (*DB, error) { return db, nil } +// Ping verifies a connection to the database is still alive, +// establishing a connection if necessary. +func (db *DB) Ping() error { + // TODO(bradfitz): give drivers an optional hook to implement + // this in a more efficient or more reliable way, if they + // have one. + c, err := db.conn() + if err != nil { + return err + } + db.putConn(c, nil) + return nil +} + // Close closes the database, releasing any open resources. func (db *DB) Close() error { db.mu.Lock() |
