Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/8: Рейтинг темы: голосов - 8, средняя оценка - 4.88
16 / 16 / 2
Регистрация: 17.02.2012
Сообщений: 104

Не работают запросы в C# с подключенной БД ACCESS

10.07.2013, 13:22. Показов 1562. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
OleDbConnection con1 = new OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=db_elements_filled.accdb");
                string com1 = String.Format("SELECT element_dimension_type FROM Element_dimension_type WHERE fk_element_type=0 ;");
                OleDbCommand cmd1 = new OleDbCommand(com1);
                DataTable tbl1 = new DataTable();
                OleDbDataAdapter da1 = new OleDbDataAdapter(cmd1);
                con1.Open();
                da1.Fill(tbl1); // ошибка Fill: Свойство SelectCommand.Connection не инициализировано.
                elementdimensiontypeBindingSource.DataSource = tbl1;
                this.Element_dimension_type_dropdown_1.DataSource = tbl1;
                this.Element_dimension_type_dropdown_1.DisplayMember = "element_dimension_type";
                this.Element_dimension_type_dropdown_1.ValueMember = "id_element_dimension_type";
                this.Element_dimension_type_dropdown_1.SelectedIndex = -1;
                con1.Close();
Третий час ползаю по гуглу и все безрезультатно Помогите, люди добрые
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
10.07.2013, 13:22
Ответы с готовыми решениями:

Не работают texbox с подключенной БД
Есть программа с подключенной бд (Access). Название из таблицы выводятся в listbox и при нажатии выводятся остальные элементы в texbox`ы....

Как сделать выпадающий список в Access в подключённой таблице из MySql?
ВОПРОС: Как сделать выпадающий список в Access в подключённой таблице из MySql? Какой должна быть талица справочника:...

Как в Access объединить запросы в один или вывести эти запросы в одном отчете и рассчитать по ним коэффициент?
Добрый день! Помогите разобраться. Есть у меня 5 запросов access, которые через долгие манипуляции все же вывели мне суммы, которые...

6
 Аватар для gitarillo
755 / 554 / 48
Регистрация: 17.06.2010
Сообщений: 1,041
Записей в блоге: 1
10.07.2013, 13:31
C#
1
OleDbCommand cmd1 = new OleDbCommand(com1, con1 );
1
16 / 16 / 2
Регистрация: 17.02.2012
Сообщений: 104
10.07.2013, 14:24  [ТС]
Огромное спасибо!
Вот уж не думал что все так легко разрешится...
А после стольких часов "насиживания кода" глаза стали похожи на глаза у смайлика---> %)

Добавлено через 41 минуту
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
string dd1 = Element_type_dropdown_1.SelectedIndex.ToString();
            Convert.ToInt32(dd1);
OleDbConnection con1 = new OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=db_elements_filled.accdb");
                string com1 = String.Format("SELECT element_dimension_type, id_element_dimension_type FROM Element_dimension_type WHERE fk_element_type = '"+ dd1 +"'");
                OleDbCommand cmd1 = new OleDbCommand(com1, con1);
                DataTable tbl1 = new DataTable();
                OleDbDataAdapter da1 = new OleDbDataAdapter(cmd1);
                con1.Open();
                da1.Fill(tbl1); // Несоответствие типов данных в выражении условия отбора... dd1 стало чслом Инт32. Поле Фк_Элемент_Тайп тоже забито как числовое. Собственно по нему идет связь с первой таблицей.
                this.Element_dimension_type_dropdown_1.DataSource = tbl1;
                this.Element_dimension_type_dropdown_1.DisplayMember = "element_dimension_type";
                this.Element_dimension_type_dropdown_1.ValueMember = "id_element_dimension_type";
                this.Element_dimension_type_dropdown_1.SelectedIndex = -1;
                con1.Close();
откуда же возникло несоответствие типов?
P.S. Смысл задачи был в том, чтобы заполнить первый выпадающий список значениями из БД первой таблицы
В зависимости от выбранного элемента в выпадающем_списке_1 генерировать данные в выпадающем_списке_2. Но не прокатило
0
 Аватар для gitarillo
755 / 554 / 48
Регистрация: 17.06.2010
Сообщений: 1,041
Записей в блоге: 1
10.07.2013, 14:26
fk_element_type = '"+ dd1 +"'"
если fk_element_type - тип целое, то апострофы убираем
1
16 / 16 / 2
Регистрация: 17.02.2012
Сообщений: 104
10.07.2013, 14:38  [ТС]
Цитата Сообщение от gitarillo Посмотреть сообщение
fk_element_type = '"+ dd1 +"'"
если fk_element_type - тип целое, то апострофы убираем
Еще раз спасибо, ты стал моим наставником!
Еще один вопрос:
Первый список генерируется замечательно, просто сказка. А второй сдвинут на 1 назад, т. е. первому элементу Первого_выпадающего_Списка соответствует ничего. Для 2 элемента из первого списка - первый из второго и т.д.
Как бы это разрешить?
0
 Аватар для gitarillo
755 / 554 / 48
Регистрация: 17.06.2010
Сообщений: 1,041
Записей в блоге: 1
10.07.2013, 14:41
надо полагать надо сделать так
C#
1
string dd1 = (Element_type_dropdown_1.SelectedIndex+1).ToString();
1
16 / 16 / 2
Регистрация: 17.02.2012
Сообщений: 104
11.07.2013, 06:56  [ТС]
Цитата Сообщение от gitarillo Посмотреть сообщение
надо полагать надо сделать так
C#
1
string dd1 = (Element_type_dropdown_1.SelectedIndex+1).ToString();
К несчастью я пробовал... Первый элемент становится адекватным, а остальные - пустые...

Добавлено через 16 часов 11 минут
Еще 1 вопрос:
Существуют 2 выпадающих списка(комбобоксы). Первый берет значения из БД. Второй смотрит на выбранное значение первого и смотрит в БД(но с условием). И есть 2 текстбокса... Значения из одного столбца Бд нужно засунуть в один текстбокс, а другого столбца в другой ТекстБокс. Притом выбор должен быть сделан на основе элемента, выбранного во втором списке.(не индекса, а именно значения первичного ключа[ValueMember, а не SelectedIndex])

Заполнение второго выпадающего меню
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
               string dd1 = (Element_type_dropdown_1.SelectedIndex+1).ToString();
               OleDbConnection con1 = new OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=db_elements_filled.accdb");
                string com1 = String.Format("SELECT element_dimension_type, id_element_dimension_type FROM Element_dimension_type WHERE fk_element_type = "+ dd1 +"");
                OleDbCommand cmd1 = new OleDbCommand(com1, con1);
                DataTable tbl1 = new DataTable();
                OleDbDataAdapter da1 = new OleDbDataAdapter(cmd1);
                con1.Open();
                da1.Fill(tbl1);
                this.Element_dimension_type_dropdown_1.DataSource = tbl1;
                this.Element_dimension_type_dropdown_1.DisplayMember = "element_dimension_type";
                this.Element_dimension_type_dropdown_1.ValueMember = "id_element_dimension_type";
                this.Element_dimension_type_dropdown_1.SelectedIndex = -1;
                con1.Close();
Заполнение первого выпадающего меню
C#
1
2
3
4
5
6
7
            this.element_typeTableAdapter.Fill(this.db_elements_filledDataSet.Element_type);
            this.element_dimension_typeTableAdapter.Fill(this.db_elements_filledDataSet.Element_dimension_type);
            this.informationTableAdapter.Fill(this.db_elements_filledDataSet.information);
            this.Element_type_dropdown_1.DataSource = db_elements_filledDataSet.Element_type;
            this.Element_type_dropdown_1.DisplayMember = "element_type";
            this.Element_type_dropdown_1.ValueMember = "id_element_type";
            this.Element_type_dropdown_1.SelectedIndex = -1;
Что-то придуманное для текстбоксов.
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
private void Element_dimension_type_dropdown_1_SelectedIndexChanged_1(object sender, EventArgs e)
        {
            string dd2 = (Element_dimension_type_dropdown_1.ValueMember).ToString();
            OleDbConnection con = new OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=db_elements_filled.accdb");
            con.Open();
           // string com2 = string.Format("SELECT rate, weight FROM information WHERE fk_element_dimension_type = " + dd2 + "");
           // OleDbCommand cmd2 = new OleDbCommand(com2, con);
         //   DataTable tbl2 = new DataTable();
         //   OleDbDataAdapter da2 = new OleDbDataAdapter(cmd2);
            OleDbCommand c1 = con.CreateCommand();
            c1.CommandText = "SELECT rate, weight FROM information WHERE fk_element_dimension_type = " + dd2 + "";
            OleDbDataReader r1 = c1.ExecuteReader();
            string s1 = string.Empty;
            string s2 = string.Empty;
            while (r1.Read())
            {
                s1 += r1["rate"];
                s2 += r1["weight"];
            }
            r1.Close();
            con.Close();
 
            // con.Open();
            // da2.Fill(tbl2);
            Rate_1.Text = s1;
            Weight_for_piece_1.Text = s2;
            //con.Close();
        }
Заранее спасибо!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
11.07.2013, 06:56
Помогаю со студенческими работами здесь

Вывод в TextBox определенной информации, взятой из подключенной базы данных access
добрый вечер уважаемые обитатели форума. помогите доработать программу, а точнее разобраться с некоторыми функциями(проблемы с записью sql...

Не работают запросы
В первый раз делаю приложение $token = '66323197*****a9d46'; $fields = array( 'connection','site', 'education','contacts', ...

Не работают параметрические запросы
Создал БД, сделал запрос такой , но когда запускаю запрос, получаю и ничего он не спрашивает, так же не подсвечиваются подсказки вроде...

Не работают медиа-запросы
Мдемс, есть вот такой css3 код : .slidershow { float: left; clear: both; position: relative; width: 550px; height: 300px; ...

Не работают медиа-запросы
Добрый вечер, написал 2 медиа-запроса @media (max-width: 1200px){ .header{ background: #000; } } @media (max-width:...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru