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

Вниз

Ошибка   Найти похожие ветки 

 
stur ©   (2002-10-09 16:40) [0]

Уважаемые Мастера подскажите.
DBGrid подключен к базе через Query. Для преобразования типа поля используется следующий код. Проблема в следующем при просмотре базы данных назад через вполне определённое число строк вылетает ошибка "Invalid BLOB handle in record buffer" виной всему строка Query1.FieldByName ("EmpChar1_05").AsString);. Почему то теряется взаимосвязь. Как от этого избавиться?

procedure TForm1.DBGrid1DrawColumnCell(Sender: TObject; const Rect: TRect;
DataCol: Integer; Column: TColumn; State: TGridDrawState);
begin
if Column.Field.FieldName="EMPCHAR1_05" then
begin
DBGrid1.Canvas.FillRect(Rect);
DBGrid1.Canvas.TextOut Rect.Left+1,Rect.Top+2, Query1.FieldByName ("EmpChar1_05").AsString);
end;
end;


 
stur ©   (2002-10-09 16:46) [1]

Если же подключаться к базе через TTable, то этой проблемы нет. Так подключаться не совсем корректно...


 
Johnny Smith ©   (2002-10-09 16:48) [2]

Какой тип у поля "EMPCHAR1_05"?


 
stur ©   (2002-10-09 16:49) [3]

VARCHAR(256)


 
Johnny Smith ©   (2002-10-09 17:30) [4]

Тут уже говорилось о том, что BDE принимает VarChar"овские типы длиной более 255 байт как BLOB. Соответственно, как мне кажется, он и пытается читать его как BLOB, то есть передавая для него ссылку на некий буфер, а не на переменную строкового типа. Отсюда и причина падения.
Мой совет - уйти с BDE на другую библиотеку доступа к данным.


 
stur ©   (2002-10-09 17:40) [5]

Возможно, но....
Почему всё работает при просмотре базы вперёд?
И всё нормально работает если использовать не TQuery( select * from EMP), а TTable ?


 
Johnny Smith ©   (2002-10-09 17:56) [6]

2stur © (09.10.02 17:40)
Честно сказать? Фиг его знает. Надо смотреть исходники BDE :^)))


 
petr_v_a ©   (2002-10-09 18:58) [7]

В настройках алиаса надо увеличить параметр BLOBS_TO_CACHE



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

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

Наверх




Память: 0.48 MB
Время: 0.02 c
3-101063
Саша К.
2002-10-12 04:59
2002.10.31
Delphi+ADO


1-101271
Vladislav
2002-10-22 14:22
2002.10.31
ShellExecute


14-101476
Mad_Ghost
2002-10-11 14:29
2002.10.31
есть число, как показать его в TEdit в шестнадцатеричном формате?


14-101487
Николай Быков
2002-10-11 15:46
2002.10.31
Бинарное дерево


1-101374
3asys
2002-10-21 12:04
2002.10.31
Моделирование design-time в run-time