Skip to content

Commit

Permalink
Expose a MySQLConn interface for use with database/sql.Conn.Raw()
Browse files Browse the repository at this point in the history
Based on the design of @methane

We can later add a LoadLocalInfile() method instead of the Register...()
functions.

for issue go-sql-driver#1416
  • Loading branch information
Jille committed Jun 26, 2023
1 parent 564dee9 commit 93e157a
Showing 1 changed file with 38 additions and 0 deletions.
38 changes: 38 additions & 0 deletions interface.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
package mysql

import (
"context"
"database/sql"
"fmt"
"time"
)

// MySQLConn exposes the usable methods on driverConn given to database/sql.Conn.Raw.
type MySQLConn interface {
// Prevent other modules from implementing this interface so we can keep adding methods.
isMySQLConn()

// Location gets the Config.Loc of this connection. (This may differ from `time_zone` connection variable.)
Location() *time.Location
}

func (mc *mysqlConn) isMySQLConn() {
}

func (mc *mysqlConn) Location() *time.Location {
return mc.cfg.Loc
}

var _ MySQLConn = &mysqlConn{}

func ExampleMySQLConn() {
db, _ := sql.Open("mysql", "root:pw@unix(/tmp/mysql.sock)/myDatabase?parseTime=true&loc=Europe%2FAmsterdam")
conn, _ := db.Conn(context.Background())
var location *time.Location
conn.Raw(func(dc any) error {
mc := dc.(MySQLConn)
location = mc.Location()
return nil
})
fmt.Println(location)
}

0 comments on commit 93e157a

Please sign in to comment.