Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/11: Рейтинг темы: голосов - 11, средняя оценка - 4.73
0 / 0 / 0
Регистрация: 14.10.2017
Сообщений: 6
MS SQL

Исключение при вызове ExecuteReader()

14.10.2017, 16:45. Показов 2271. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день , пишу программу где требуется авторизация , вроде по коду все верно но в месте read = cmd.ExecuteReader();-данная строка не выполняется и в итоге переходит сразу в catch . В чём причина , подскажите пожалуйста.

Вот сам код формы.

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Data.SqlClient;
 
namespace Maraphon
{
    public partial class Form3 : Form
    {
        SqlConnection conect = new SqlConnection(Properties.Settings.Default.WSConnectionString);
        SqlDataReader read;
        SqlCommand cmd;
        
        public Form3()
        {
            InitializeComponent();
        }
private void button4_Click(object sender, EventArgs e)
        {
            if (string.IsNullOrEmpty(textBox1.Text)) 
            {
                MessageBox.Show("Введите Email");
                textBox1.Focus();
                return;
            }
            else if (string.IsNullOrEmpty(textBox2.Text))
            {
                MessageBox.Show("Введите пароль");
                textBox2.Focus();
                return;
            }
            else{
                conect.Open();
                cmd = new SqlCommand(@"SELECT  [Password], [Roled]
                                     FROM dbo.[User]
                                     WHERE Email =" +textBox1 ,conect);
                try
                {
 
                     read =  cmd.ExecuteReader();
                    
                    read.Read();
                   
                    if(textBox2.Text == read[0].ToString())
                    {
                        Program.Email = textBox1.Text;
                        Program.Password = textBox2.Text;
                        Program.Roled = read[1].ToString();
 
                        switch(Program.Roled)
                        {
                            case"R":
                                Form7 Form7 = new Form7();
                                Form7.ShowDialog();
                                break;
                            case"C":
                                 Form14 Form14 = new Form14();
                                Form14.ShowDialog();
                                break;
                            case"A":
                                 Form15 Form15 = new Form15();
                                Form15.ShowDialog();
                                break;
                                           
                        }
                                           }
                    else
                    {
                        MessageBox.Show("Связка логин-пароль введены неверно\nПроверьте введеные вами данные и повторите попытку");
                        textBox1.Focus();
                    }
                    read.Close();
                }
               catch
                {
                    MessageBox.Show("Пользователь с таким логином не зарегистрирован в системе\nПроверьте введённые данные и повторите попытку");
                    textBox1.Focus();
                }
                finally
                {
                    conect.Close();
                }
            }
 
        }         
    }
}
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.10.2017, 16:45
Ответы с готовыми решениями:

ExecuteReader()
Вот код который работал, после того как я удалил с одной и той же БД таблицу и создал новую таблицу перстал работать(Менял...

Асинхронный ExecuteReader
Добрый день друзья! Помогите мне пожалуйста открыть соединение и выполнить чтения из БД асинхронно! Вот конкретный пример: public...

ExecuteReader проверка наличия данных
Если ввести логин которого нет в базе, то переменная dr в себе ничего иметь не будет, как это понять программно?для того что бы вывести...

8
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18273 / 14196 / 5368
Регистрация: 17.03.2014
Сообщений: 28,881
Записей в блоге: 1
14.10.2017, 17:51
Лучший ответ Сообщение было отмечено PustoyPetr как решение

Решение

PustoyPetr, у тебя ошибка в тексте запроса - не хватает одинарных кавычек и в запрос нужно подставлять значение свойства Text
C#
1
2
3
                cmd = new SqlCommand(@"SELECT  [Password], [Roled]
                                     FROM dbo.[User]
                                     WHERE Email = '" +textBox1.Text + "'", conect);
Еще лучше сразу приучить себя к использованию параметризованных запросов:
C#
1
2
3
4
                cmd = new SqlCommand(@"SELECT  [Password], [Roled]
                                     FROM dbo.[User]
                                     WHERE Email = @Email", conect);
                cmd.Parameters.AddWithValue("@Email", textBox1.Text);
Добавлено через 3 минуты
Цитата Сообщение от PustoyPetr Посмотреть сообщение
в итоге переходит сразу в catch
Обработка исключений неудачно организоавана. Во-первых объект исключения нужно иметь под рукой чтобы знать что именно пошло не так. Во-вторых, проверку отсутствия записи лучше завязать на результат метода Read(). В третьих ловить абсолютно все исключения плохая практика - правильнее ловить конкретные.
1
0 / 0 / 0
Регистрация: 14.10.2017
Сообщений: 6
15.10.2017, 13:07  [ТС]
А не подскажете здесь , в чем ошибка ?

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
private void butIns_Click(object sender, EventArgs e)
        {
            SqlCommand cmd;
            conect.Open();
 
              cmd = new SqlCommand(@"INSERT INTO [User](Email, Password)VALUES(@Email, @Password)", conect);
            try
            {
                if (!string.IsNullOrEmpty(txtEmail.Text) && !string.IsNullOrWhiteSpace(txtEmail.Text) &&
                  !string.IsNullOrEmpty(txtPassword.Text) && !string.IsNullOrWhiteSpace(txtPassword.Text))
                {
                   
                    cmd.Parameters.AddWithValue("Email", txtEmail.Text);
                    cmd.Parameters.AddWithValue("Password", txtPassword.Text);
                    cmd.ExecuteNonQuery(); // данная операция так же не проходит и переходит в catch
 
                    
                }
                else
                {
                    MessageBox.Show("Oshibka");
                }
            }
            catch
            {
                MessageBox.Show("Net");
            }
 
            
            finally
            {
                conect.Close();
            }
        }
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18273 / 14196 / 5368
Регистрация: 17.03.2014
Сообщений: 28,881
Записей в блоге: 1
15.10.2017, 14:00
PustoyPetr, что сказано в тексте исключения?
0
0 / 0 / 0
Регистрация: 14.10.2017
Сообщений: 6
15.10.2017, 17:33  [ТС]
То , что строки Email и Password не должны быть пустыми , пробовал с разными исключениями , не работает(, что делать ?
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18273 / 14196 / 5368
Регистрация: 17.03.2014
Сообщений: 28,881
Записей в блоге: 1
15.10.2017, 17:35
PustoyPetr, попробуй добавить @ к имени параметров при вызове AddWithValue
C#
1
2
cmd.Parameters.AddWithValue("@Email", txtEmail.Text);
cmd.Parameters.AddWithValue("@Password", txtPassword.Text);
0
0 / 0 / 0
Регистрация: 14.10.2017
Сообщений: 6
15.10.2017, 18:35  [ТС]
Не помогло. Так как там обращение к строке(столбцу) а не к тексту в ней.
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18273 / 14196 / 5368
Регистрация: 17.03.2014
Сообщений: 28,881
Записей в блоге: 1
15.10.2017, 19:01
PustoyPetr, выложи точный текст исключения

Цитата Сообщение от PustoyPetr Посмотреть сообщение
C#
1
2
if (!string.IsNullOrEmpty(txtEmail.Text) && !string.IsNullOrWhiteSpace(txtEmail.Text)
&& !string.IsNullOrEmpty(txtPassword.Text) && !string.IsNullOrWhiteSpace(txtPassword.Text))
Вызов IsNullOrEmpty избыточен т.к. IsNullOrWhiteSpace делает проверки на null и пустую строку.
1
0 / 0 / 0
Регистрация: 14.10.2017
Сообщений: 6
15.10.2017, 20:09  [ТС]
Тут и представлено всё исключение , может ли это быть потому что Email имеет первичный ключ в базе данных ?

Добавлено через 22 минуты
Всё заработала . забыл про 3 параметр Roled ) ххааахах
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
15.10.2017, 20:09
Помогаю со студенческими работами здесь

ExecuteReader: Свойство Connection не инициализировано
При обработке, выскакивает ошибка. Подскажите пожалуйста, что я неправильно делаю protected void Button1_Click(object sender, EventArgs...

ExecuteReader требует, чтобы команда имела транзакцию
Добрый день. Выполняю такой код: //ищем в базе даных string query = "SELECT * FROM Quotations WHERE "; ...

MySqlDataReader mdr = cmd.ExecuteReader() почему происходит ошибка
public void InsertGroupData(string Group, string kurs, int idProfile, string tbGroup) { string conStr =...

Ошибка при вызове SqlDataReader
Есть код: static public decimal SumComplectation(SqlConnection connection) { SqlCommand SqlCom = new...

Атрибуты параметров при вызове dl
Использую , вызываемая с++ функция должна изменить один из передаваемых параметров и ждет его в качестве указателя DWORD*. При описании ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru