sql_result.go 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  1. package sdk
  2. import (
  3. "fmt"
  4. "git.sxidc.com/go-tools/utils/reflectutils"
  5. "strings"
  6. "time"
  7. )
  8. const (
  9. sqlResultTimeMicroFormat = "2006-01-02T15:04:05.000000+08:00"
  10. sqlResultTimeMilliFormat = "2006-01-02T15:04:05.000+08:00"
  11. sqlResultTimeSecFormat = "2006-01-02T15:04:05+08:00"
  12. )
  13. func ParseSqlResultTimeStr(timeStr string) (time.Time, error) {
  14. var layout string
  15. if strings.HasSuffix(timeStr, ".000000+08:00") {
  16. layout = sqlResultTimeMicroFormat
  17. } else if strings.HasSuffix(timeStr, ".000+08:00") {
  18. layout = sqlResultTimeMilliFormat
  19. } else {
  20. layout = sqlResultTimeSecFormat
  21. }
  22. return time.ParseInLocation(layout, timeStr, time.Local)
  23. }
  24. type SqlResult map[string]any
  25. func (result SqlResult) ColumnValueStringAsTime(columnName string) time.Time {
  26. value, ok := result[columnName].(string)
  27. if !ok {
  28. return time.Time{}
  29. }
  30. t, err := ParseSqlResultTimeStr(value)
  31. if err != nil {
  32. return time.Time{}
  33. }
  34. return t
  35. }
  36. func (result SqlResult) ColumnValueBool(columnName string) bool {
  37. value, err := reflectutils.ToBool(result[columnName])
  38. if err != nil {
  39. fmt.Println(err)
  40. return false
  41. }
  42. return value
  43. }
  44. func (result SqlResult) ColumnValueString(columnName string) string {
  45. value, err := reflectutils.ToString(result[columnName])
  46. if err != nil {
  47. fmt.Println(err)
  48. return ""
  49. }
  50. return value
  51. }
  52. func (result SqlResult) ColumnValueInt(columnName string) int {
  53. value, err := reflectutils.ToInt64(result[columnName])
  54. if err != nil {
  55. fmt.Println(err)
  56. return 0
  57. }
  58. return int(value)
  59. }
  60. func (result SqlResult) ColumnValueInt8(columnName string) int8 {
  61. value, err := reflectutils.ToInt64(result[columnName])
  62. if err != nil {
  63. fmt.Println(err)
  64. return 0
  65. }
  66. return int8(value)
  67. }
  68. func (result SqlResult) ColumnValueInt16(columnName string) int16 {
  69. value, err := reflectutils.ToInt64(result[columnName])
  70. if err != nil {
  71. fmt.Println(err)
  72. return 0
  73. }
  74. return int16(value)
  75. }
  76. func (result SqlResult) ColumnValueInt32(columnName string) int32 {
  77. value, err := reflectutils.ToInt64(result[columnName])
  78. if err != nil {
  79. fmt.Println(err)
  80. return 0
  81. }
  82. return int32(value)
  83. }
  84. func (result SqlResult) ColumnValueInt64(columnName string) int64 {
  85. value, err := reflectutils.ToInt64(result[columnName])
  86. if err != nil {
  87. fmt.Println(err)
  88. return 0
  89. }
  90. return value
  91. }
  92. func (result SqlResult) ColumnValueUint(columnName string) uint {
  93. value, err := reflectutils.ToUint64(result[columnName])
  94. if err != nil {
  95. fmt.Println(err)
  96. return 0
  97. }
  98. return uint(value)
  99. }
  100. func (result SqlResult) ColumnValueUint8(columnName string) uint8 {
  101. value, err := reflectutils.ToUint64(result[columnName])
  102. if err != nil {
  103. fmt.Println(err)
  104. return 0
  105. }
  106. return uint8(value)
  107. }
  108. func (result SqlResult) ColumnValueUint16(columnName string) uint16 {
  109. value, err := reflectutils.ToUint64(result[columnName])
  110. if err != nil {
  111. fmt.Println(err)
  112. return 0
  113. }
  114. return uint16(value)
  115. }
  116. func (result SqlResult) ColumnValueUint32(columnName string) uint32 {
  117. value, err := reflectutils.ToUint64(result[columnName])
  118. if err != nil {
  119. fmt.Println(err)
  120. return 0
  121. }
  122. return uint32(value)
  123. }
  124. func (result SqlResult) ColumnValueUint64(columnName string) uint64 {
  125. value, err := reflectutils.ToUint64(result[columnName])
  126. if err != nil {
  127. fmt.Println(err)
  128. return 0
  129. }
  130. return value
  131. }
  132. func (result SqlResult) ColumnValueFloat32(columnName string) float32 {
  133. value, err := reflectutils.ToFloat64(result[columnName])
  134. if err != nil {
  135. fmt.Println(err)
  136. return 0
  137. }
  138. return float32(value)
  139. }
  140. func (result SqlResult) ColumnValueFloat64(columnName string) float64 {
  141. value, err := reflectutils.ToFloat64(result[columnName])
  142. if err != nil {
  143. fmt.Println(err)
  144. return 0
  145. }
  146. return value
  147. }