sqlmaps_executor.go 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311
  1. package xorm
  2. import (
  3. "database/sql"
  4. "strings"
  5. )
  6. type SqlMapsExecutor struct {
  7. session *Session
  8. sqlkeys interface{}
  9. parmas interface{}
  10. err error
  11. }
  12. func (sqlMapsExecutor *SqlMapsExecutor) Execute() ([][]map[string]interface{}, map[string][]map[string]interface{}, error) {
  13. if sqlMapsExecutor.err != nil {
  14. return nil, nil, sqlMapsExecutor.err
  15. }
  16. var model_1_results ResultMap
  17. var model_2_results sql.Result
  18. var err error
  19. sqlModel := 1
  20. switch sqlMapsExecutor.sqlkeys.(type) {
  21. case string:
  22. sqlkey := strings.TrimSpace(sqlMapsExecutor.sqlkeys.(string))
  23. sqlStr := sqlMapsExecutor.session.Engine.GetSql(sqlkey)
  24. sqlCmd := strings.ToLower(strings.Split(sqlStr, " ")[0])
  25. if sqlMapsExecutor.parmas == nil {
  26. switch sqlCmd {
  27. case "select", "desc":
  28. model_1_results = sqlMapsExecutor.session.SqlMapClient(sqlkey).Query()
  29. case "insert", "delete", "update", "create":
  30. model_2_results, err = sqlMapsExecutor.session.SqlMapClient(sqlkey).Execute()
  31. sqlModel = 2
  32. }
  33. } else {
  34. switch sqlMapsExecutor.parmas.(type) {
  35. case []map[string]interface{}:
  36. parmaMap, ok := sqlMapsExecutor.parmas.([]map[string]interface{})
  37. if !ok {
  38. return nil, nil, ErrParamsType
  39. }
  40. switch sqlCmd {
  41. case "select", "desc":
  42. model_1_results = sqlMapsExecutor.session.SqlMapClient(sqlkey, &parmaMap[0]).Query()
  43. case "insert", "delete", "update", "create":
  44. model_2_results, err = sqlMapsExecutor.session.SqlMapClient(sqlkey, &parmaMap[0]).Execute()
  45. sqlModel = 2
  46. }
  47. case map[string]interface{}:
  48. parmaMap, ok := sqlMapsExecutor.parmas.(map[string]interface{})
  49. if !ok {
  50. return nil, nil, ErrParamsType
  51. }
  52. switch sqlCmd {
  53. case "select", "desc":
  54. model_1_results = sqlMapsExecutor.session.SqlMapClient(sqlkey, &parmaMap).Query()
  55. case "insert", "delete", "update", "create":
  56. model_2_results, err = sqlMapsExecutor.session.SqlMapClient(sqlkey, &parmaMap).Execute()
  57. sqlModel = 2
  58. }
  59. default:
  60. return nil, nil, ErrParamsType
  61. }
  62. }
  63. resultSlice := make([][]map[string]interface{}, 1)
  64. if sqlModel == 1 {
  65. if model_1_results.Error != nil {
  66. return nil, nil, model_1_results.Error
  67. }
  68. resultSlice[0] = make([]map[string]interface{}, len(model_1_results.Results))
  69. resultSlice[0] = model_1_results.Results
  70. return resultSlice, nil, nil
  71. } else {
  72. if err != nil {
  73. return nil, nil, err
  74. }
  75. resultMap := make([]map[string]interface{}, 1)
  76. resultMap[0] = make(map[string]interface{})
  77. //todo all database support LastInsertId
  78. LastInsertId, _ := model_2_results.LastInsertId()
  79. resultMap[0]["LastInsertId"] = LastInsertId
  80. RowsAffected, err := model_2_results.RowsAffected()
  81. if err != nil {
  82. return nil, nil, err
  83. }
  84. resultMap[0]["RowsAffected"] = RowsAffected
  85. resultSlice[0] = resultMap
  86. return resultSlice, nil, nil
  87. }
  88. case []string:
  89. if sqlMapsExecutor.session.IsSqlFuc == true {
  90. err := sqlMapsExecutor.session.Begin()
  91. if err != nil {
  92. return nil, nil, err
  93. }
  94. }
  95. sqlkeysSlice := sqlMapsExecutor.sqlkeys.([]string)
  96. n := len(sqlkeysSlice)
  97. resultSlice := make([][]map[string]interface{}, n)
  98. parmaSlice := make([]map[string]interface{}, n)
  99. switch sqlMapsExecutor.parmas.(type) {
  100. case []map[string]interface{}:
  101. parmaSlice = sqlMapsExecutor.parmas.([]map[string]interface{})
  102. default:
  103. if sqlMapsExecutor.session.IsSqlFuc == true {
  104. err := sqlMapsExecutor.session.Rollback()
  105. if err != nil {
  106. return nil, nil, err
  107. }
  108. }
  109. return nil, nil, ErrParamsType
  110. }
  111. for i, _ := range sqlkeysSlice {
  112. sqlkey := strings.TrimSpace(sqlkeysSlice[i])
  113. sqlStr := sqlMapsExecutor.session.Engine.GetSql(sqlkey)
  114. sqlCmd := strings.ToLower(strings.Split(sqlStr, " ")[0])
  115. if parmaSlice[i] == nil {
  116. switch sqlCmd {
  117. case "select", "desc":
  118. model_1_results = sqlMapsExecutor.session.SqlMapClient(sqlkey).Query()
  119. case "insert", "delete", "update", "create":
  120. model_2_results, err = sqlMapsExecutor.session.SqlMapClient(sqlkey).Execute()
  121. sqlModel = 2
  122. }
  123. } else {
  124. switch sqlCmd {
  125. case "select", "desc":
  126. model_1_results = sqlMapsExecutor.session.SqlMapClient(sqlkey, &parmaSlice[i]).Query()
  127. case "insert", "delete", "update", "create":
  128. model_2_results, err = sqlMapsExecutor.session.SqlMapClient(sqlkey, &parmaSlice[i]).Execute()
  129. sqlModel = 2
  130. }
  131. }
  132. if sqlModel == 1 {
  133. if model_1_results.Error != nil {
  134. if sqlMapsExecutor.session.IsSqlFuc == true {
  135. err := sqlMapsExecutor.session.Rollback()
  136. if err != nil {
  137. return nil, nil, err
  138. }
  139. }
  140. return nil, nil, model_1_results.Error
  141. }
  142. resultSlice[i] = make([]map[string]interface{}, len(model_1_results.Results))
  143. resultSlice[i] = model_1_results.Results
  144. } else {
  145. if err != nil {
  146. if sqlMapsExecutor.session.IsSqlFuc == true {
  147. err := sqlMapsExecutor.session.Rollback()
  148. if err != nil {
  149. return nil, nil, err
  150. }
  151. }
  152. return nil, nil, err
  153. }
  154. resultMap := make([]map[string]interface{}, 1)
  155. resultMap[0] = make(map[string]interface{})
  156. //todo all database support LastInsertId
  157. LastInsertId, _ := model_2_results.LastInsertId()
  158. resultMap[0]["LastInsertId"] = LastInsertId
  159. RowsAffected, err := model_2_results.RowsAffected()
  160. if err != nil {
  161. return nil, nil, err
  162. }
  163. resultMap[0]["RowsAffected"] = RowsAffected
  164. resultSlice[i] = make([]map[string]interface{}, 1)
  165. resultSlice[i] = resultMap
  166. }
  167. }
  168. if sqlMapsExecutor.session.IsSqlFuc == true {
  169. err := sqlMapsExecutor.session.Commit()
  170. if err != nil {
  171. return nil, nil, err
  172. }
  173. }
  174. return resultSlice, nil, nil
  175. case map[string]string:
  176. if sqlMapsExecutor.session.IsSqlFuc == true {
  177. err := sqlMapsExecutor.session.Begin()
  178. if err != nil {
  179. return nil, nil, err
  180. }
  181. }
  182. sqlkeysMap := sqlMapsExecutor.sqlkeys.(map[string]string)
  183. n := len(sqlkeysMap)
  184. resultsMap := make(map[string][]map[string]interface{}, n)
  185. parmasMap := make(map[string]map[string]interface{}, n)
  186. switch sqlMapsExecutor.parmas.(type) {
  187. case map[string]map[string]interface{}:
  188. parmasMap = sqlMapsExecutor.parmas.(map[string]map[string]interface{})
  189. default:
  190. if sqlMapsExecutor.session.IsSqlFuc == true {
  191. err := sqlMapsExecutor.session.Rollback()
  192. if err != nil {
  193. return nil, nil, err
  194. }
  195. }
  196. return nil, nil, ErrParamsType
  197. }
  198. for k, _ := range sqlkeysMap {
  199. sqlkey := strings.TrimSpace(sqlkeysMap[k])
  200. sqlStr := sqlMapsExecutor.session.Engine.GetSql(sqlkey)
  201. sqlCmd := strings.ToLower(strings.Split(sqlStr, " ")[0])
  202. if parmasMap[k] == nil {
  203. switch sqlCmd {
  204. case "select", "desc":
  205. model_1_results = sqlMapsExecutor.session.SqlMapClient(sqlkey).Query()
  206. case "insert", "delete", "update", "create":
  207. model_2_results, err = sqlMapsExecutor.session.SqlMapClient(sqlkey).Execute()
  208. sqlModel = 2
  209. }
  210. } else {
  211. parmaMap := parmasMap[k]
  212. switch sqlCmd {
  213. case "select", "desc":
  214. model_1_results = sqlMapsExecutor.session.SqlMapClient(sqlkey, &parmaMap).Query()
  215. case "insert", "delete", "update", "create":
  216. model_2_results, err = sqlMapsExecutor.session.SqlMapClient(sqlkey, &parmaMap).Execute()
  217. sqlModel = 2
  218. }
  219. }
  220. if sqlModel == 1 {
  221. if model_1_results.Error != nil {
  222. if sqlMapsExecutor.session.IsSqlFuc == true {
  223. err := sqlMapsExecutor.session.Rollback()
  224. if err != nil {
  225. return nil, nil, err
  226. }
  227. }
  228. return nil, nil, model_1_results.Error
  229. }
  230. resultsMap[k] = make([]map[string]interface{}, len(model_1_results.Results))
  231. resultsMap[k] = model_1_results.Results
  232. } else {
  233. if err != nil {
  234. if sqlMapsExecutor.session.IsSqlFuc == true {
  235. err := sqlMapsExecutor.session.Rollback()
  236. if err != nil {
  237. return nil, nil, err
  238. }
  239. }
  240. return nil, nil, err
  241. }
  242. resultMap := make([]map[string]interface{}, 1)
  243. resultMap[0] = make(map[string]interface{})
  244. //todo all database support LastInsertId
  245. LastInsertId, _ := model_2_results.LastInsertId()
  246. resultMap[0]["LastInsertId"] = LastInsertId
  247. RowsAffected, err := model_2_results.RowsAffected()
  248. if err != nil {
  249. if sqlMapsExecutor.session.IsSqlFuc == true {
  250. err := sqlMapsExecutor.session.Rollback()
  251. if err != nil {
  252. return nil, nil, err
  253. }
  254. }
  255. return nil, nil, err
  256. }
  257. resultMap[0]["RowsAffected"] = RowsAffected
  258. resultsMap[k] = make([]map[string]interface{}, 1)
  259. resultsMap[k] = resultMap
  260. }
  261. }
  262. if sqlMapsExecutor.session.IsSqlFuc == true {
  263. err := sqlMapsExecutor.session.Commit()
  264. if err != nil {
  265. return nil, nil, err
  266. }
  267. }
  268. return nil, resultsMap, nil
  269. }
  270. return nil, nil, nil
  271. }