Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2003.09.18;
Скачать: [xml.tar.bz2];

Вниз

Подмена полей в DBGride   Найти похожие ветки 

 
-=[SDA]=-   (2003-08-28 09:50) [0]

Вываливаю запрос в Grid, но некоторые поля имеют хитрые значения, например: "Н/У" - не установлено, или даты - 1.1.1900, или сокращенные названия, так вот хотелось бы, чтобы в БД оставалось всё по старому, а при выводе такие поля заменялись на новые значения, например: 1.1.1900 - "дата не введена" или "00-00-0000", Н/У - не установлена, вот! Пробовал на DrawDataCell писать типа: DBGrid1.Columns[Field.FieldNo-1].Field.Text := "ssssss"; - столбец строковый. Пишет: Query1: DataSet not in edit or insert mode.


 
stone   (2003-08-28 09:53) [1]

Создай вычисляемые поля и формируй их как тебе нравится. Их же и показывай.


 
-=[SDA]=-   (2003-08-28 09:58) [2]

А без вычисляемых полей как нибудь можно?


 
DenK_vrtz   (2003-08-28 10:02) [3]

в MSSQL есть такое понятие как view? и конструкция типа case?
Если да, то нет ничего проще!


 
Соловьев   (2003-08-28 10:02) [4]


> Пробовал на DrawDataCell писать типа: DBGrid1.Columns[Field.FieldNo-1].Field.Text
> := "ssssss"; - столбец строковый

все правильно пишет.
...
if Columns[0].Field.AsDateTime = "1.1.1900" then
TDBGrid(Sender).Canvas.DrawText(Rect.Left,Rect.Top,"дата не введена");
...


 
Fiend   (2003-08-28 10:02) [5]

тада используй у полей OnGetText & OnSetText.
там можешь пробразовать что и куда угодно


 
-=[SDA]=-   (2003-08-28 10:06) [6]

Всем большое спасибо! Буду пробовать.


 
Zacho   (2003-08-28 10:07) [7]

Еще вариант: использовать TDBGridEh, в нем есть такая фича


 
Sergey13   (2003-08-28 10:08) [8]

2-=[SDA]=- (28.08.03 09:50)
Что то у тебя данные имеют уж очень "хитрые значения", ИМХО. 8-)
Я бы посоветовал поразбираться со структурой данных. Например вместо "Н/У" сделать просто NULL. Или дефолтом текущую дату присваивать. Смотря по задаче. И для дат желательно, ИМХО, выбирать соответствующий тип поля.



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

Форум: "Базы";
Текущий архив: 2003.09.18;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.46 MB
Время: 0.009 c
1-58714
паша_ок
2003-09-08 07:43
2003.09.18
Определение имени компонента, на котором кликнули мышкой?


1-58615
McSimm2
2003-09-05 16:22
2003.09.18
---|Ветка была без названия|---


1-58666
АлексейК
2003-09-08 13:10
2003.09.18
16-Bit сегмент в 32-Bit


6-58822
danatelo
2003-07-17 16:16
2003.09.18
Пересылка файлов через FTP


4-58976
LambdA
2003-07-17 03:33
2003.09.18
Проблема со сменой разрешения экрана





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский