service.go.tpl 3.4 KB

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