AddTrener.xaml.cs 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262
  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 KursachMukha692gr
  17. {
  18. /// <summary>
  19. /// Логика взаимодействия для AddTrener.xaml
  20. /// </summary>
  21. public partial class AddTrener : Window
  22. {
  23. List<string> Alphabetrus = new List<string> {
  24. "А", "а", "Б", "б", "В", "в", "Г", "г", "Д", "д", "Е", "е", "Ё", "ё", "Ж", "ж", "З", "з", "И", "и", "Й", "й",
  25. "К", "к", "Л", "л", "М", "м", "Н", "н", "О", "о", "П", "п", "Р", "р", "С", "с", "Т", "т", "У", "у", "Ф", "ф",
  26. "Х", "х", "Ц", "ц", "Ч", "ч", "Ш", "ш", "Щ", "щ", "Ъ", "ъ", "Ы", "ы", "Ь", "ь", "Э", "э", "Ю", "ю", "Я", "я" };
  27. List<string> Date = new List<string> {
  28. "0","1","2","3","4","5","6","7","8","9","."};
  29. public AddTrener()
  30. {
  31. InitializeComponent();
  32. }
  33. public DataTable Select(string selectSQL)
  34. {
  35. DataTable dataTable = new DataTable("dataBase");
  36. SqlConnection sqlConnection = new SqlConnection("server=mssql; Trusted_Connection=YES;DataBase=gr692_mkm;");
  37. sqlConnection.Open();
  38. SqlCommand sqlCommand = sqlConnection.CreateCommand();
  39. sqlCommand.CommandText = selectSQL;
  40. SqlDataAdapter sqlDataAdapter = new SqlDataAdapter(sqlCommand);
  41. sqlDataAdapter.Fill(dataTable);
  42. sqlConnection.Close();
  43. return dataTable;
  44. }
  45. public DataTable Select1(string selectSQL)
  46. {
  47. DataTable dataTable = new DataTable("dataBase");
  48. SqlConnection sqlConnection = new SqlConnection("server=mssql; Trusted_Connection=YES;DataBase=gr692_mkm;");
  49. sqlConnection.Open();
  50. SqlCommand sqlCommand = sqlConnection.CreateCommand();
  51. sqlCommand.CommandText = selectSQL;
  52. SqlDataAdapter sqlDataAdapter = new SqlDataAdapter(sqlCommand);
  53. sqlDataAdapter.Fill(dataTable);
  54. sqlConnection.Close();
  55. return dataTable;
  56. }
  57. private void Button_Click_Add(object sender, RoutedEventArgs e)
  58. {
  59. if (familiyaTrener.Text != "" && imyaTrener.Text != "" && otchTrener.Text != "" && dataTrener.Text != "" && numberTrener.Text != "" && sportspec.Text != "" && pol_id.Text != "" && categoryTrener.Text!="")
  60. {
  61. bool fam = false, imya = false, otch = false, data = false, num = false;
  62. bool sport = false, pol = false,cat = false;
  63. for (int i = 0; i < familiyaTrener.Text.Length; i++)//проверка фамилии
  64. {
  65. if (fam)
  66. {
  67. fam = false;
  68. }
  69. for (int j = 0; j < Alphabetrus.Count; j++)
  70. {
  71. if (Convert.ToString(familiyaTrener.Text[i]).Contains(Alphabetrus[j]))
  72. {
  73. fam = true;
  74. break;
  75. }
  76. }
  77. if (fam == false)
  78. {
  79. MessageBox.Show("Поле фамилия должно содержать только русские символы");
  80. break;
  81. }
  82. }
  83. for (int i = 0; i < imyaTrener.Text.Length; i++)//проверка имени
  84. {
  85. if (imya)
  86. {
  87. imya = false;
  88. }
  89. for (int j = 0; j < Alphabetrus.Count; j++)
  90. {
  91. if (Convert.ToString(imyaTrener.Text[i]).Contains(Alphabetrus[j]))
  92. {
  93. imya = true;
  94. break;
  95. }
  96. }
  97. if (imya == false)
  98. {
  99. MessageBox.Show("Поле имя должно содержать только русские символы");
  100. break;
  101. }
  102. }
  103. for (int i = 0; i < otchTrener.Text.Length; i++)//проверка отчества
  104. {
  105. if (otch)
  106. {
  107. otch = false;
  108. }
  109. for (int j = 0; j < Alphabetrus.Count; j++)
  110. {
  111. if (Convert.ToString(otchTrener.Text[i]).Contains(Alphabetrus[j]))
  112. {
  113. otch = true;
  114. break;
  115. }
  116. }
  117. if (otch == false)
  118. {
  119. MessageBox.Show("Поле отчество должно содержать только русские символы");
  120. break;
  121. }
  122. }
  123. for (int i = 0; i < dataTrener.Text.Length; i++)//проверка даты рождения
  124. {
  125. if (data)
  126. {
  127. data = false;
  128. }
  129. for (int j = 0; j < Date.Count; j++)
  130. {
  131. if (Convert.ToString(dataTrener.Text[i]).Contains(Date[j]))
  132. {
  133. data = true;
  134. break;
  135. }
  136. }
  137. if (data == false)
  138. {
  139. MessageBox.Show("Поле дата рождения должно содержать только цифры и знак '.''");
  140. break;
  141. }
  142. }
  143. for (int i = 0; i < numberTrener.Text.Length; i++)//проверка номера телефона
  144. {
  145. if (num)
  146. {
  147. num = false;
  148. }
  149. if (numberTrener.Text[i] >= '0' && numberTrener.Text[i] <= '9' && numberTrener.Text.Length == 11)
  150. {
  151. num = true;
  152. break;
  153. }
  154. if (num == false)
  155. {
  156. MessageBox.Show("Поле номер телефона должно содержать только цифры (без знака + и 11 цифр)");
  157. break;
  158. }
  159. }
  160. DataTable sel = Select("select * from [dbo].[disciplina] where id = " + sportspec.Text);
  161. for (int i = 0; i < sportspec.Text.Length; i++)
  162. {
  163. if (sport)
  164. {
  165. sport = false;
  166. }
  167. if (sportspec.Text[i] >='1' && sportspec.Text[i]<= '7' && sportspec.Text.Length == 1)
  168. {
  169. if (sel.Rows.Count > 0)
  170. {
  171. sport = true;
  172. }
  173. else
  174. {
  175. sport = false;
  176. }
  177. }
  178. if (sport == false)
  179. {
  180. MessageBox.Show("Поле спортивная специальность должно содержать код специальности (1-хоккей,2-Мини-футбол,3-Волейбол,4-Футбол,5-Баскетбол,6-Плавание,7-Бокс)");
  181. break;
  182. }
  183. }
  184. DataTable sel1 = Select1("select * from [dbo].[pol] where id = " + pol_id.Text);
  185. for (int i = 0; i < pol_id.Text.Length; i++)
  186. {
  187. if (pol)
  188. {
  189. pol = false;
  190. }
  191. if (pol_id.Text[i] == '1' || pol_id.Text[i] == '2' && pol_id.Text.Length == 1)
  192. {
  193. if (sel1.Rows.Count > 0)
  194. {
  195. pol = true;
  196. }
  197. else
  198. {
  199. pol = false;
  200. }
  201. }
  202. if (pol == false)
  203. {
  204. MessageBox.Show("Поле пол должно содержать только цифры 1 (мужской) и 2 (женский)");
  205. break;
  206. }
  207. }
  208. for (int i = 0; i < categoryTrener.Text.Length; i++)
  209. {
  210. if (cat)
  211. {
  212. cat = false;
  213. }
  214. if (categoryTrener.Text[i] >= '1' && categoryTrener.Text[i] <= '9' || categoryTrener.Text[i] >= 'A' && categoryTrener.Text[i] <= 'Z')
  215. {
  216. cat = true;
  217. break;
  218. }
  219. if (cat == false)
  220. {
  221. MessageBox.Show("Поле тренерская категория должно содержать только английские (заглавные) буквы и цифры");
  222. break;
  223. }
  224. }
  225. if (fam && imya && otch && data && num && sport && pol && cat)
  226. {
  227. DataTable dt_infotrener = Insert("insert into [dbo].[infotrener] values " +
  228. "('" + familiyaTrener.Text + "','" + imyaTrener.Text + "','" + otchTrener.Text +
  229. "','" + dataTrener.Text + "','" + numberTrener.Text + "','" + sportspec.Text +
  230. "','" + categoryTrener.Text + "','" + pol_id.Text + "')");
  231. MessageBox.Show("Тренер добавлен");
  232. SpisokTrenerov mainreg = new SpisokTrenerov();
  233. mainreg.Show();
  234. Close();
  235. }
  236. else { MessageBox.Show("Неправильный формат"); }
  237. }
  238. else { MessageBox.Show("Все строки должны быть заполнены"); }
  239. }
  240. public DataTable Insert(string selectSQL)
  241. {
  242. DataTable dataTable = new DataTable("dataBase");
  243. SqlConnection sqlConnection = new SqlConnection("server=mssql; Trusted_Connection=YES;DataBase=gr692_mkm;");
  244. sqlConnection.Open();
  245. SqlCommand sqlCommand = sqlConnection.CreateCommand();
  246. sqlCommand.CommandText = selectSQL;
  247. SqlDataAdapter sqlDataAdapter = new SqlDataAdapter(sqlCommand);
  248. sqlDataAdapter.Fill(dataTable);
  249. sqlConnection.Close();
  250. return dataTable;
  251. }
  252. private void Button_Click_Back(object sender, RoutedEventArgs e)
  253. {
  254. SpisokTrenerov trenerov = new SpisokTrenerov();
  255. trenerov.Show();
  256. Close();
  257. }
  258. }
  259. }