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

SqlDataReader не считывает первую строку из таблицы в БД

23.04.2019, 15:34. Показов 2592. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток!

Имеется такая функция:

Кликните здесь для просмотра всего текста
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
private void check_report_date()
        {
            SqlConnection con = new SqlConnection(ConStr.connect());
 
            try
            {
                using (SqlCommand sql = con.CreateCommand())
                {
                    con.Open();
 
                    for (int i = 0; i < dGV.Rows.Count; i++)
                    {
                        string okudJ = dGV[4, i].Value.ToString();
                        string periodJ = dGV[5, i].Value.ToString();
                        string yearJ = dGV[6, i].Value.ToString();
 
                        SqlCommand command = new SqlCommand(@"SELECT Dates.okud, Dates.period, Dates.year, Dates.date_send FROM dbo.Dates", con);
                        SqlDataReader read = command.ExecuteReader();
                        read.Read();
 
                        while (read.Read())
                        {
                            if (read.HasRows && (string.IsNullOrWhiteSpace(dGV.Rows[i].Cells[16].Value.ToString()) == false))
                            {
                                if (read.GetString(0) == "0" + okudJ && read.GetString(1) == periodJ && read.GetString(2) == yearJ)
                                {
                                    if ((DateTime.Parse(read.GetValue(3).ToString())) >= (DateTime.Parse(dGV.Rows[i].Cells[16].Value.ToString())))
                                    {
                                        dGV[16, i].Style.BackColor = Color.MediumSeaGreen;
                                    }
                                    else
                                    {
                                        dGV[16, i].Style.BackColor = Color.DarkSalmon;
                                    }
                                }
                            }
                        }
                        read.Close();
                    }
                    con.Close();
                }
            }
            catch (SqlException ex)
            {
                con.Close();
                MetroMessageBox.Show(this, ex.Message, "Ошибка", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
        }

Она сравнивает даты из DataGridView ("dGV") с датами из таблицы в базе MS SQL ("Dates") и при совпадении/несовпадении окрашивает ячейку с датой в dGV в соответствующий цвет. Все работает нормально, за исключением того, что с первой записью в таблице Dates сравнения не происходит, Reader начинает чтение только со второй строки таблицы. Подскажите, что необходимо изменить в коде, чтобы считывание происходило с самого начала таблицы?
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
23.04.2019, 15:34
Ответы с готовыми решениями:

Ifstream считывает только первую строку
я написал короткую программу, с водом имена в файл и выводом. проблема заключается в том что ifstream выводит только первую строку, а...

QDataStream считывает только первую строку из файла
Здравствуйте. Запись в бинарный файл: if (file.open(QIODevice::WriteOnly)) { QDataStream write_stream(&amp;file); ...

Напишите программу, которая считывает первую строку целого числа N
Напишите программу, которая считывает первую строку целого числа N. После вступления читает N линий, каждая из которых содержит одно целое...

2
Эксперт .NET
 Аватар для Даценд
5878 / 4755 / 2939
Регистрация: 20.04.2015
Сообщений: 8,361
23.04.2019, 15:35
Лучший ответ Сообщение было отмечено yarmak72 как решение

Решение

yarmak72,
уберите строку 19
1
0 / 0 / 0
Регистрация: 29.06.2016
Сообщений: 21
23.04.2019, 15:38  [ТС]
Спасибо большое. Столько всего перерыл в Интернете, а всё оказывается так просто )
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
23.04.2019, 15:38
Помогаю со студенческими работами здесь

Программа считывает только первую строку файла,как сделать чтобы она считывала все строки
#include &lt;fstream&gt; #include &lt;iostream&gt; using namespace std; int main(int argc, char* argv) { setlocale(LC_ALL, &quot;rus&quot;); ...

Извлечь данные из SqlDatareader в строку
Нужно извлчь данные из дата ридера строкой представляющей собой одну запись таблицы в БД. Строка должна быть следующего вида: ...

Двумерный массив. Вывести на экран только первую строку таблицы
Help me!!! Написать программу, которая заполняет двумерный массив случайными числами в диапазоне от -5 до 8 и выводит его в виде таблицы....

Текстовые файлы: в первую строку вставить первую гласную из второй строки, после каждой согласной в первой
1-в первую строку вставить первую гласную из второй строки, после каждой согласной в первой (строки записаны в файле, туда же и сохранить) ...

Считывает символьную строку с экрана, выводит в файл (.txt) данную строку, перевернув её(было 123, стало 321)
Наткнулся на задачу, помогите решить: вводиться символьная строка, программа считывает строку и выводит её в файл(текстовой), перевернув...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Вывод данных через динамический список в справочнике
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ документа "ВыдачаОборудованияНаСпецтехнику" в. . .
Функция заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию. 2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 31.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO Апнулись до NET10. Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта так и в интерактивном режиме. из сложностей - чисто функциональный подход. Решил. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru