xorm/xorm.go

43 lines
1.0 KiB
Go
Raw Normal View History

2013-05-03 07:26:51 +00:00
package xorm
import (
2013-06-16 03:05:16 +00:00
//"database/sql"
"errors"
"fmt"
2013-05-08 14:50:19 +00:00
"reflect"
2013-06-16 03:05:16 +00:00
"sync"
//"time"
2013-05-03 07:26:51 +00:00
)
2013-06-16 03:05:16 +00:00
func NewEngine(driverName string, dataSourceName string) (*Engine, error) {
engine := &Engine{ShowSQL: false, DriverName: driverName, Mapper: SnakeMapper{},
2013-05-09 01:56:58 +00:00
DataSourceName: dataSourceName}
2013-06-16 03:05:16 +00:00
engine.Tables = make(map[reflect.Type]*Table)
engine.mutex = &sync.Mutex{}
engine.InsertMany = true
2013-05-19 05:25:52 +00:00
engine.TagIdentifier = "xorm"
2013-06-16 03:05:16 +00:00
engine.QuoteIdentifier = "`"
2013-05-09 01:56:58 +00:00
if driverName == SQLITE {
engine.Dialect = sqlite3{}
2013-05-09 01:56:58 +00:00
engine.AutoIncrement = "AUTOINCREMENT"
2013-06-16 03:05:16 +00:00
//engine.Pool = NoneConnectPool{}
} else if driverName == MYSQL {
engine.Dialect = mysql{}
2013-05-09 01:56:58 +00:00
engine.AutoIncrement = "AUTO_INCREMENT"
2013-06-16 03:05:16 +00:00
} else {
return nil, errors.New(fmt.Sprintf("Unsupported driver name: %v", driverName))
2013-05-03 07:26:51 +00:00
}
2013-06-16 03:05:16 +00:00
/*engine.Pool = SimpleConnectPool{
releasedSessions: make([]*sql.DB, 30),
usingSessions: map[*sql.DB]time.Time{},
cur: -1,
maxWaitTimeOut: 14400,
mutex: &sync.Mutex{},
}*/
engine.Pool = NoneConnectPool{}
2013-06-16 03:05:16 +00:00
return engine, nil
2013-05-03 07:26:51 +00:00
}