helper.go 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. package callbacks
  2. import (
  3. "sort"
  4. "gorm.io/gorm"
  5. "gorm.io/gorm/clause"
  6. )
  7. // ConvertMapToValuesForCreate convert map to values
  8. func ConvertMapToValuesForCreate(stmt *gorm.Statement, mapValue map[string]interface{}) (values clause.Values) {
  9. values.Columns = make([]clause.Column, 0, len(mapValue))
  10. selectColumns, restricted := stmt.SelectAndOmitColumns(true, false)
  11. var keys = make([]string, 0, len(mapValue))
  12. for k := range mapValue {
  13. keys = append(keys, k)
  14. }
  15. sort.Strings(keys)
  16. for _, k := range keys {
  17. value := mapValue[k]
  18. if stmt.Schema != nil {
  19. if field := stmt.Schema.LookUpField(k); field != nil {
  20. k = field.DBName
  21. }
  22. }
  23. if v, ok := selectColumns[k]; (ok && v) || (!ok && !restricted) {
  24. values.Columns = append(values.Columns, clause.Column{Name: k})
  25. if len(values.Values) == 0 {
  26. values.Values = [][]interface{}{{}}
  27. }
  28. values.Values[0] = append(values.Values[0], value)
  29. }
  30. }
  31. return
  32. }
  33. // ConvertSliceOfMapToValuesForCreate convert slice of map to values
  34. func ConvertSliceOfMapToValuesForCreate(stmt *gorm.Statement, mapValues []map[string]interface{}) (values clause.Values) {
  35. var (
  36. columns = make([]string, 0, len(mapValues))
  37. result = map[string][]interface{}{}
  38. selectColumns, restricted = stmt.SelectAndOmitColumns(true, false)
  39. )
  40. if len(mapValues) == 0 {
  41. stmt.AddError(gorm.ErrEmptySlice)
  42. return
  43. }
  44. for idx, mapValue := range mapValues {
  45. for k, v := range mapValue {
  46. if stmt.Schema != nil {
  47. if field := stmt.Schema.LookUpField(k); field != nil {
  48. k = field.DBName
  49. }
  50. }
  51. if _, ok := result[k]; !ok {
  52. if v, ok := selectColumns[k]; (ok && v) || (!ok && !restricted) {
  53. result[k] = make([]interface{}, len(mapValues))
  54. columns = append(columns, k)
  55. } else {
  56. continue
  57. }
  58. }
  59. result[k][idx] = v
  60. }
  61. }
  62. sort.Strings(columns)
  63. values.Values = make([][]interface{}, len(mapValues))
  64. values.Columns = make([]clause.Column, len(columns))
  65. for idx, column := range columns {
  66. values.Columns[idx] = clause.Column{Name: column}
  67. for i, v := range result[column] {
  68. if len(values.Values[i]) == 0 {
  69. values.Values[i] = make([]interface{}, len(columns))
  70. }
  71. values.Values[i][idx] = v
  72. }
  73. }
  74. return
  75. }