TestInsertBikes.xaml.cs 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219
  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. /// Логика взаимодействия для TestInsertBikes.xaml
  20. /// </summary>
  21. public partial class TestInsertBikes : Window
  22. {
  23. List<string> Alphabetrus = new List<string> {
  24. "А", "а", "Б", "б", "В", "в", "Г", "г", "Д", "д", "Е", "е", "Ё", "ё", "Ж", "ж", "З", "з", "И", "и", "Й", "й",
  25. "К", "к", "Л", "л", "М", "м", "Н", "н", "О", "о", "П", "п", "Р", "р", "С", "с", "Т", "т", "У", "у", "Ф", "ф",
  26. "Х", "х", "Ц", "ц", "Ч", "ч", "Ш", "ш", "Щ", "щ", "Ъ", "ъ", "Ы", "ы", "Ь", "ь", "Э", "э", "Ю", "ю", "Я", "я",
  27. "0", "1", "2", "3", "4", "5", "6", "7", "8", "9", ".", "-", "_"};
  28. List<string> Number = new List<string> {
  29. "0","1","2","3","4","5","6","7","8","9"};
  30. public TestInsertBikes()
  31. {
  32. InitializeComponent();
  33. }
  34. public bool TestInsert(string numberofbikes, string company, string title, string type, string zan, string idadm)
  35. {
  36. numberofbikes = NumberOfBikes.Text;
  37. company = Company.Text;
  38. title = Title.Text;
  39. type = Type.Text;
  40. zan = Zan.Text;
  41. idadm = LnameAdm.Text;
  42. if (numberofbikes != "" && company != "" && title != "" && type != "" && zan != "" && idadm != "")
  43. {
  44. bool Comp = false, tit = false, numbofbike = false, tip = false, zAn = false, idAdm = false;
  45. for (int i = 0; i < numberofbikes.Length; i++)
  46. {
  47. if (numbofbike)
  48. {
  49. numbofbike = false;
  50. }
  51. for (int j = 0; j < Number.Count; j++)
  52. {
  53. if (Convert.ToString(numberofbikes[i]).Contains(Number[j]))
  54. {
  55. numbofbike = true;
  56. break;
  57. }
  58. }
  59. if (numbofbike == false)
  60. {
  61. MessageBox.Show("Поле Номер велосипеда должно содержать только цифры");
  62. return false;
  63. }
  64. }
  65. for (int i = 0; i < company.Length; i++)
  66. {
  67. if (Comp)
  68. {
  69. Comp = false;
  70. }
  71. if (company[i] >= 'A' && company[i] <= 'Z' || company[i] >= 'a' && company[i] <= 'z')
  72. {
  73. Comp = true;
  74. break;
  75. }
  76. if (Comp == false)
  77. {
  78. MessageBox.Show("Поле Компания должно содержать только английские символы");
  79. return false;
  80. }
  81. }
  82. for (int i = 0; i < title.Length; i++)
  83. {
  84. if (tit)
  85. {
  86. tit = false;
  87. }
  88. for (int j = 0; j < Alphabetrus.Count; j++)
  89. {
  90. if (title[i] >= 'A' && title[i] <= 'Z' || title[i] >= 'a' && title[i] <= 'z')
  91. {
  92. tit = true;
  93. break;
  94. }
  95. }
  96. if (tit == false)
  97. {
  98. MessageBox.Show("Поле Модель должно содержать только русские символы");
  99. return false;
  100. }
  101. }
  102. for (int i = 0; i < type.Length; i++)
  103. {
  104. if (tip)
  105. {
  106. tip = false;
  107. }
  108. for (int j = 0; j < Alphabetrus.Count; j++)
  109. {
  110. if (Convert.ToString(type[i]).Contains(Alphabetrus[j]))
  111. {
  112. tip = true;
  113. break;
  114. }
  115. }
  116. if (tip == false)
  117. {
  118. MessageBox.Show("Поле Тип должно содержать только русские символы и цифры");
  119. return false;
  120. }
  121. }
  122. if (zan == "Свободен" || zan == "Занят" || zan == "В тех. обслуживании")
  123. {
  124. zAn = true;
  125. return true;
  126. }
  127. else
  128. {
  129. MessageBox.Show("Поле 'занятость должно включать только одно из значений!'");
  130. return false;
  131. }
  132. for (int i = 0; i < idadm.Length; i++)
  133. {
  134. if (idAdm)
  135. {
  136. idAdm = false;
  137. }
  138. for (int j = 0; j < Number.Count; j++)
  139. {
  140. if (Convert.ToString(idadm[i]).Contains(Number[j]))
  141. {
  142. idAdm = true;
  143. break;
  144. }
  145. }
  146. if (idAdm == false)
  147. {
  148. MessageBox.Show("Поле Номер велосипеда должно содержать только цифры");
  149. return false;
  150. }
  151. }
  152. if (numbofbike && Comp && tit && tip && zAn && idAdm)
  153. {
  154. if (zan == "Свободен")
  155. {
  156. DataTable InfoAdm = Insert("insert into [dbo].[Bikes] values " +
  157. "('" + NumberOfBikes.Text + "','" + Company.Text + "','" + Title.Text + "','" + Type.Text + "', 1)");
  158. MessageBox.Show("Велосипед добавлен");
  159. InfoBikes SB = new InfoBikes();
  160. SB.Show();
  161. Close();
  162. return true;
  163. }
  164. else if (zan == "Занят")
  165. {
  166. DataTable InfoAdm = Insert("insert into [dbo].[Bikes] values " +
  167. "('" + NumberOfBikes.Text + "','" + Company.Text + "','" + Title.Text + "','" + Type.Text + "', 2)");
  168. MessageBox.Show("Велосипед добавлен");
  169. InfoBikes SB = new InfoBikes();
  170. SB.Show();
  171. Close();
  172. return true;
  173. }
  174. else if (zan == "В тех. обслуживании")
  175. {
  176. DataTable InfoAdm = Insert("insert into [dbo].[Bikes] values " +
  177. "('" + NumberOfBikes.Text + "','" + Company.Text + "','" + Title.Text + "','" + Type.Text + "', 3)");
  178. MessageBox.Show("Велосипед добавлен");
  179. InfoBikes SB = new InfoBikes();
  180. SB.Show();
  181. Close();
  182. return true;
  183. }
  184. }
  185. else { MessageBox.Show("Неправильный формат"); return false; }
  186. }
  187. else { MessageBox.Show("Все строки должны быть заполнены"); return false; }
  188. }
  189. private void Registraciya(object sender, RoutedEventArgs e)
  190. {
  191. }
  192. private void Otmena(object sender, RoutedEventArgs e)
  193. {
  194. }
  195. public DataTable Insert(string selectSQL) // функция подключения к базе данных и обработка запросов
  196. {
  197. DataTable dataTable = new DataTable("dataBase"); // создаём таблицу в приложении
  198. // подключаемся к базе данных
  199. SqlConnection sqlConnection = new SqlConnection("server=mssql;Trusted_Connection=Yes;DataBase=gr692_kaa;");
  200. sqlConnection.Open(); // открываем базу данных
  201. SqlCommand sqlCommand = sqlConnection.CreateCommand(); // создаём команду
  202. sqlCommand.CommandText = selectSQL; // присваиваем команде текст
  203. SqlDataAdapter sqlDataAdapter = new SqlDataAdapter(sqlCommand); // создаём обработчик
  204. sqlDataAdapter.Fill(dataTable); // возращаем таблицу с результатом
  205. return dataTable;
  206. }
  207. }
  208. }