您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

KitRepository.asp 6.2KB

9 个月前
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222
  1. <%
  2. '=======================================================================================================================
  3. ' Kit Model
  4. '=======================================================================================================================
  5. Class KitModel_Class
  6. Public Validator
  7. Public Class_Get_Properties
  8. Public ID '90
  9. Public JobNumber '106
  10. Public Jcode '106
  11. Private Sub Class_Initialize
  12. 'ValidateExitsts Me, "",""
  13. Class_Get_Properties = Array("ID, JobNumber, Jcode")
  14. End Sub
  15. End CLass
  16. '=======================================================================================================================
  17. ' Kit Repository
  18. '=======================================================================================================================
  19. Class KitRepository_Class
  20. Public Function FindByID(ID)
  21. dim sql : sql = "Select [ID], [JobNumber], [Jcode] FROM [Kit] WHERE ID = ?"
  22. dim rs : set rs = DAL.Query(sql,ID)
  23. If rs.EOF then
  24. Err.Raise 1, "KitRepository_Class", KitNotFoundException("ID", ID)
  25. Else
  26. set FindByID = Automapper.AutoMap(rs,"KitModel_Class")
  27. End If
  28. End Function
  29. Public Function GetAll(orderBy)
  30. set GetAll = Find(empty,orderBy)
  31. End Function
  32. Public Function Find(where_kvarray, order_string_or_array)
  33. dim sql : sql = "Select [ID], [JobNumber], [Jcode] FROM [Kit]"
  34. If Not IsEmpty(where_kvarray) then
  35. sql = sql & " WHERE "
  36. dim where_keys, where_values
  37. KVUnzip where_kvarray, where_keys, where_values
  38. dim i
  39. For i = 0 to UBound(where_keys)
  40. If i > 0 then sql = sql & " AND "
  41. sql = sql & " " & where_keys(i) & " "
  42. Next
  43. End If
  44. If Not IsEmpty(order_string_or_array) then
  45. sql = sql & "ORDER BY "
  46. If IsArray(order_string_or_array) then
  47. dim order_array : order_array = order_string_or_array
  48. For i = 0 to UBound(order_array)
  49. If i > 0 then sql = sql & ", "
  50. sql = sql & " " & order_array(i)
  51. Next
  52. Else
  53. sql = sql & order_string_or_array & " "
  54. End If
  55. End If
  56. dim rs : set rs = DAL.Query(sql, where_values)
  57. set Find = KitList(rs)
  58. Destroy rs
  59. End Function
  60. Public Function FindPaged(where_kvarray, order_string_or_array, per_page, page_num, ByRef page_count, ByRef record_count)
  61. dim sql : sql = "Select [ID], [JobNumber], [Jcode] FROM [Kit]"
  62. If Not IsEmpty(where_kvarray) then
  63. sql = sql & " WHERE "
  64. dim where_keys, where_values
  65. KVUnzip where_kvarray, where_keys, where_values
  66. dim i
  67. For i = 0 to UBound(where_keys)
  68. If i > 0 then sql = sql & " AND "
  69. sql = sql & " " & where_keys(i) & " "
  70. Next
  71. End If
  72. If Not IsEmpty(order_string_or_array) then
  73. sql = sql & "ORDER BY "
  74. If IsArray(order_string_or_array) then
  75. dim order_array : order_array = order_string_or_array
  76. For i = 0 to UBound(order_array)
  77. If i > 0 then sql = sql & ", "
  78. sql = sql & " " & order_array(i)
  79. Next
  80. Else
  81. sql = sql & order_string_or_array & " "
  82. End If
  83. End If
  84. dim list : set list = new LinkedList_Class
  85. dim rs : set rs = DAL.PagedQuery(sql, where_values, per_page, page_num)
  86. If Not rs.EOF and Not (IsEmpty(per_page) and IsEmpty(page_num) and IsEmpty(page_count) and IsEmpty(record_count)) then
  87. rs.PageSize = per_page
  88. rs.AbsolutePage = page_num
  89. page_count = rs.PageCount
  90. record_count = rs.RecordCount
  91. End If
  92. set FindPaged = PagedKitList(rs, per_page)
  93. Destroy rs
  94. End Function
  95. Public Function SearchTablePaged(where_kvarray, order_string_or_array, per_page, page_num, ByRef page_count, ByRef record_count)
  96. dim sql : sql = "Select [ID], [JobNumber], [Jcode] FROM [Kit]"
  97. If Not IsEmpty(where_kvarray) then
  98. sql = sql & " WHERE "
  99. dim where_keys, where_values
  100. KVUnzip where_kvarray, where_keys, where_values
  101. dim i
  102. For i = 0 to UBound(where_keys)
  103. If i > 0 then sql = sql & " OR"
  104. sql = sql & " " & where_keys(i) & " LIKE ?"
  105. Next
  106. End If
  107. If Not IsEmpty(order_string_or_array) then
  108. sql = sql & " ORDER BY "
  109. If IsArray(order_string_or_array) then
  110. dim order_array : order_array = order_string_or_array
  111. For i = 0 to UBound(order_array)
  112. If i > 0 then sql = sql & ", "
  113. sql = sql & " " & order_array(i)
  114. Next
  115. Else
  116. sql = sql & order_string_or_array & " "
  117. End If
  118. End If
  119. dim list : set list = new LinkedList_Class
  120. dim rs : set rs = DAL.PagedQuery(sql, where_values, per_page, page_num)
  121. If Not rs.EOF and Not (IsEmpty(per_page) and IsEmpty(page_num) and IsEmpty(page_count) and IsEmpty(record_count)) then
  122. rs.PageSize = per_page
  123. rs.AbsolutePage = page_num
  124. page_count = rs.PageCount
  125. record_count = rs.RecordCount
  126. End If
  127. set SearchTablePaged = PagedKitList(rs, per_page)
  128. Destroy rs
  129. End Function
  130. Private Function PagedKitList(rs, per_page)
  131. dim list : set list = new LinkedList_Class
  132. dim x : x =0
  133. Do While x < per_page and Not rs.EOF
  134. list.Push Automapper.AutoMap(rs, new KitModel_Class)
  135. x = x +1
  136. rs.MoveNext
  137. Loop
  138. set PagedKitList = list
  139. End Function
  140. Private Function KitNotFoundException(ByVal field_name, ByVal field_val)
  141. KitNotFoundException = "Kit was not found with " & field_name & " of '" & field_val & "'."
  142. End Function
  143. Private Function KitList(rs)
  144. dim list : set list = new LinkedList_Class
  145. dim model
  146. Do until rs.EOF
  147. set model = new KitModel_Class
  148. list.Push Automapper.AutoMap(rs, model)
  149. rs.MoveNext
  150. Loop
  151. set KitList = list
  152. End Function
  153. Public Sub AddNew(ByRef model)
  154. dim sql : sql = "INSERT INTO [Kit] (" &_
  155. "[JobNumber]," &_
  156. "[Jcode])" &_
  157. "VALUES (?,?)"
  158. DAL.Execute sql, Array(model.JobNumber, _
  159. model.Jcode)
  160. sql = "SELECT TOP 1 ID FROM [Kit] ORDER BY ID DESC"
  161. dim rs : set rs = DAL.Query(sql, empty)
  162. model.ID = rs("ID")
  163. Destroy rs
  164. End Sub
  165. Public Sub Update(model)
  166. dim sql : sql = "UPDATE [Kit] SET [JobNumber] = ?," &_
  167. "[Jcode] = ?" &_
  168. " WHERE [ID] = ?"
  169. DAL.Execute sql, Array(model.JobNumber, _
  170. model.Jcode, _
  171. model.ID)
  172. End Sub
  173. Public Sub Delete(id)
  174. dim sql : sql = "DELETE FROM [Kit] WHERE [ID] = ?"
  175. DAL.Execute sql, id
  176. End Sub
  177. End Class
  178. dim KitRepository__Singleton
  179. Function KitRepository()
  180. If IsEmpty(KitRepository__Singleton) then
  181. set KitRepository__Singleton = new KitRepository_Class
  182. End If
  183. set KitRepository = KitRepository__Singleton
  184. End Function
  185. %>

Powered by TurnKey Linux.