Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.77/13: Рейтинг темы: голосов - 13, средняя оценка - 4.77
0 / 0 / 0
Регистрация: 08.04.2018
Сообщений: 30

Сравнить значение в TextBox со значением ячейки БД access (авторизация)

24.05.2019, 21:05. Показов 2668. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. Есть БД access(понимаю что не лучший вариант) и форма в WPF. В БД есть таблица с логином и паролем. Не могу понять почему после ввода данных в TextBox'ы программа выдает ошибку System.InvalidOperationException: "Для ExecuteScalar нужно открытое и доступное подключение Connection. Подключение закрыто." Помогите найти и понять ошибку

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
        static private string GetConnectionString(string path)
        {
            return @"Provider = Microsoft.ACE.OLEDB.12.0; Data Source = " + path + ";";
        }
        public void ReadMyData()
        {            
            string mySelectQuery = "SELECT * FROM log WHERE login ='" + tbUserName.Text + "' and password='" + tbUserPassword.Text + "'";
 
            OleDbConnection myConnection = new OleDbConnection(GetConnectionString("Auto.accdb"));
            OleDbCommand cmd = new OleDbCommand(mySelectQuery, myConnection);
            object obj = cmd.ExecuteScalar();
 
            if (DBNull.Value.Equals(obj))
            {                
                ConnectUser();
            }
            else
            {                
                DisconnectUser();
            }
        }
        void ConnectUser()
        {
            if (!isConnected)
            {
                client = new ServiceChatClient(new System.ServiceModel.InstanceContext(this));
                ID = client.Connect(tbUserName.Text);
                tbUserName.IsEnabled = false;
                bConnDicon.Content = "Disconnect";
                isConnected = true;
            }            
        }
 
        void DisconnectUser()
        {
            if (isConnected)
            {
                client.Disconnect(ID);
                client = null;
                tbUserName.IsEnabled = true;
                bConnDicon.Content = "Connect";
                isConnected = false;
            }
 
        }
 
        private void Button_Click(object sender, RoutedEventArgs e)
        {
            ReadMyData();
            if (isConnected)
            {
                DisconnectUser();
            }
            else
            {
                ConnectUser();
            }
 
        }
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
24.05.2019, 21:05
Ответы с готовыми решениями:

Сравнить значение в TextBox со значением ячейки БД SQL (авторизация)
Здраствуйте, только начал учить SQL, поэтому много не знаю. У меня есть WinForm с окошками афотризации ввода логина и пароля, также у меня...

Сравнить значение ячейки DataGridView со значением в TextBox
Доброе время суток. Подскажите пожалуйста как мне сделать. У меня есть значения в textdox и мне нужно проверить, если это значения...

Как сравнить значение переменной со значением из textBox?
Я мог бы и в переменную записать значение textBox, но это как-то некрасиво будет :) if (discr != textBox10.Text) { ...

5
Фрилансер
805 / 312 / 148
Регистрация: 13.02.2019
Сообщений: 1,071
24.05.2019, 21:18
tm1, подключение перед использованием нужно открыть:
C#
1
myConnection.Open();
0
0 / 0 / 0
Регистрация: 08.04.2018
Сообщений: 30
24.05.2019, 22:13  [ТС]
теперь такое исключение System.Data.OleDb.OleDbException: "Отсутствует значение для одного или нескольких требуемых параметров."
0
22 / 20 / 13
Регистрация: 19.07.2015
Сообщений: 99
24.05.2019, 22:22
tm1, Вы пытаетесь получить скалярное значение (ExecuteScalar) при select запросе, результатом которого будет несколько значений (select * ...).
0
0 / 0 / 0
Регистрация: 08.04.2018
Сообщений: 30
25.05.2019, 11:49  [ТС]
запрос переделал, теперь не получается проверить данные из TextBox'а с БД и если данные совпали, то подключиться. Можно подключиться если убрать методы из условия, а так никакой реакции
C#
1
2
3
4
5
6
7
8
if (DBNull.Value.Equals(obj))
            {                
                ConnectUser();
            }
            else
            {                
                DisconnectUser();
            }
0
3566 / 2507 / 1174
Регистрация: 14.08.2016
Сообщений: 8,219
26.05.2019, 01:26
это все неправильно, пароли в БиДе зашифрованы(это не обсуждается тут), передаётся в БиДе логин и зашифрованный пароль, и уже БиДе возвращает, совпало или "пнх"
создаем подключение,формируем запрос, отрываем, юззаем запрос, получаем результат, двигаемся дальше....
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
26.05.2019, 01:26
Помогаю со студенческими работами здесь

Как сравнить значение TextBox на VB 6.0 с ячейкой Access
Подскажите пожалуйста, кто что знает. Заранее, премного благодарен!

Как сравнить значение со значением в файле?
Как сравнить значение со значением в файле? Например: сохранил в файле значения 1234 и abcd, затем ввожу с консоли число 1234. Теперь мне...

Вычислить значение выражения и сравнить с ожидаемым значением
В этой задачи надо проверить правильность формулы Это main.cpp #include "Equation.h" #include <iostream> ...

Как сравнить значение введенное в консоли со значением в файле?
как сравнить значение введенное в консоли со значением в файле, к примеру с консоли вводится какое то слово или число, после чего идет...

Перейти по заданной ссылке, и сравнить значение с сайта со значением переменной
Доброе время суток, мне нужно что бы программа переходила по заданой ссылке и сравнивала значение перемнной заданое мной и значение...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru