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

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

16.06.2014, 22:28. Показов 4128. Ответов 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
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
16.06.2014, 22:48
Это для Access? Там дата форматируется определённым образом.
Лучше пользуйся Parameters.
0
19 / 19 / 13
Регистрация: 19.03.2013
Сообщений: 423
16.06.2014, 22:49  [ТС]
если вас не затруднит,не могли бы вы показать пример.
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
16.06.2014, 23:02
Создаёшь сначала команду OleDBCommand c текстом
SQL
1
SELECT * FROM sob WHERE DATA =  @dt
, там через Parameters добавляешь параметр-дату и потом создаёшь OleDbDataAdapter с этой командой.
C++
1
Parameters.AddWithValue("@dt", DateTime.Now)
1
19 / 19 / 13
Регистрация: 19.03.2013
Сообщений: 423
17.06.2014, 00:49  [ТС]
а нельзя иначе?
только через OleDBCommand ?

Добавлено через 59 минут
C#
1
2
3
4
5
6
7
8
9
10
11
12
OleDbConnection connection = new OleDbConnection(connectionString);
            connection.Open();
            OleDbDataAdapter adapter = new OleDbDataAdapter("SELECT * FROM sob where data =  '" + DateTime.Now + "'   ", connection);
 
         
 
            dataSet = new DataSet();
            adapter.Fill(dataSet);
 
            connection.Close();
            source.DataSource = dataSet.Tables[0];
            dataGridView1.DataSource = source;
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
 private void connect()
        {
            OleDbConnection connection = new OleDbConnection(connectionString);
            connection.Open();
            OleDbDataAdapter adapter = new OleDbDataAdapter("SELECT * FROM sob", connection);
            dataSet = new DataSet();
            adapter.Fill(dataSet);
            connection.Close();
            source.DataSource = dataSet.Tables[0];
            dataGridView1.DataSource = source;
            dataGridView1.Columns[0].Visible = false;
 
            
        }
0
6 / 6 / 1
Регистрация: 09.06.2014
Сообщений: 49
17.06.2014, 11:08
C#
1
2
OleDbDataAdapter adapter = new OleDbDataAdapter("SELECT * FROM sob where data = '@p_date'", connection);
OleDbDataAdapter.SelectCommand.Parameters.Add("@p_date", SqlDbType.DateTime,0,"data");
0
19 / 19 / 13
Регистрация: 19.03.2013
Сообщений: 423
17.06.2014, 15:34  [ТС]
Для нестатического поля, метода или свойства "System.Data.OleDb.OleDbDataAdapter.Sele ctCommand.get" требуется ссылка на объект

C#
1
2
3
4
5
6
7
8
9
10
11
12
 OleDbConnection connection = new OleDbConnection(connectionString);
            connection.Open();
            OleDbDataAdapter adapter = new OleDbDataAdapter("SELECT * FROM sob where data = '@p_date'", connection);
            OleDbDataAdapter.SelectCommand.Parameters.Add("@p_date", SqlDbType.DateTime, 0, "data");
         
 
            dataSet = new DataSet();
            adapter.Fill(dataSet);
 
            connection.Close();
            source.DataSource = dataSet.Tables[0];
            dataGridView1.DataSource = source;
Добавлено через 4 минуты
Скорее нужно как нибудь так может.но все равно ошибка
C#
1
2
OleDbDataAdapter adapter = new OleDbDataAdapter("SELECT * FROM sob where data = '@p_date'", connection);
            adapter.SelectCommand.Parameters.Add("@p_date", OleDbType.Date, 0, "data");
Добавлено через 6 минут
так ,что то тоже не работает

C#
1
2
3
  OleDbDataAdapter adapter = new OleDbDataAdapter("SELECT * FROM sob where data = @dt ", connection);
           
            adapter.SelectCommand.Parameters.AddWithValue("@dt", DateTime.Now);
0
6 / 6 / 1
Регистрация: 09.06.2014
Сообщений: 49
18.06.2014, 15:25
попробуй так:
после того как открыл соединение пиши
C#
1
adapter.SelectCommand.Parameters["@p_date"].Value=DateTime.Now;
Добавлено через 2 минуты
ошибку выдаёт из за того что ты открываешь соединение раньше чем нужно
C#
1
2
OleDbDataAdapter adapter = new OleDbDataAdapter("SELECT * FROM sob where data = '@p_date'", connection);
            OleDbDataAdapter.SelectCommand.Parameters.Add("@p_date", SqlDbType.DateTime, 0, "data");
только потом нажно открыть соединение:
C#
1
2
connection.Open();
adapter.SelectCommand.Parameters["@p_date"].Value=DateTime.Now;
0
19 / 19 / 13
Регистрация: 19.03.2013
Сообщений: 423
18.06.2014, 18:15  [ТС]
Все равно несоответствие типов

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
OleDbConnection connection = new OleDbConnection(connectionString);
            OleDbDataAdapter adapter = new OleDbDataAdapter("SELECT * FROM sob where data = '@p_date'", connection);
            adapter.SelectCommand.Parameters.Add("@p_date", OleDbType.Date, 0, "data");
            connection.Open();
            adapter.SelectCommand.Parameters["@p_date"].Value = DateTime.Now;
 
            dataSet = new DataSet();
            adapter.Fill(dataSet);
 
            connection.Close();
            source.DataSource = dataSet.Tables[0];
            dataGridView1.DataSource = source;
 
 
 
 
 
 adapter.Fill(dataSet); на это ругается
0
0 / 0 / 0
Регистрация: 24.09.2012
Сообщений: 70
18.06.2014, 18:43
DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")
Здесь в скобочках мой пример для записи в SQL compact, вам нужно узнать какой формат запрашивает ваша БД
0
19 / 19 / 13
Регистрация: 19.03.2013
Сообщений: 423
18.06.2014, 19:17  [ТС]
Все равно этаже ошибка
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
18.06.2014, 20:29
Вот по такому образцу делай:
C#
1
2
3
4
5
            command = new OleDbCommand("SELECT * FROM Table1 WHERE DT = @DT", db_connection);
            command.Parameters.Add("@DT", OleDbType.Date).Value = DateTime.Now.Date;
            adapter = new OleDbDataAdapter(command);
            adapter.Fill(ds, "Table1");
            dataGridView1.DataSource = ds.Tables["Table1"];
0
19 / 19 / 13
Регистрация: 19.03.2013
Сообщений: 423
18.06.2014, 21:03  [ТС]
а ds что такое
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
18.06.2014, 22:18
DataSet
1
6 / 6 / 1
Регистрация: 09.06.2014
Сообщений: 49
18.06.2014, 22:34
Не соответствует тип из за того что в параметре ты указал тип Data а передаёшь DateTime попробуй изменить тип параметра
C#
1
adapter.SelectCommand.Parameters.Add("@p_date", OleDbType.DateTime, 0, "data");
0
19 / 19 / 13
Регистрация: 19.03.2013
Сообщений: 423
18.06.2014, 22:37  [ТС]
Ошибка 1 "System.Data.OleDb.OleDbType" не содержит определение для "DateTime" такого нет
0
6 / 6 / 1
Регистрация: 09.06.2014
Сообщений: 49
18.06.2014, 22:43
А я чё то не подумал... привык уже к sql server...
ну остаётся только так как тебе nmcf подсказал
0
19 / 19 / 13
Регистрация: 19.03.2013
Сообщений: 423
18.06.2014, 22:57  [ТС]
ну или поле сделать не data ,а строковую)

Добавлено через 3 минуты
nmcf,вроде сделал как вы подсказали.
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
OleDbConnection connection = new OleDbConnection(connectionString);
            connection.Open();
            
 
            OleDbDataAdapter adapter = new OleDbDataAdapter("SELECT * FROM sob ", connection);
 
 
            OleDbCommand command = new OleDbCommand("SELECT * FROM sob WHERE DT = @DT", connection);
            command.Parameters.Add("@DT", OleDbType.Date).Value = DateTime.Now.Date;
            adapter = new OleDbDataAdapter(command);
            adapter.Fill(dataSet,"sob");
            dataGridView1.DataSource =dataSet. Tables["sob"];
            source.DataSource = dataSet.Tables[0];
            dataGridView1.DataSource = source;
            connection.Close();
Но что то не работает все равно
0
6 / 6 / 1
Регистрация: 09.06.2014
Сообщений: 49
18.06.2014, 23:39
Опять соединение открыл раньше чем положенно

Добавлено через 1 минуту
Сначало создаёшь соединение и команду, потом параметры настраиваешь и только тогда открываешь соединение
0
19 / 19 / 13
Регистрация: 19.03.2013
Сообщений: 423
18.06.2014, 23:54  [ТС]
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
  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).Value = DateTime.Now.Date;
            adapter = new OleDbDataAdapter(command);
            connection.Open();
            adapter.Fill(dataSet,"sob");
            dataGridView1.DataSource =dataSet.Tables["sob"];
            source.DataSource = dataSet.Tables[0];
            dataGridView1.DataSource = source;
            connection.Close();
теперь при нажатии на кнопку просто выделяется у первой записи у столбец
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
18.06.2014, 23:54
Помогаю со студенческими работами здесь

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:=;...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
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 Использованы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru