aboutsummaryrefslogtreecommitdiff
path: root/src/pkg/database/sql/sql.go
diff options
context:
space:
mode:
authorBrad Fitzpatrick <bradfitz@golang.org>2013-03-14 14:06:46 -0700
committerBrad Fitzpatrick <bradfitz@golang.org>2013-03-14 14:06:46 -0700
commita4a8651419af7864996b904203cc3496416a6ac8 (patch)
tree45dbbafd6a167eff117937f431b38571a8d0b805 /src/pkg/database/sql/sql.go
parentcf46e561b2be3b15649fe029ffa8dc02fca6459a (diff)
downloadgo-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.go20
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()