xorm.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  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/xormplus/core"
  13. )
  14. const (
  15. // Version show the xorm's version
  16. Version string = "0.5.5.0728"
  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. "sqlite3": {"sqlite3", func() core.Driver { return &sqlite3Driver{} }, func() core.Dialect { return &sqlite3{} }},
  30. "oci8": {"oracle", func() core.Driver { return &oci8Driver{} }, func() core.Dialect { return &oracle{} }},
  31. "goracle": {"oracle", func() core.Driver { return &goracleDriver{} }, func() core.Dialect { return &oracle{} }},
  32. }
  33. for driverName, v := range providedDrvsNDialects {
  34. if driver := core.QueryDriver(driverName); driver == nil {
  35. core.RegisterDriver(driverName, v.getDriver())
  36. core.RegisterDialect(v.dbType, v.getDialect)
  37. }
  38. }
  39. return true
  40. }
  41. func close(engine *Engine) {
  42. engine.Close()
  43. }
  44. // NewEngine new a db manager according to the parameter. Currently support four
  45. // drivers
  46. func NewEngine(driverName string, dataSourceName string) (*Engine, error) {
  47. regDrvsNDialects()
  48. driver := core.QueryDriver(driverName)
  49. if driver == nil {
  50. return nil, fmt.Errorf("Unsupported driver name: %v", driverName)
  51. }
  52. uri, err := driver.Parse(driverName, dataSourceName)
  53. if err != nil {
  54. return nil, err
  55. }
  56. dialect := core.QueryDialect(uri.DbType)
  57. if dialect == nil {
  58. return nil, fmt.Errorf("Unsupported dialect type: %v", uri.DbType)
  59. }
  60. db, err := core.Open(driverName, dataSourceName)
  61. if err != nil {
  62. return nil, err
  63. }
  64. err = dialect.Init(db, uri, driverName, dataSourceName)
  65. if err != nil {
  66. return nil, err
  67. }
  68. engine := &Engine{
  69. db: db,
  70. dialect: dialect,
  71. Tables: make(map[reflect.Type]*core.Table),
  72. mutex: &sync.RWMutex{},
  73. TagIdentifier: "xorm",
  74. TZLocation: time.Local,
  75. }
  76. logger := NewSimpleLogger(os.Stdout)
  77. logger.SetLevel(core.LOG_INFO)
  78. engine.SetLogger(logger)
  79. engine.SetMapper(core.NewCacheMapper(new(core.SnakeMapper)))
  80. runtime.SetFinalizer(engine, close)
  81. return engine, nil
  82. }
  83. // Clone clone an engine
  84. func (engine *Engine) Clone() (*Engine, error) {
  85. return NewEngine(engine.DriverName(), engine.DataSourceName())
  86. }