service.go.tpl 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. package service
  2. import (
  3. "gin-vue-admin/global"
  4. "gin-vue-admin/model"
  5. "gin-vue-admin/model/request"
  6. )
  7. //@author: [piexlmax](https://github.com/piexlmax)
  8. //@function: Create{{.StructName}}
  9. //@description: 创建{{.StructName}}记录
  10. //@param: {{.Abbreviation}} model.{{.StructName}}
  11. //@return: err error
  12. func Create{{.StructName}}({{.Abbreviation}} model.{{.StructName}}) (err error) {
  13. err = global.GVA_DB.Create(&{{.Abbreviation}}).Error
  14. return err
  15. }
  16. //@author: [piexlmax](https://github.com/piexlmax)
  17. //@function: Delete{{.StructName}}
  18. //@description: 删除{{.StructName}}记录
  19. //@param: {{.Abbreviation}} model.{{.StructName}}
  20. //@return: err error
  21. func Delete{{.StructName}}({{.Abbreviation}} model.{{.StructName}}) (err error) {
  22. err = global.GVA_DB.Delete(&{{.Abbreviation}}).Error
  23. return err
  24. }
  25. //@author: [piexlmax](https://github.com/piexlmax)
  26. //@function: Delete{{.StructName}}ByIds
  27. //@description: 批量删除{{.StructName}}记录
  28. //@param: ids request.IdsReq
  29. //@return: err error
  30. func Delete{{.StructName}}ByIds(ids request.IdsReq) (err error) {
  31. err = global.GVA_DB.Delete(&[]model.{{.StructName}}{},"id in ?",ids.Ids).Error
  32. return err
  33. }
  34. //@author: [piexlmax](https://github.com/piexlmax)
  35. //@function: Update{{.StructName}}
  36. //@description: 更新{{.StructName}}记录
  37. //@param: {{.Abbreviation}} *model.{{.StructName}}
  38. //@return: err error
  39. func Update{{.StructName}}({{.Abbreviation}} model.{{.StructName}}) (err error) {
  40. err = global.GVA_DB.Save(&{{.Abbreviation}}).Error
  41. return err
  42. }
  43. //@author: [piexlmax](https://github.com/piexlmax)
  44. //@function: Get{{.StructName}}
  45. //@description: 根据id获取{{.StructName}}记录
  46. //@param: id uint
  47. //@return: err error, {{.Abbreviation}} model.{{.StructName}}
  48. func Get{{.StructName}}(id uint) (err error, {{.Abbreviation}} model.{{.StructName}}) {
  49. err = global.GVA_DB.Where("id = ?", id).First(&{{.Abbreviation}}).Error
  50. return
  51. }
  52. //@author: [piexlmax](https://github.com/piexlmax)
  53. //@function: Get{{.StructName}}InfoList
  54. //@description: 分页获取{{.StructName}}记录
  55. //@param: info request.{{.StructName}}Search
  56. //@return: err error, list interface{}, total int64
  57. func Get{{.StructName}}InfoList(info request.{{.StructName}}Search) (err error, list interface{}, total int64) {
  58. limit := info.PageSize
  59. offset := info.PageSize * (info.Page - 1)
  60. // 创建db
  61. db := global.GVA_DB.Model(&model.{{.StructName}}{})
  62. var {{.Abbreviation}}s []model.{{.StructName}}
  63. // 如果有条件搜索 下方会自动创建搜索语句
  64. {{- range .Fields}}
  65. {{- if .FieldSearchType}}
  66. {{- if eq .FieldType "string" }}
  67. if info.{{.FieldName}} != "" {
  68. db = db.Where("`{{.ColumnName}}` {{.FieldSearchType}} ?",{{if eq .FieldSearchType "LIKE"}}"%"+ {{ end }}info.{{.FieldName}}{{if eq .FieldSearchType "LIKE"}}+"%"{{ end }})
  69. }
  70. {{- else if eq .FieldType "bool" }}
  71. if info.{{.FieldName}} != nil {
  72. db = db.Where("`{{.ColumnName}}` {{.FieldSearchType}} ?",{{if eq .FieldSearchType "LIKE"}}"%"+{{ end }}info.{{.FieldName}}{{if eq .FieldSearchType "LIKE"}}+"%"{{ end }})
  73. }
  74. {{- else if eq .FieldType "int" }}
  75. if info.{{.FieldName}} != 0 {
  76. db = db.Where("`{{.ColumnName}}` {{.FieldSearchType}} ?",{{if eq .FieldSearchType "LIKE"}}"%"+{{ end }}info.{{.FieldName}}{{if eq .FieldSearchType "LIKE"}}+"%"{{ end }})
  77. }
  78. {{- else if eq .FieldType "float64" }}
  79. if info.{{.FieldName}} != 0 {
  80. db = db.Where("`{{.ColumnName}}` {{.FieldSearchType}} ?",{{if eq .FieldSearchType "LIKE"}}"%"+{{ end }}info.{{.FieldName}}{{if eq .FieldSearchType "LIKE"}}+"%"{{ end }})
  81. }
  82. {{- else if eq .FieldType "time.Time" }}
  83. if !info.{{.FieldName}}.IsZero() {
  84. db = db.Where("`{{.ColumnName}}` {{.FieldSearchType}} ?",{{if eq .FieldSearchType "LIKE"}}"%"+{{ end }}info.{{.FieldName}}{{if eq .FieldSearchType "LIKE"}}+"%"{{ end }})
  85. }
  86. {{- end }}
  87. {{- end }}
  88. {{- end }}
  89. err = db.Count(&total).Error
  90. err = db.Limit(limit).Offset(offset).Find(&{{.Abbreviation}}s).Error
  91. return err, {{.Abbreviation}}s, total
  92. }