Форум программистов, компьютерный форум, киберфорум
Visual Basic .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/15: Рейтинг темы: голосов - 15, средняя оценка - 4.67
 Аватар для yutrans
142 / 125 / 50
Регистрация: 10.11.2011
Сообщений: 622

Обновить данные в комбобоксе после добавления в базу данных Access

25.12.2016, 17:03. Показов 3176. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброе время суток.
При составлении формы столкнулся с такой проблемой. Нужно добавить новые данные в базу данных Access и результат должен обновиться в комбобоксе. Сейчас данные добавляются ,но в комбобоксе не отражаются. Нужно закрывать форму и по новому запускать.
В прилагаемом файле проект выполненный на visual Basic 2010 и база данных Access
Вложения
Тип файла: rar Тест.rar (112.8 Кб, 17 просмотров)
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
25.12.2016, 17:03
Ответы с готовыми решениями:

Сохранить данные в ComboBox после добавления новых данных
Добрый день. Создана форма организаций. Список организаций в комбобоксе создан программно. Выбираем данные из комбобокса и в...

Как сделать информационное сообщение после добавления данных в базу
Как сделать, что бы после того как оператор вносил данные в базу высвечивалось сообщение типа "Запись была добавлена № дела (такой то-...

Код добавления данных в базу перестал работать после изменения
всем привет. делаю форму для добавления данных в базу. в один момент все работало, но после изменения перестало. помогите пожалуйста,...

7
34 / 34 / 6
Регистрация: 24.11.2015
Сообщений: 330
25.12.2016, 17:20
снова считайте процедуру fillcombo() вот так
VB.NET
1
2
3
4
5
6
7
8
9
Try
          cmd.ExecuteNonQuery()
            cmd.Dispose()
            myConnection.Close()
            'очистка полей формы
            TextBox3.Clear()
            TextBox4.Clear()
            TextBox5.Clear()
        "" fillcombo()"""
0
 Аватар для yutrans
142 / 125 / 50
Регистрация: 10.11.2011
Сообщений: 622
25.12.2016, 17:30  [ТС]
Khaker_tt,спасибо за ответ. Прописал Ваш код ,но обновления нет?
Вложения
Тип файла: rar Comb.rar (112.9 Кб, 15 просмотров)
0
1723 / 1537 / 165
Регистрация: 25.07.2015
Сообщений: 2,639
25.12.2016, 18:59
Цитата Сообщение от yutrans Посмотреть сообщение
Сейчас данные добавляются ,но в комбобоксе не отражаются.
Просто вставьте в обработчик кнопки вашу подпрограмку заполнения комбобокса.
Только в ней первой строкой пропишите
VB.NET
1
ComboBox1.Items.Clear()
чтобы строки не дублировались.

VB.NET
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
Private Sub Button2_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button2.Click
       .....................................................................
 
        Try
            cmd.ExecuteNonQuery()
            cmd.Dispose()
            myConnection.Close()
            'очистка полей формы
            TextBox3.Clear()
            TextBox4.Clear()
            TextBox5.Clear()
            Me.Size = New System.Drawing.Size(275, 180)
 
           fillcombo() ' Этот модуль выполнит перезаполнение комбобокса
 
        Catch ex As Exception
            MsgBox(ex.Message)
        End Try
    End Sub
0
 Аватар для yutrans
142 / 125 / 50
Регистрация: 10.11.2011
Сообщений: 622
25.12.2016, 19:55  [ТС]
VB.NET
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
  'добавить новую запись в базу данных Access
    Private Sub Button2_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button2.Click
 
        ComboBox1.Items.Clear()
 
        connstring = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=D:\DB\База данных1.accdb;Persist Security Info=False;"
        myConnection.ConnectionString = connstring
        myConnection.Open()
        Dim str As String
        str = "insert into Таблица1([Организация],[Адрес],[Контакт])Values(?,?,?)"
        Dim cmd As OleDbCommand = New OleDbCommand(Str, myConnection)
        cmd.Parameters.Add(New OleDbParameter("Организация", CType(TextBox3.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("Адрес", CType(TextBox4.Text, String)))
        cmd.Parameters.Add(New OleDbParameter("Контакт", CType(TextBox5.Text, String)))
 
       Try
            cmd.ExecuteNonQuery()
            cmd.Dispose()
            myConnection.Close()
            'очистка полей формы
            TextBox3.Clear()
            TextBox4.Clear()
            TextBox5.Clear()
            Me.Size = New System.Drawing.Size(275, 180)
 
            fillcombo() ' Этот модуль выполнит перезаполнение комбобокса
 
        Catch ex As Exception
            MsgBox(ex.Message)
        End Try
    End Sub
Добавил код ,но обновления нет
0
1723 / 1537 / 165
Регистрация: 25.07.2015
Сообщений: 2,639
25.12.2016, 21:09
Хм..

Переписал заполнение

VB.NET
1
2
3
4
5
6
7
8
9
10
Sub fillcombo()
 
        Dim da As New OleDbDataAdapter(New OleDbCommand("select * from Таблица1", acsconn))
        Dim dsMake As New DataSet("DsSelect")
        dsMake.Tables.Add("Таблица1")
        da.Fill(dsMake.Tables("Таблица1"))
        makeBS.DataSource = dsMake.Tables("Таблица1")
        ComboBox1.DataSource = makeBS
        ComboBox1.ValueMember = "Организация"
    End Sub
Работает, но ....
При первом запуске перезаполнение комбобокса не срабатывает,
потом всё нормально обновляется....пока не понял почему

Добавлено через 5 минут
Только объявите в классе формы
VB.NET
1
Friend makeBS As New BindingSource
Добавлено через 56 минут
Разобрался в чём проблема.
Вы не закрываете соединение.
Допишите в Sub fillcombo() acsconn.Close и всё будет работать как надо

VB.NET
1
2
3
4
5
6
7
8
9
Dim da As New OleDbDataAdapter(New OleDbCommand("select * from Таблица1", acsconn))
        Dim dsMake As New DataSet("DsSelect")
        dsMake.Tables.Add("Таблица1")
        da.Fill(dsMake.Tables("Таблица1"))
        makeBS.DataSource = dsMake.Tables("Таблица1")
        ComboBox1.DataSource = makeBS
        ComboBox1.ValueMember = "Организация"
        acsconn.Close
    End Sub
И пару советов
- для сортировки в комбобокс используйте сортировку при выборке
SQL
1
SELECT * FROM Таблица1 ORDER BY Организация
- Не используйте несколько разных подключений к БД. Просто не забывайте закрывать существующие
по окончании процедуры.
Вашу процедуру подключения в модуле1 можно переписать так
VB.NET
1
2
3
4
5
6
7
8
Friend Sub connect()
   IF acsconn.state =ConnectionState.Closed Then
        acsconn.ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=D:\DB\База данных1.accdb;Persist Security  Info=False;"
        acsconn.Open()
   Else
        Exit Sub
   End If
End Sub
и использовать её в любой части программы.
При такой проверке вы избежите ошибок , если всё-же забудете закрыть соединение
Использование многих разных соединений может принести большие проблемы
0
1723 / 1537 / 165
Регистрация: 25.07.2015
Сообщений: 2,639
25.12.2016, 21:19
Лучший ответ Сообщение было отмечено yutrans как решение

Решение

ваш прект
Вложения
Тип файла: rar Comb.rar (125.9 Кб, 44 просмотров)
1
 Аватар для yutrans
142 / 125 / 50
Регистрация: 10.11.2011
Сообщений: 622
25.12.2016, 23:51  [ТС]
Kulma, спасибо за ответ.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
25.12.2016, 23:51
Помогаю со студенческими работами здесь

Обновить данные в таблице Access на основе данных из Excel
Добрый день, подскажите, пожалуйста, как решить задачу: Есть книга Excel "C:\Data\Новые сотрудники.xls". В этой книге есть лист...

Пытаюсь добавить записи в базу данных.После добавления 5-7 записей вылетает ошибка.
Уважаемые коллеги. Проблема следующая. Пытаюсь добавить записи в базу данных.После добавления 5-7 записей вылетает ошибка : Could not...

Обновление datagrid после добавления данных а Access
Здравствуйте Такая проблема, есть код для добавления данных в базу по нажатию кнопки но вот дата грид не добавляет новые строки и все...

Не отображается форма в Access после добавления данных из подчиненной таблицы
Гуру Access!!! Помогите новичку! :gsorry: Создаю форму, все идет нормально, пока не добавляю вкладку для данных из подчиненной таблицы....

Rs.EditMode или как обновить данные в Базе Данных VBA (Excel to Access)
Нужно обновить или перезаписать данные в таблице: Структура БД: Таблицы с полями: (id Счетчик, name Char, dd Int, itime datetime,...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
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