Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
113 / 100 / 68
Регистрация: 21.04.2014
Сообщений: 1,420

Запрос не работает с определёнными датами

22.12.2015, 12:33. Показов 535. Ответов 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
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
60
61
62
63
64
65
66
67
68
69
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data.OleDb;
using System.IO;
 
namespace GettingByAccess
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }
 
        private void btnStart_Click(object sender, EventArgs e)
        {
            extendedListView1.Items.Clear();
            System.IO.StreamWriter file = new System.IO.StreamWriter("TestFile.txt", false);
            OleDbConnection Connection = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;" + @"Data Source= mydb.mdb");
 
            OleDbCommand Command = Connection.CreateCommand();
            string strDate = monthCalendar1.SelectedDate.Date.ToString().Replace(".", "/");
            strDate = strDate.Split(' ')[0];
            Command.CommandText = "SELECT * FROM SAMP_ODR WHERE FDATE=#" + strDate + "#";
            Connection.Open();
            OleDbDataReader DataReader = Command.ExecuteReader();
 
            string strColumNameTable = string.Empty;
            for (int i = 0; i < DataReader.FieldCount; i++)
            {
                extendedListView1.Columns[i].Text = DataReader.GetName(i);
 
                if (i == (DataReader.FieldCount)-1)
                    strColumNameTable+=DataReader.GetName(i);
                else
                    strColumNameTable += DataReader.GetName(i) + ",";
            }
            file.WriteLine(strColumNameTable);
 
            string strContentTable = string.Empty;
            int j = 0;
            while (DataReader.Read())
            {
                extendedListView1.Items.Add(DataReader[0].ToString());
                for (int i = 0; i < DataReader.FieldCount; i++)
                {
                    extendedListView1.Items[j].SubItems.Add(DataReader[i].ToString());
 
                    if (i == (DataReader.FieldCount) - 1)
                        strContentTable += DataReader[i].ToString();
                    else
                        strContentTable += DataReader[i].ToString() + ",";
                }
                file.WriteLine(strContentTable);
                strContentTable = string.Empty;
                j++;
            }
            file.Close();
            DataReader.Close();
            Connection.Close();
        }
    }
}
И вроде бы всё работает но почему-то на определённые даты значения не возвращаются (на 11.12.2015, на пример и ещё на некоторые). При этом заголовки столбцов всегда приходят корректно. Записи в БД с такими датами есть, проверял. Что я делаю не так?

Добавлено через 24 минуты
P.S. То, что у меня дублируется первый столбец я знаю, уже исправил. Ситуацию это не изменило.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
22.12.2015, 12:33
Ответы с готовыми решениями:

запрос между двумя датами
есть такой запрос, который должен вывести все Ид_проводки, если заданы даты почему он не работает так как надо? выводит все строки. ...

Запрос на выборку между датами
Не работает, запрос private void button2_Click(object sender, EventArgs e) { OleDbConnection db =...

Запрос с датами
Здравствуйте. Напишите, пожалуйста, как написать запрос: выдать информацию..., where с момента определенной даты прошло более 3-х лет.

1
311 / 309 / 125
Регистрация: 29.01.2013
Сообщений: 638
Записей в блоге: 1
22.12.2015, 12:36
Думается мне, что Вы и база данных не совсем одинаково воспринимаете текстовое значение даты: Вы думаете, что 11.12.2015 - это 11 декабря, а база воспринимает эту строку как 12 ноября. Избежать путаницы помогает использование параметров в запросах:
C#
1
2
3
4
Command.CommandText = "SELECT * FROM SAMP_ODR WHERE FDATE=?";
Command.Parameters.AddWithValue("param1", monthCalendar1.SelectedDate.Date;
            Connection.Open();
            OleDbDataReader DataReader = Command.ExecuteReader();
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
22.12.2015, 12:36
Помогаю со студенческими работами здесь

Запрос с датами
Добрый день, уважаемые форумчане! Помогите пожалуйста с запросом. Имеется таблица такого вида(значений огромное множество). Необходимо из...

Запрос с датами
Доброго времени суток! Вообще такая проблема: нужен запрос в котором бы подсчитывалось количество дней между датами разных столбцов...

Запрос с датами
Доброго времени суток. Собственно в запросе нужно вывести количество больных по месяцам Написал запрос: SELECT ARKART.DATV,...

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

Запрос между датами
Добрый вечер! Кто-нибудь сможет подсказать: есть таблица в бд, в ней, например, 4 даты - 28.10.2017; 29.10.2017; 03.11.2017;...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
Программный отбор значений справочника
Maks 21.03.2026
Установка программного отбора значений справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru