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.

104 lines
3.1 KiB

  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. package xorm
  5. import (
  6. "fmt"
  7. "os"
  8. "reflect"
  9. "runtime"
  10. "sync"
  11. "time"
  12. "github.com/go-xorm/core"
  13. )
  14. const (
  15. // Version show the xorm's version
  16. Version string = "0.6.0.1022"
  17. )
  18. func regDrvsNDialects() bool {
  19. providedDrvsNDialects := map[string]struct {
  20. dbType core.DbType
  21. getDriver func() core.Driver
  22. getDialect func() core.Dialect
  23. }{
  24. "mssql": {"mssql", func() core.Driver { return &odbcDriver{} }, func() core.Dialect { return &mssql{} }},
  25. "odbc": {"mssql", func() core.Driver { return &odbcDriver{} }, func() core.Dialect { return &mssql{} }}, // !nashtsai! TODO change this when supporting MS Access
  26. "mysql": {"mysql", func() core.Driver { return &mysqlDriver{} }, func() core.Dialect { return &mysql{} }},
  27. "mymysql": {"mysql", func() core.Driver { return &mymysqlDriver{} }, func() core.Dialect { return &mysql{} }},
  28. "postgres": {"postgres", func() core.Driver { return &pqDriver{} }, func() core.Dialect { return &postgres{} }},
  29. "pgx": {"postgres", func() core.Driver { return &pqDriver{} }, func() core.Dialect { return &postgres{} }},
  30. "sqlite3": {"sqlite3", func() core.Driver { return &sqlite3Driver{} }, func() core.Dialect { return &sqlite3{} }},
  31. "oci8": {"oracle", func() core.Driver { return &oci8Driver{} }, func() core.Dialect { return &oracle{} }},
  32. "goracle": {"oracle", func() core.Driver { return &goracleDriver{} }, func() core.Dialect { return &oracle{} }},
  33. }
  34. for driverName, v := range providedDrvsNDialects {
  35. if driver := core.QueryDriver(driverName); driver == nil {
  36. core.RegisterDriver(driverName, v.getDriver())
  37. core.RegisterDialect(v.dbType, v.getDialect)
  38. }
  39. }
  40. return true
  41. }
  42. func close(engine *Engine) {
  43. engine.Close()
  44. }
  45. // NewEngine new a db manager according to the parameter. Currently support four
  46. // drivers
  47. func NewEngine(driverName string, dataSourceName string) (*Engine, error) {
  48. regDrvsNDialects()
  49. driver := core.QueryDriver(driverName)
  50. if driver == nil {
  51. return nil, fmt.Errorf("Unsupported driver name: %v", driverName)
  52. }
  53. uri, err := driver.Parse(driverName, dataSourceName)
  54. if err != nil {
  55. return nil, err
  56. }
  57. dialect := core.QueryDialect(uri.DbType)
  58. if dialect == nil {
  59. return nil, fmt.Errorf("Unsupported dialect type: %v", uri.DbType)
  60. }
  61. db, err := core.Open(driverName, dataSourceName)
  62. if err != nil {
  63. return nil, err
  64. }
  65. err = dialect.Init(db, uri, driverName, dataSourceName)
  66. if err != nil {
  67. return nil, err
  68. }
  69. engine := &Engine{
  70. db: db,
  71. dialect: dialect,
  72. Tables: make(map[reflect.Type]*core.Table),
  73. mutex: &sync.RWMutex{},
  74. TagIdentifier: "xorm",
  75. TZLocation: time.Local,
  76. }
  77. logger := NewSimpleLogger(os.Stdout)
  78. logger.SetLevel(core.LOG_INFO)
  79. engine.SetLogger(logger)
  80. engine.SetMapper(core.NewCacheMapper(new(core.SnakeMapper)))
  81. runtime.SetFinalizer(engine, close)
  82. return engine, nil
  83. }
  84. // Clone clone an engine
  85. func (engine *Engine) Clone() (*Engine, error) {
  86. return NewEngine(engine.DriverName(), engine.DataSourceName())
  87. }