mirror of
https://github.com/aclindsa/moneygo.git
synced 2024-12-27 16:02:27 -05:00
71 lines
1.6 KiB
Go
71 lines
1.6 KiB
Go
package db
|
|
|
|
import (
|
|
"database/sql"
|
|
"github.com/aclindsa/gorp"
|
|
"strings"
|
|
)
|
|
|
|
type Tx struct {
|
|
Dialect gorp.Dialect
|
|
Tx *gorp.Transaction
|
|
}
|
|
|
|
func (tx *Tx) Rebind(query string) string {
|
|
chunks := strings.Split(query, "?")
|
|
str := chunks[0]
|
|
for i := 1; i < len(chunks); i++ {
|
|
str += tx.Dialect.BindVar(i-1) + chunks[i]
|
|
}
|
|
return str
|
|
}
|
|
|
|
func (tx *Tx) Select(i interface{}, query string, args ...interface{}) ([]interface{}, error) {
|
|
return tx.Tx.Select(i, tx.Rebind(query), args...)
|
|
}
|
|
|
|
func (tx *Tx) Exec(query string, args ...interface{}) (sql.Result, error) {
|
|
return tx.Tx.Exec(tx.Rebind(query), args...)
|
|
}
|
|
|
|
func (tx *Tx) SelectInt(query string, args ...interface{}) (int64, error) {
|
|
return tx.Tx.SelectInt(tx.Rebind(query), args...)
|
|
}
|
|
|
|
func (tx *Tx) SelectOne(holder interface{}, query string, args ...interface{}) error {
|
|
return tx.Tx.SelectOne(holder, tx.Rebind(query), args...)
|
|
}
|
|
|
|
func (tx *Tx) Insert(list ...interface{}) error {
|
|
return tx.Tx.Insert(list...)
|
|
}
|
|
|
|
func (tx *Tx) Update(list ...interface{}) (int64, error) {
|
|
count, err := tx.Tx.Update(list...)
|
|
if count == 0 {
|
|
switch tx.Dialect.(type) {
|
|
case gorp.MySQLDialect:
|
|
// Always return 1 for 0 if we're using MySQL because it returns
|
|
// count=0 if the row data was unchanged, even if the row existed
|
|
|
|
// TODO Find another way to fix this without risking ignoring
|
|
// errors
|
|
|
|
count = 1
|
|
}
|
|
}
|
|
return count, err
|
|
}
|
|
|
|
func (tx *Tx) Delete(list ...interface{}) (int64, error) {
|
|
return tx.Tx.Delete(list...)
|
|
}
|
|
|
|
func (tx *Tx) Commit() error {
|
|
return tx.Tx.Commit()
|
|
}
|
|
|
|
func (tx *Tx) Rollback() error {
|
|
return tx.Tx.Rollback()
|
|
}
|