insertDrug.cs 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. using System;
  2. using System.Collections.Generic;
  3. using System.ComponentModel;
  4. using System.Data;
  5. using System.Drawing;
  6. using System.Linq;
  7. using System.Text;
  8. using System.Threading.Tasks;
  9. using System.Windows.Forms;
  10. using System.Data.SqlClient;
  11. namespace hospital
  12. {
  13. public partial class insertDrug : Form
  14. {
  15. SqlConnection sqlConnection = null;
  16. public insertDrug()
  17. {
  18. InitializeComponent();
  19. }
  20. private void button1_Click(object sender, EventArgs e)
  21. {
  22. try
  23. {
  24. bool checkTB = false, checkNUD = false;
  25. foreach (TextBox textBox in this.Controls.OfType<TextBox>())
  26. {
  27. if (String.IsNullOrEmpty(textBox.Text) && textBox.Visible == true)
  28. {
  29. checkTB = true;
  30. break;
  31. }
  32. }
  33. foreach (NumericUpDown numericUpDown in this.Controls.OfType<NumericUpDown>())
  34. {
  35. if(numericUpDown.Value == numericUpDown.Minimum)
  36. {
  37. checkNUD = true;
  38. break;
  39. }
  40. }
  41. if (!checkTB && !checkNUD)
  42. {
  43. SqlCommand a = new SqlCommand($"select count(*) from drugs where name_drugs like N'{drugNameTB.Text}'", sqlConnection);
  44. Array.Resize(ref auth.data, 2);
  45. auth.data[0] = $"Лекарство: {drugNameTB.Text}";
  46. auth.data[1] = $"Стоимость: {priceNUD.Value}";
  47. a = new SqlCommand($"select name_drugs from drugs", sqlConnection);
  48. SqlDataReader reader = a.ExecuteReader();
  49. string[] xd = new string[0];
  50. int i = 0;
  51. while (reader.Read())
  52. {
  53. Array.Resize(ref xd, xd.Length + 1);
  54. xd[i] = reader.GetString(0);
  55. i++;
  56. }
  57. bool check = false;
  58. for (int j = 0; j < xd.Length; j++)
  59. {
  60. if (drugNameTB.Text.Equals(xd[j]))
  61. {
  62. check = true;
  63. break;
  64. }
  65. }
  66. reader.Close();
  67. if (!check)
  68. {
  69. a = new SqlCommand($"insert into drugs (name_drugs, price_drugs) values (@name_drugs, @price_drugs)", sqlConnection);
  70. a.Parameters.AddWithValue("name_drugs", drugNameTB.Text);
  71. a.Parameters.AddWithValue("price_drugs", priceNUD.Value);
  72. if (a.ExecuteNonQuery() == 1)
  73. {
  74. MessageBox.Show("Добавление данных произошло успешно", "Уведомление", MessageBoxButtons.OK, MessageBoxIcon.Information);
  75. debugAndTrace.writeInFile("Добавление лекарства", auth.data);
  76. debugAndTrace.writeInFile("Переход на главную форму");
  77. this.Close();
  78. }
  79. else
  80. {
  81. MessageBox.Show("Произошла ошибка", "Ошибка", MessageBoxButtons.OK, MessageBoxIcon.Error);
  82. debugAndTrace.writeInFile("Ошибка добавления лекарства", auth.data);
  83. }
  84. }
  85. else
  86. {
  87. MessageBox.Show("Такое лекарство уже добавлено", "Ошибка", MessageBoxButtons.OK, MessageBoxIcon.Error);
  88. debugAndTrace.writeInFile("Такое лекарство уже добавлено", auth.data);
  89. }
  90. }
  91. else
  92. {
  93. MessageBox.Show("Заполнены не все поля", "Ошибка", MessageBoxButtons.OK, MessageBoxIcon.Error);
  94. debugAndTrace.writeInFile("Error, заполнены не все поля");
  95. }
  96. }
  97. catch
  98. {
  99. MessageBox.Show("Произошла непредвиденная ошибка", "Ошибка", MessageBoxButtons.OK, MessageBoxIcon.Error);
  100. debugAndTrace.writeInFile("ERROR");
  101. }
  102. }
  103. private void insertDrug_Load(object sender, EventArgs e)
  104. {
  105. FormCreating.openConnection(ref sqlConnection);
  106. }
  107. private void backBTN_Click(object sender, EventArgs e)
  108. {
  109. try
  110. {
  111. var res = MessageBox.Show("Уверены, что хотите отменить добавление лекарства?", "Предупреждение", MessageBoxButtons.YesNo, MessageBoxIcon.Question);
  112. if (res == DialogResult.Yes)
  113. {
  114. debugAndTrace.writeInFile("Отмена добавления лекарства");
  115. this.Close();
  116. }
  117. else
  118. {
  119. MessageBox.Show("Действие отменено", "Уведомление", MessageBoxButtons.OK, MessageBoxIcon.Information);
  120. }
  121. }
  122. catch
  123. {
  124. MessageBox.Show("Произошла непредвиденная ошибка", "Ошибка", MessageBoxButtons.OK, MessageBoxIcon.Error);
  125. debugAndTrace.writeInFile("ERROR");
  126. }
  127. }
  128. }
  129. }