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

Несоответствие типов в запросе с полем Date/Time

16.06.2014, 22:28. Показов 4308. Ответов 28
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток.
C#
1
OleDbDataAdapter adapter = new OleDbDataAdapter("SELECT * FROM sob where data =  '" + DateTime.Now + "'   ", connection);
В базе столбец типа Дата/Время
Подскажите как правильно,а то на это ругается
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
16.06.2014, 22:28
Ответы с готовыми решениями:

Проблема с полем типа Date/time
В поисковике есть поле типа Date/Time Если я ввожу туда вместо даты - буквы, то у меня просто буквы удаляются и поле пусто. И поисковик...

EOleException 'Несоответствие типов данных в выражении условия отбора' при запросе Update
Здравствуйте, прошу совета в связи с такой ситуацией: В программе по нажатию кнопки на форме выполняется запрос нескольких значений из...

SQL-запрос в Access, ошибка: Run-time error 3464 Несоответствие типов данных в выражении условия отбора.
Добрый день! Помогите решить проблему. Есть поле regdate в Access-таблице типа Дата/время, где я в коротком формате храню даты. Данные...

28
6 / 6 / 1
Регистрация: 09.06.2014
Сообщений: 49
19.06.2014, 00:08
Студворк — интернет-сервис помощи студентам
C#
1
2
3
4
5
6
7
8
9
10
11
            OleDbConnection connection = new OleDbConnection(connectionString);
           
            OleDbDataAdapter adapter = new OleDbDataAdapter("SELECT * FROM sob ", connection);
 
            OleDbCommand command = new OleDbCommand("SELECT * FROM sob WHERE data = @DT", connection);
            command.Parameters.Add("@DT", OleDbType.Date,0,"Date");
            adapter = new OleDbDataAdapter(command);
            connection.Open();
            command.Parametres["@DT"].Value = DateTime.Now.Date;
            adapter.Fill(dataSet,"sob");
            connection.Close();
0
19 / 19 / 13
Регистрация: 19.03.2013
Сообщений: 423
19.06.2014, 00:12  [ТС]
не работает тоже
0
6 / 6 / 1
Регистрация: 09.06.2014
Сообщений: 49
19.06.2014, 00:38
Лучший ответ Сообщение было отмечено linkoln_737 как решение

Решение

что то я сам уже начинаю путаться...
попробуй так
C#
1
2
3
4
5
OleDbConnection connection = new OleDbConnection(connectionString);
OleDbCommand command = new OleDbCommand("SELECT * FROM sob WHERE data = @DT", connection);
command.Parameters.Add("@DT", OleDbType.Date,0,"Date");
command.Parametres["@DT"].Value = DateTime.Now.Date;
adapter.Fill(dataSet,"sob");
2
19 / 19 / 13
Регистрация: 19.03.2013
Сообщений: 423
19.06.2014, 00:43  [ТС]
заработало))спасибо большое!
0
6 / 6 / 1
Регистрация: 09.06.2014
Сообщений: 49
19.06.2014, 00:46
не за что)
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
19.06.2014, 15:49
И в чём была проблема? Я дал рабочий фрагмент, у меня же работает.
0
6 / 6 / 1
Регистрация: 09.06.2014
Сообщений: 49
19.06.2014, 22:04
Ваш пример был правильный, просто его не так переписали...
ошибок было много по невнимательности
0
19 / 19 / 13
Регистрация: 19.03.2013
Сообщений: 423
19.06.2014, 22:09  [ТС]
что да,то да.еще раз спасибо вам)
0
 Аватар для BigOblom
124 / 124 / 17
Регистрация: 30.06.2010
Сообщений: 478
03.02.2020, 08:24
Doping91, намучался я с этим Access. Была база, где дата хранится как строка. Если ручками в запросе SQL прописывать дату, то выбираются не все столбцы, например должно быть 88 строк, а возвращается 62.
SQL
1
2
SELECT * FROM dbName 
WHERE CDate(s_datetime) BETWEEN '20.01.2020 00:00:00' AND '20.01.2020 23:59:59'
Если добавить параметры
SQL
1
2
PARAMETERS [dtBegin] DateTime, [dtEnd] DateTime;
SELECT string_date FROM databaseName WHERE string_date BETWEEN dtBegin AND dtEnd
то выбираются все нужные строки, но параметры приходится вводить каждый раз.
Осталось добиться такого же результата в C#. Добавляю дату как параметр
C#
1
2
3
"SELECT * FROM dbName WHERE CDate(s_datetime) BETWEEN @dtBegin AND @dtEnd";
cmd.Parameters.Add(new OleDbParameter("dtBegin", OleDbType.Date) { Value = dtBegin });
cmd.Parameters.Add(new OleDbParameter("dtEnd", OleDbType.Date) { Value = dtEnd });
И опять получаю не все строки, 62, вместо 88.
Помогли доп параметры при создании OleDbParameter
C#
1
2
cmd.Parameters.Add(new OleDbParameter("dtBegin", OleDbType.Date, 0, "Date") { Value = dtBegin });
cmd.Parameters.Add(new OleDbParameter("dtEnd", OleDbType.Date, 0, "Date") { Value = dtEnd });
Дату передавал в виде форматированной строки
C#
1
2
string dtBegin = new DateTime(2020, 01, 20, 0, 0, 0).ToString("dd.MM.yyyy HH:mm:ss");
string dtEnd = new DateTime(2020, 01, 20, 23, 59, 59).ToString("dd.MM.yyyy HH:mm:ss");

Не по теме:

Извиняюсь за некропост :)

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
03.02.2020, 08:24
Помогаю со студенческими работами здесь

Real time clock error - Check date and time setting
Всех приветствую! Ноутбук Lenovo b590, после помывки и просушки мат платы, при включении стал выдавать сею картину(на скриншоте). В...

Создание таблицы с полем DATE
Пишу запрос на создание таблицы CREATE TABLE FR (BIRTHDAY date(8)) выдаёт ошибку синтаксиса - почему ? как мне тогда указать длинну...

Несоответствие типов
Есть вот такая вот задачка. Дана целочисленная матрица размера M × N, элементы которой могут принимать значения от 0 до 100. Различные...

Несоответствие типов
Добрый день, ни как не могу победить несоответствие типов. То есть, есть некая форма с полем TextBoxOne и полем TextBoxTwo Нужно: 1....

Несоответствие типов
var s1,s2,s3:string; ss1,ss2,ss3 :set of byte; y:integer; H:char; begin readln(s1); readln(s2); ss1:=; ss2:=;...


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

Или воспользуйтесь поиском по форуму:
29
Ответ Создать тему
Новые блоги и статьи
[golang] Угол между стрелками часов
alhaos 12.05.2026
По заданным значениям часа и минуты необходимо определить значение меньшего угла между стрелками аналогового циферблата часов. import "math" func angleClock(hour int, minutes int) float64 { . . .
Debian 13: Установка Lazarus QT5
ВитГо 09.05.2026
Эта инструкция моя компиляция инструкций volvo https:/ / www. cyberforum. ru/ blogs/ 203668/ 10753. html и его же старой инструкции по установке Lazarus с gtk2. . .
Нейросеть на алгоритме "эстафета хвоста" как перспектива.
Hrethgir 06.05.2026
На десерт, когда запущу сервер. Статья тут https:/ / habr. com/ ru/ articles/ 1030914/ . Автор я сам, нейросеть только помогает в вопросах которые мне не известны - не знаю людей которые знали-бы. . .
Асинхронный приём данных из COM-порта
Argus19 01.05.2026
Асинхронный приём данных из COM-порта Купил на aliexpress термопринтер QR701. Он оказался странным. Поключил к Arduino Nano. Был очень удивлён. Наотрез отказывается печатать русские буквы. Чтобы. . .
попытка написать игровой сервер на C++
pyirrlicht 29.04.2026
попытка написать игровой сервер на плюсах с открытым бесконечным миром. возможно получится прикрутить интерпретатор питон для кастомизации игровой логики. что есть на текущий момент:. . .
Контроль уникальности выбранного документа-основания при изменении реквизита
Maks 28.04.2026
Алгоритм из решения ниже разработан на примере нетипового документа "ЗаявкаНаРемонтСпецтехники", разработанного в КА2. Задача: уведомлять пользователя, если указанная заявка (документ-основание). . .
Благородство как наказание
Maks 24.04.2026
У хорошего человека отношения с женщинами всегда складываются трудно. А я человек хороший. Заявляю без тени смущения, потому что гордиться тут нечем. От хорошего человека ждут соответствующего. . .
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru