InsertZakaz.xaml.cs 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data;
  4. using System.Data.SqlClient;
  5. using System.Linq;
  6. using System.Text;
  7. using System.Threading.Tasks;
  8. using System.Windows;
  9. using System.Windows.Controls;
  10. using System.Windows.Data;
  11. using System.Windows.Documents;
  12. using System.Windows.Input;
  13. using System.Windows.Media;
  14. using System.Windows.Media.Imaging;
  15. using System.Windows.Shapes;
  16. namespace veloprokat2
  17. {
  18. /// <summary>
  19. /// Логика взаимодействия для InsertZakaz.xaml
  20. /// </summary>
  21. public partial class InsertZakaz : Window
  22. {
  23. List<string> Datee = new List<string> {
  24. "0","1","2","3","4","5","6","7","8","9","."};
  25. List<string> Timee = new List<string> {
  26. "0","1","2","3","4","5","6","7","8","9",":"};
  27. List<string> Countt = new List<string> {
  28. "0","1","2","3","4","5","6","7","8","9"};
  29. public InsertZakaz()
  30. {
  31. InitializeComponent();
  32. }
  33. private void Registraciya(object sender, RoutedEventArgs e)
  34. {
  35. if (NumberZakaza.Text !="" && NumberBikes.Text !="" && NumberTarif.Text !="" && Date.Text !="" && Time.Text !="" && Count.Text !="")
  36. {
  37. bool zakaz = false; bool bikes = false; bool tarif = false; bool date = false; bool time = false; bool count = false;
  38. for(int i=0;i<NumberZakaza.Text.Length;i++)
  39. {
  40. if(bikes)
  41. {
  42. bikes = false;
  43. }
  44. for(int j=0;j<Countt.Count;j++)
  45. {
  46. if (Convert.ToString(NumberZakaza.Text[i]).Contains(Countt[j]))
  47. {
  48. bikes = true;
  49. break;
  50. }
  51. }
  52. if (bikes == false)
  53. {
  54. MessageBox.Show("Поле номер заказа должно содержать только цифры");
  55. break;
  56. }
  57. }
  58. for (int i = 0; i < NumberBikes.Text.Length; i++)
  59. {
  60. if (zakaz)
  61. {
  62. zakaz = false;
  63. }
  64. for (int j = 0; j < Countt.Count; j++)
  65. {
  66. if (Convert.ToString(NumberBikes.Text[i]).Contains(Countt[j]))
  67. {
  68. zakaz = true;
  69. break;
  70. }
  71. }
  72. if (zakaz == false)
  73. {
  74. MessageBox.Show("Поле номер велосипеда должно содержать только цифры");
  75. break;
  76. }
  77. }
  78. for (int i = 0; i < NumberTarif.Text.Length; i++)
  79. {
  80. if (tarif)
  81. {
  82. tarif = false;
  83. }
  84. for (int j = 0; j < Countt.Count; j++)
  85. {
  86. if (Convert.ToString(NumberTarif.Text[i]).Contains(Countt[j]))
  87. {
  88. tarif = true;
  89. break;
  90. }
  91. }
  92. if (tarif == false)
  93. {
  94. MessageBox.Show("Поле номер тарифа должно содержать только цифры");
  95. break;
  96. }
  97. }
  98. for (int i = 0; i < Date.Text.Length; i++)
  99. {
  100. if (date)
  101. {
  102. date = false;
  103. }
  104. for (int j = 0; j < Datee.Count; j++)
  105. {
  106. if (Convert.ToString(Date.Text[i]).Contains(Datee[j]))
  107. {
  108. date = true;
  109. break;
  110. }
  111. }
  112. if (date == false)
  113. {
  114. MessageBox.Show("Поле дата должно содержать только цифры и знак '.'");
  115. break;
  116. }
  117. }
  118. for (int i = 0; i < Time.Text.Length; i++)
  119. {
  120. if (time)
  121. {
  122. time = false;
  123. }
  124. for (int j = 0; j < Timee.Count; j++)
  125. {
  126. if (Convert.ToString(Time.Text[i]).Contains(Timee[j]))
  127. {
  128. time = true;
  129. break;
  130. }
  131. }
  132. if (date == false)
  133. {
  134. MessageBox.Show("Поле время должно содержать только цифры и знак ':'");
  135. break;
  136. }
  137. }
  138. for (int i = 0; i < Count.Text.Length; i++)
  139. {
  140. if (count)
  141. {
  142. count = false;
  143. }
  144. for (int j = 0; j < Countt.Count; j++)
  145. {
  146. if (Convert.ToString(Count.Text[i]).Contains(Countt[j]))
  147. {
  148. count = true;
  149. break;
  150. }
  151. }
  152. if (count == false)
  153. {
  154. MessageBox.Show("Поле количество должно содержать только цифры");
  155. break;
  156. }
  157. }
  158. if (zakaz && bikes && tarif && date && time && count)
  159. {
  160. DataTable SpisProk = Insert("insert into [dbo].[SpisProk] values " +
  161. "('" + NumberZakaza.Text + "','" + NumberBikes.Text + "','" + NumberTarif.Text +
  162. "','" + Date.Text + "','" + Time.Text + "','" + Count.Text + "','" + Lname.Text + "','" + NumberEmp.Text + "')");
  163. MessageBox.Show("Заказ добавлен");
  164. MainWindowProd MWP = new MainWindowProd();
  165. MWP.Show();
  166. Close();
  167. }
  168. }
  169. }
  170. private void Otmena(object sender, RoutedEventArgs e)
  171. {
  172. MainWindowProd MWP = new MainWindowProd();
  173. MWP.Show();
  174. Close();
  175. }
  176. public DataTable Insert(string selectSQL) // функция подключения к базе данных и обработка запросов
  177. {
  178. DataTable dataTable = new DataTable("dataBase"); // создаём таблицу в приложении
  179. // подключаемся к базе данных
  180. SqlConnection sqlConnection = new SqlConnection("server=mssql;Trusted_Connection=Yes;DataBase=gr692_kaa;");
  181. sqlConnection.Open(); // открываем базу данных
  182. SqlCommand sqlCommand = sqlConnection.CreateCommand(); // создаём команду
  183. sqlCommand.CommandText = selectSQL; // присваиваем команде текст
  184. SqlDataAdapter sqlDataAdapter = new SqlDataAdapter(sqlCommand); // создаём обработчик
  185. sqlDataAdapter.Fill(dataTable); // возращаем таблицу с результатом
  186. return dataTable;
  187. }
  188. }
  189. }