You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

xorm.go 3.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. // Copyright 2015 The Xorm Authors. All rights reserved.
  2. // Use of this source code is governed by a BSD-style
  3. // license that can be found in the LICENSE file.
  4. // +build go1.8
  5. package xorm
  6. import (
  7. "fmt"
  8. "os"
  9. "reflect"
  10. "runtime"
  11. "sync"
  12. "time"
  13. "github.com/go-xorm/core"
  14. )
  15. const (
  16. // Version show the xorm's version
  17. Version string = "0.7.0.0504"
  18. )
  19. func regDrvsNDialects() bool {
  20. providedDrvsNDialects := map[string]struct {
  21. dbType core.DbType
  22. getDriver func() core.Driver
  23. getDialect func() core.Dialect
  24. }{
  25. "mssql": {"mssql", func() core.Driver { return &odbcDriver{} }, func() core.Dialect { return &mssql{} }},
  26. "odbc": {"mssql", func() core.Driver { return &odbcDriver{} }, func() core.Dialect { return &mssql{} }}, // !nashtsai! TODO change this when supporting MS Access
  27. "mysql": {"mysql", func() core.Driver { return &mysqlDriver{} }, func() core.Dialect { return &mysql{} }},
  28. "mymysql": {"mysql", func() core.Driver { return &mymysqlDriver{} }, func() core.Dialect { return &mysql{} }},
  29. "postgres": {"postgres", func() core.Driver { return &pqDriver{} }, func() core.Dialect { return &postgres{} }},
  30. "pgx": {"postgres", func() core.Driver { return &pqDriverPgx{} }, func() core.Dialect { return &postgres{} }},
  31. "sqlite3": {"sqlite3", func() core.Driver { return &sqlite3Driver{} }, func() core.Dialect { return &sqlite3{} }},
  32. "oci8": {"oracle", func() core.Driver { return &oci8Driver{} }, func() core.Dialect { return &oracle{} }},
  33. "goracle": {"oracle", func() core.Driver { return &goracleDriver{} }, func() core.Dialect { return &oracle{} }},
  34. }
  35. for driverName, v := range providedDrvsNDialects {
  36. if driver := core.QueryDriver(driverName); driver == nil {
  37. core.RegisterDriver(driverName, v.getDriver())
  38. core.RegisterDialect(v.dbType, v.getDialect)
  39. }
  40. }
  41. return true
  42. }
  43. func close(engine *Engine) {
  44. engine.Close()
  45. }
  46. func init() {
  47. regDrvsNDialects()
  48. }
  49. // NewEngine new a db manager according to the parameter. Currently support four
  50. // drivers
  51. func NewEngine(driverName string, dataSourceName string) (*Engine, error) {
  52. driver := core.QueryDriver(driverName)
  53. if driver == nil {
  54. return nil, fmt.Errorf("Unsupported driver name: %v", driverName)
  55. }
  56. uri, err := driver.Parse(driverName, dataSourceName)
  57. if err != nil {
  58. return nil, err
  59. }
  60. dialect := core.QueryDialect(uri.DbType)
  61. if dialect == nil {
  62. return nil, fmt.Errorf("Unsupported dialect type: %v", uri.DbType)
  63. }
  64. db, err := core.Open(driverName, dataSourceName)
  65. if err != nil {
  66. return nil, err
  67. }
  68. err = dialect.Init(db, uri, driverName, dataSourceName)
  69. if err != nil {
  70. return nil, err
  71. }
  72. engine := &Engine{
  73. db: db,
  74. dialect: dialect,
  75. Tables: make(map[reflect.Type]*core.Table),
  76. mutex: &sync.RWMutex{},
  77. TagIdentifier: "xorm",
  78. TZLocation: time.Local,
  79. tagHandlers: defaultTagHandlers,
  80. cachers: make(map[string]core.Cacher),
  81. }
  82. if uri.DbType == core.SQLITE {
  83. engine.DatabaseTZ = time.UTC
  84. } else {
  85. engine.DatabaseTZ = time.Local
  86. }
  87. logger := NewSimpleLogger(os.Stdout)
  88. logger.SetLevel(core.LOG_INFO)
  89. engine.SetLogger(logger)
  90. engine.SetMapper(core.NewCacheMapper(new(core.SnakeMapper)))
  91. runtime.SetFinalizer(engine, close)
  92. return engine, nil
  93. }
  94. // NewEngineWithParams new a db manager with params. The params will be passed to dialect.
  95. func NewEngineWithParams(driverName string, dataSourceName string, params map[string]string) (*Engine, error) {
  96. engine, err := NewEngine(driverName, dataSourceName)
  97. engine.dialect.SetParams(params)
  98. return engine, err
  99. }
  100. // Clone clone an engine
  101. func (engine *Engine) Clone() (*Engine, error) {
  102. return NewEngine(engine.DriverName(), engine.DataSourceName())
  103. }