Использование Visual Studio 2015 (VB) с SQL Server 2012. Это будет сложно, пожалуйста, несите меня.
Мои вопросы: почему я не обновляю gridview?
У меня есть веб-страница, которая создает файлы txt на удаленном сервере. Эти файлы затем собираются отдельным (сторонним инструментом), который отправляет их в государственный орган. Затем государственный орган отправляет файл квитанции для каждого файла txt, который мое веб-приложение затем принимает и записывает результат. Результат - либо принятие, либо отказ.
На веб-странице я предоставляю сетку, показывающую последние десять результатов, и если я отправляю по одному файлу за раз (при каждом нажатии кнопки), мое сетка обновляется без проблем с отображением результатов квитанций. Между созданием файла, отправкой файла и получением квитанции может быть небольшой промежуток времени.
На изображении ниже показан пример моей сетки после успешной отправки и получения.
При нажатии кнопки столбцы отправленных и принятых сообщений отображаются красным цветом с надписью «Нет».
Когда нажимается кнопка для отправки файла, обрабатывается подпрограмма, которая создает файл. Затем включается таймер (срабатывает каждые десять секунд), который запускает другую подпрограмму для проверки отправленных и квитанций. У меня нет проблем с этим, поскольку он работает, как ожидалось, и каждая ячейка в gridview изменяется, чтобы отразить статус отправки и получения.
Это делается с помощью вызова для построения представления сетки.
Звонок
displayLastSentGridView()
displayHistoryGridView()
historyUpdatePanel.Update()
Один из субмаринов для построения gridview
Public Sub displayLastSentGridView()
Dim mlastSent As New lastSent
Dim mLastSents As New List(Of lastSent)
mLastSents = mlastSent.lastSentGridView
gridLastSent.DataSource = mLastSents
gridLastSent.DataBind()
End Sub
Итак, поступил запрос, что при создании конкретного файла генерируются еще 4 (с другим макетом) и автоматически отправляются. Я реализовал это, и он работает, как ожидалось. Затем я использую новую подпрограмму для проверки статуса этих файлов (поскольку их классификация отличается). Когда файл отправляется, веб-страница обновляет базу данных, помечая запись как отправленную, когда квитанция принимается, она отмечает ее как принятую. Моя проблема возникает здесь. Я использую тот же код, что и выше, для вызова обновлений gridview, когда даже происходит отправка и когда приходит подтверждение, но gridviedw не обновляется.
Если я помещаю код в конец подпрограммы, все ячейки обновляются, то есть он обновит сетку за один раз, и все ячейки станут зелеными с Да внутри них, но я хочу, чтобы он обновлял каждую ячейку по мере изменения уведомлений базы данных .
Ниже приведен отрывок из моего кода, который проверяет расположение папки strSentFileLocation
, если она существует, база данных обновляется, а затем выполняется вызов для обновления gridviews. Обновление базы данных работает, но вид сетки не меняется.
If File.Exists(strSentFileLocation) Then
db.ngc_updateActivityLogSent(True, seq)
db.ngc_updateActivityLogRejected(False, "N/A", seq)
db.ngc_updateActivityLogAccepted(False, seq)
'update gridviews
displayLastSentGridView()
displayHistoryGridView()
historyUpdatePanel.Update()
End If
Моя панель обновлений настроена на условное выполнение.
Любая помощь очень ценится. Спасибо
ОБНОВИТЬ
Для информации: оператор IF
вложен в цикл FOR
.