Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 12.01.2012, 20:11
graf.da graf.da вне форума
Прохожий
 
Регистрация: 07.12.2011
Сообщения: 4
Репутация: 10
По умолчанию TDBGrid не показывает техт...

В проекте имеется компонент TADOQuery, который через запрос получает определенные данные из БД MSSql.
Данные из Query должны отображаться в TDBGridEh. Но проблема в том что одно текстовое-поле( varchar (мах) ), отображаться в таблице только этим -> (МЕМО) а должен текстом, кот. находится в этом поле...
Как можно решить эту проблему?
Ответить с цитированием
  #2  
Старый 12.01.2012, 20:40
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Если TDBGridEh не умеет отображать данные мемо непосредственно в гриде, то тогда ручками или сделать отдельное окошко под вывод содержимого мемо.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #3  
Старый 12.01.2012, 20:50
graf.da graf.da вне форума
Прохожий
 
Регистрация: 07.12.2011
Сообщения: 4
Репутация: 10
По умолчанию

Цитата:
Сообщение от Страдалецъ
Если TDBGridEh не умеет отображать данные мемо непосредственно в гриде, то тогда ручками ...

можно пример!!!!
Ответить с цитированием
  #4  
Старый 12.01.2012, 20:58
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Можно. Вот что на просторах инета пишут по этому поводу:
Код:
Как показать содержание поля Memo в DBGrid? 
procedure TForm1.DBGrid1DrawDataCell(Sender: TObject; const Rect: TRect;
Field: TField; State: TGridDrawState);
var
P : array [0..50] of char; {array size is number of characters needed}
BS : tBlobStream; {from the memo field}
S : String;
begin
If Field is TMemoField then begin
with (Sender as TDBGrid).Canvas do
begin
{Table1Notes is the TMemoField}
BS := tBlobStream.Create(Table1Notes, bmRead);
FillChar(P,SizeOf(P),#0); {terminate the null string}
BS.Read(P, 50); {read 50 chars from memo into blobStream}
BS.Free;
S := StrPas(P);
while Pos(#13, S) > 0 do {remove carriage returns and}
S[Pos(#13, S)] := ' '; {line feeds}
While Pos(#10, S) > 0 do
S[Pos(#10, S)] := ' ';
FillRect(Rect); {clear the cell}
TextOut(Rect.Left, Rect.Top, S); {fill cell with memo data}
end;
end;
end;
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #5  
Старый 13.01.2012, 14:10
graf.da graf.da вне форума
Прохожий
 
Регистрация: 07.12.2011
Сообщения: 4
Репутация: 10
Радость

ОГРОМНОЕ Спасибо!
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 17:47.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter