mirror of
https://github.com/zeromicro/go-zero.git
synced 2025-01-25 02:08:44 +08:00
f6d9e19ecb
* expose sql.DB to let orm operate on it * add missing RawDB methods * add NewSqlConnFromDB for cooperate with dtm
107 lines
2.9 KiB
Go
107 lines
2.9 KiB
Go
// copy from core/stores/sqlx/sqlconn.go
|
|
|
|
package mocksql
|
|
|
|
import (
|
|
"database/sql"
|
|
|
|
"github.com/tal-tech/go-zero/core/stores/sqlx"
|
|
)
|
|
|
|
type (
|
|
// MockConn defines a mock connection instance for mysql
|
|
MockConn struct {
|
|
db *sql.DB
|
|
}
|
|
|
|
statement struct {
|
|
stmt *sql.Stmt
|
|
}
|
|
)
|
|
|
|
// NewMockConn creates an instance for MockConn
|
|
func NewMockConn(db *sql.DB) *MockConn {
|
|
return &MockConn{db: db}
|
|
}
|
|
|
|
// Exec executes sql and returns the result
|
|
func (conn *MockConn) Exec(query string, args ...interface{}) (sql.Result, error) {
|
|
return exec(conn.db, query, args...)
|
|
}
|
|
|
|
// Prepare executes sql by sql.DB
|
|
func (conn *MockConn) Prepare(query string) (sqlx.StmtSession, error) {
|
|
st, err := conn.db.Prepare(query)
|
|
return statement{stmt: st}, err
|
|
}
|
|
|
|
// QueryRow executes sql and returns a query row
|
|
func (conn *MockConn) QueryRow(v interface{}, q string, args ...interface{}) error {
|
|
return query(conn.db, func(rows *sql.Rows) error {
|
|
return unmarshalRow(v, rows, true)
|
|
}, q, args...)
|
|
}
|
|
|
|
// QueryRowPartial executes sql and returns a partial query row
|
|
func (conn *MockConn) QueryRowPartial(v interface{}, q string, args ...interface{}) error {
|
|
return query(conn.db, func(rows *sql.Rows) error {
|
|
return unmarshalRow(v, rows, false)
|
|
}, q, args...)
|
|
}
|
|
|
|
// QueryRows executes sql and returns query rows
|
|
func (conn *MockConn) QueryRows(v interface{}, q string, args ...interface{}) error {
|
|
return query(conn.db, func(rows *sql.Rows) error {
|
|
return unmarshalRows(v, rows, true)
|
|
}, q, args...)
|
|
}
|
|
|
|
// QueryRowsPartial executes sql and returns partial query rows
|
|
func (conn *MockConn) QueryRowsPartial(v interface{}, q string, args ...interface{}) error {
|
|
return query(conn.db, func(rows *sql.Rows) error {
|
|
return unmarshalRows(v, rows, false)
|
|
}, q, args...)
|
|
}
|
|
|
|
// RawDB returns the underlying sql.DB.
|
|
func (conn *MockConn) RawDB() (*sql.DB, error) {
|
|
return conn.db, nil
|
|
}
|
|
|
|
// Transact is the implemention of sqlx.SqlConn, nothing to do
|
|
func (conn *MockConn) Transact(func(session sqlx.Session) error) error {
|
|
return nil
|
|
}
|
|
|
|
func (s statement) Close() error {
|
|
return s.stmt.Close()
|
|
}
|
|
|
|
func (s statement) Exec(args ...interface{}) (sql.Result, error) {
|
|
return execStmt(s.stmt, args...)
|
|
}
|
|
|
|
func (s statement) QueryRow(v interface{}, args ...interface{}) error {
|
|
return queryStmt(s.stmt, func(rows *sql.Rows) error {
|
|
return unmarshalRow(v, rows, true)
|
|
}, args...)
|
|
}
|
|
|
|
func (s statement) QueryRowPartial(v interface{}, args ...interface{}) error {
|
|
return queryStmt(s.stmt, func(rows *sql.Rows) error {
|
|
return unmarshalRow(v, rows, false)
|
|
}, args...)
|
|
}
|
|
|
|
func (s statement) QueryRows(v interface{}, args ...interface{}) error {
|
|
return queryStmt(s.stmt, func(rows *sql.Rows) error {
|
|
return unmarshalRows(v, rows, true)
|
|
}, args...)
|
|
}
|
|
|
|
func (s statement) QueryRowsPartial(v interface{}, args ...interface{}) error {
|
|
return queryStmt(s.stmt, func(rows *sql.Rows) error {
|
|
return unmarshalRows(v, rows, false)
|
|
}, args...)
|
|
}
|