value.go 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. package sql
  2. import (
  3. "git.sxidc.com/go-tools/utils/reflectutils"
  4. "git.sxidc.com/service-supports/fserr"
  5. "reflect"
  6. "strings"
  7. "time"
  8. )
  9. const (
  10. timeWriteFormat = time.DateTime + ".000000 +08:00"
  11. )
  12. var keyWordsMap = map[string]any{}
  13. func toSqlValue(value any) (string, error) {
  14. if value == nil {
  15. return "", nil
  16. }
  17. valueValue := reflect.ValueOf(value)
  18. if valueValue.Kind() == reflect.Slice {
  19. return "", fserr.New("请使用toSqlValues处理slice类型")
  20. }
  21. switch v := reflectutils.PointerValueElem(valueValue).Interface().(type) {
  22. case string:
  23. return "'" + v + "'", nil
  24. case time.Time:
  25. return "'" + v.Format(timeWriteFormat) + "'", nil
  26. default:
  27. retStr := new(string)
  28. err := reflectutils.AssignStringValue(v, reflect.ValueOf(retStr).Elem())
  29. if err != nil {
  30. return "", err
  31. }
  32. return *retStr, nil
  33. }
  34. }
  35. func toSqlValues(values any) (string, error) {
  36. if values == nil {
  37. return "()", nil
  38. }
  39. sliceValue := reflect.ValueOf(values)
  40. if sliceValue.IsZero() {
  41. return "()", nil
  42. }
  43. if sliceValue.Kind() != reflect.Slice {
  44. return "", fserr.New("传递的不是slice")
  45. }
  46. parsedValues := make([]string, 0)
  47. for i := 0; i < sliceValue.Len(); i++ {
  48. value := sliceValue.Index(i).Interface()
  49. parsedValue, err := toSqlValue(value)
  50. if err != nil {
  51. return "", err
  52. }
  53. parsedValues = append(parsedValues, parsedValue)
  54. }
  55. if len(parsedValues) == 0 {
  56. return "()", nil
  57. }
  58. return "(" + strings.Join(parsedValues, ",") + ")", nil
  59. }