db.go 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. package utils
  2. import (
  3. "database/sql"
  4. "fmt"
  5. "gorm.io/gorm"
  6. )
  7. type WtDB struct {
  8. *gorm.DB
  9. }
  10. func (db *WtDB) Table(name string, args ...interface{}) (tx *WtDB) {
  11. return &WtDB{db.DB.Table(name, args...)}
  12. }
  13. func (db *WtDB) Distinct(args ...interface{}) (tx *WtDB) {
  14. return &WtDB{db.DB.Distinct(args...)}
  15. }
  16. func (db *WtDB) Select(query interface{}, args ...interface{}) (tx *WtDB) {
  17. return &WtDB{db.DB.Select(query, args...)}
  18. }
  19. func (db *WtDB) WhereRaw(query interface{}, args ...interface{}) (tx *WtDB) {
  20. return &WtDB{db.DB.Where(query, args...)}
  21. }
  22. func (db *WtDB) Where(field string, args ...interface{}) (tx *WtDB) {
  23. n := len(args)
  24. if n == 0 {
  25. return &WtDB{db.DB.Where(field)}
  26. }
  27. if n == 1 {
  28. return &WtDB{db.DB.Where(field+" = ?", args...)}
  29. }
  30. if n == 2 {
  31. var opList = []string{"=", ">", "<", ">=", "<=", "!=", "like"}
  32. if v, ok := args[0].(string); ok {
  33. if InArray(v, opList) {
  34. return &WtDB{db.DB.Where(fmt.Sprintf("%s %s ?", field, v), args[1:]...)}
  35. }
  36. }
  37. }
  38. return &WtDB{db.DB.Where(field, args...)}
  39. }
  40. func (db *WtDB) WhereIn(field string, args ...interface{}) (tx *WtDB) {
  41. return &WtDB{db.DB.Where(fmt.Sprintf("%s in ?", field), args...)}
  42. }
  43. func (db *WtDB) WhereNotIn(field string, args ...interface{}) (tx *WtDB) {
  44. return &WtDB{db.DB.Where(fmt.Sprintf("%s not in ?", field), args...)}
  45. }
  46. func (db *WtDB) Not(query interface{}, args ...interface{}) (tx *WtDB) {
  47. return &WtDB{db.DB.Not(query, args...)}
  48. }
  49. func (db *WtDB) Or(query interface{}, args ...interface{}) (tx *WtDB) {
  50. return &WtDB{db.DB.Or(query, args...)}
  51. }
  52. func (db *WtDB) Join(table string, query string, args ...interface{}) (tx *WtDB) {
  53. return &WtDB{db.DB.Joins(fmt.Sprintf("inner join %s on %s", table, query), args...)}
  54. }
  55. func (db *WtDB) LeftJoin(table string, query string, args ...interface{}) (tx *WtDB) {
  56. return &WtDB{db.DB.Joins(fmt.Sprintf("left join %s on %s", table, query), args...)}
  57. }
  58. func (db *WtDB) RightJoin(table string, query string, args ...interface{}) (tx *WtDB) {
  59. return &WtDB{db.DB.Joins(fmt.Sprintf("right join %s on %s", table, query), args...)}
  60. }
  61. func (db *WtDB) JoinRaw(query string, args ...interface{}) (tx *WtDB) {
  62. return &WtDB{db.DB.Joins(query, args...)}
  63. }
  64. func (db *WtDB) Group(name string) (tx *WtDB) {
  65. return &WtDB{db.DB.Group(name)}
  66. }
  67. func (db *WtDB) Having(query interface{}, args ...interface{}) (tx *WtDB) {
  68. return &WtDB{db.DB.Having(query, args...)}
  69. }
  70. func (db *WtDB) Order(value interface{}) (tx *WtDB) {
  71. return &WtDB{db.DB.Order(value)}
  72. }
  73. func (db *WtDB) Limit(limit int) (tx *WtDB) {
  74. return &WtDB{db.DB.Limit(limit)}
  75. }
  76. func (db *WtDB) Offset(offset int) (tx *WtDB) {
  77. return &WtDB{db.DB.Offset(offset)}
  78. }
  79. func (db *WtDB) Raw(sql string, values ...interface{}) (tx *WtDB) {
  80. return &WtDB{db.DB.Raw(sql, values...)}
  81. }
  82. func (db *WtDB) SubQuery() *gorm.DB {
  83. return db.DB
  84. }
  85. func (db *WtDB) Begin(opts ...*sql.TxOptions) (tx *WtDB) {
  86. return &WtDB{DB: db.DB.Begin(opts...)}
  87. }
  88. func (db *WtDB) Commit() (tx *WtDB) {
  89. return &WtDB{DB: db.DB.Commit()}
  90. }
  91. func (db *WtDB) Rollback() (tx *WtDB) {
  92. return &WtDB{DB: db.DB.Rollback()}
  93. }
  94. func (db *WtDB) Transaction(fc func(tx *WtDB) error) (err error) {
  95. return db.DB.Transaction(func(t *gorm.DB) error {
  96. return fc(&WtDB{DB: t})
  97. })
  98. }