Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2007.05.13;
Скачать: CL | DM;

Вниз

Запись boolean в MS Access   Найти похожие ветки 

 
ALS ©   (2007-02-20 16:22) [0]

Есть база с несколькими таблицами, одна из них имеет автоинкрементный индекс, несколько строковых полей и логическое поле. Все поля кроме индекса могут быть BLANK. Необходимо добавлять к таблице записи.
Создал TADOQuery со следующим SQL:

INSERT INTO MainResult (
Operator, ChipName, NSet, Wafer, PassCard, ChipNumber, ChipResult)
VALUES (:POp, :PCNm, :PSt, :PWf, :PCrd, :PNum, :PRes)

Параметр PRes описал как ftBoolean. Пытаюсь выполнить запрос:

function TForm1.MainResult(const Op, CName, St, Waf, PC: string; Chip: integer; Res: boolean): boolean;
begin
 with ADOQuery do
 try
   Parameters.Items[0].Value := Op;
   Parameters.Items[1].Value := CName;
   Parameters.Items[2].Value := St;
   Parameters.Items[3].Value := Waf;
   Parameters.Items[4].Value := PC;
   Parameters.Items[5].Value := Chip;
   Parameters.Items[6].Value := Res;
   Result := ExecSQL > 0
 except
   Result := False
 end;
end;

В результате имею EOleException "Data type mismatch in criteria expression". Вопрос: как правильно заносить данные в поле логического типа таблицы MS Access, используя TADOQuery


 
Gin2   (2007-02-20 17:32) [1]

почему ты решил что проблема именно там?


 
ALS ©   (2007-02-20 19:37) [2]

Если я убираю из TADOQuery упоминания о последнем (boolean) параметре, все остальные поля прописываются нормально. При наличии этого параметра Query обламывается на ExecSQL.
А в чем еще может быть проблема?


 
Johnmen ©   (2007-02-20 21:12) [3]

Попробуй Parameters.Items[6].Value := Ord(Res);


 
ALS ©   (2007-02-20 23:10) [4]

> Parameters.Items[6].Value := Ord(Res);

Попрововал для ftBoolean, получил тоже самое ("Несоответствие типов данных в выражении условия отбора" - русская винда) .
Для ftBytes, Size=1 получил "Приложение использует для текущей операции значение неверного типа".
Помогло ftVariant, Size=1.

Спасибо


 
MsGuns ©   (2007-02-20 23:47) [5]

В акцесе нет типа boolean


 
sniknik ©   (2007-02-21 00:24) [6]

> В акцесе нет типа boolean
есть


 
fd979 ©   (2007-02-21 14:39) [7]

Вместо True и False ставь 1 и 0 соответственно.


 
sniknik ©   (2007-02-21 14:45) [8]

fd979 ©   (21.02.07 14:39) [7]
а что ты думаешь выдаст Ord(Res) из совета в [3]? соответственно.


 
fd979 ©   (2007-02-21 14:48) [9]

Не обратил внимание на все комменты, соответственно.



Страницы: 1 вся ветка

Текущий архив: 2007.05.13;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.041 c
15-1176128895
default
2007-04-09 18:28
2007.05.13
Фень Юань "Программирование графики для windows"


2-1176980335
Селезин
2007-04-19 14:58
2007.05.13
Программы по умолчанию


1-1173975798
PAN
2007-03-15 19:23
2007.05.13
подсветка синтаксиса в TRichEdit


3-1172343764
DmitrichJ
2007-02-24 22:02
2007.05.13
InterBase-Generator-Trigger. Как узнать сгенерированный номер?


2-1177074264
_Anton_
2007-04-20 17:04
2007.05.13
обнуление поля с изображением