sql_result.go 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  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) ColumnValueTime(columnName string) time.Time {
  26. value, ok := result[columnName].(time.Time)
  27. if !ok {
  28. return time.Time{}
  29. }
  30. return value
  31. }
  32. func (result SqlResult) ColumnValueStringAsTime(columnName string) time.Time {
  33. value, ok := result[columnName].(string)
  34. if !ok {
  35. return time.Time{}
  36. }
  37. t, err := ParseSqlResultTimeStr(value)
  38. if err != nil {
  39. return time.Time{}
  40. }
  41. return t
  42. }
  43. func (result SqlResult) ColumnValueBool(columnName string) bool {
  44. value, err := reflectutils.ToBool(result[columnName])
  45. if err != nil {
  46. fmt.Println(err)
  47. return false
  48. }
  49. return value
  50. }
  51. func (result SqlResult) ColumnValueString(columnName string) string {
  52. value, err := reflectutils.ToString(result[columnName])
  53. if err != nil {
  54. fmt.Println(err)
  55. return ""
  56. }
  57. return value
  58. }
  59. func (result SqlResult) ColumnValueInt(columnName string) int {
  60. value, err := reflectutils.ToInt64(result[columnName])
  61. if err != nil {
  62. fmt.Println(err)
  63. return 0
  64. }
  65. return int(value)
  66. }
  67. func (result SqlResult) ColumnValueInt8(columnName string) int8 {
  68. value, err := reflectutils.ToInt64(result[columnName])
  69. if err != nil {
  70. fmt.Println(err)
  71. return 0
  72. }
  73. return int8(value)
  74. }
  75. func (result SqlResult) ColumnValueInt16(columnName string) int16 {
  76. value, err := reflectutils.ToInt64(result[columnName])
  77. if err != nil {
  78. fmt.Println(err)
  79. return 0
  80. }
  81. return int16(value)
  82. }
  83. func (result SqlResult) ColumnValueInt32(columnName string) int32 {
  84. value, err := reflectutils.ToInt64(result[columnName])
  85. if err != nil {
  86. fmt.Println(err)
  87. return 0
  88. }
  89. return int32(value)
  90. }
  91. func (result SqlResult) ColumnValueInt64(columnName string) int64 {
  92. value, err := reflectutils.ToInt64(result[columnName])
  93. if err != nil {
  94. fmt.Println(err)
  95. return 0
  96. }
  97. return value
  98. }
  99. func (result SqlResult) ColumnValueUint(columnName string) uint {
  100. value, err := reflectutils.ToUint64(result[columnName])
  101. if err != nil {
  102. fmt.Println(err)
  103. return 0
  104. }
  105. return uint(value)
  106. }
  107. func (result SqlResult) ColumnValueUint8(columnName string) uint8 {
  108. value, err := reflectutils.ToUint64(result[columnName])
  109. if err != nil {
  110. fmt.Println(err)
  111. return 0
  112. }
  113. return uint8(value)
  114. }
  115. func (result SqlResult) ColumnValueUint16(columnName string) uint16 {
  116. value, err := reflectutils.ToUint64(result[columnName])
  117. if err != nil {
  118. fmt.Println(err)
  119. return 0
  120. }
  121. return uint16(value)
  122. }
  123. func (result SqlResult) ColumnValueUint32(columnName string) uint32 {
  124. value, err := reflectutils.ToUint64(result[columnName])
  125. if err != nil {
  126. fmt.Println(err)
  127. return 0
  128. }
  129. return uint32(value)
  130. }
  131. func (result SqlResult) ColumnValueUint64(columnName string) uint64 {
  132. value, err := reflectutils.ToUint64(result[columnName])
  133. if err != nil {
  134. fmt.Println(err)
  135. return 0
  136. }
  137. return value
  138. }
  139. func (result SqlResult) ColumnValueFloat32(columnName string) float32 {
  140. value, err := reflectutils.ToFloat64(result[columnName])
  141. if err != nil {
  142. fmt.Println(err)
  143. return 0
  144. }
  145. return float32(value)
  146. }
  147. func (result SqlResult) ColumnValueFloat64(columnName string) float64 {
  148. value, err := reflectutils.ToFloat64(result[columnName])
  149. if err != nil {
  150. fmt.Println(err)
  151. return 0
  152. }
  153. return value
  154. }