Последние записи
- TChromium (CEF3), сохранение изображений
- Как в Delphi XE обнулить таймер?
- Изменить цвет шрифта TextBox на форме
- Ресайз PNG без потери прозрачности
- Вывод на печать графического файла
- Взаимодействие через командную строку
- Перенести программу из Delphi в Lazarus
- Определить текущую ОС
- Автоматическая смена языка (раскладки клавиатуры)
- Сравнение языков на массивах. Часть 2
Интенсив по Python: Работа с API и фреймворками 24-26 ИЮНЯ 2022. Знаете Python, но хотите расширить свои навыки?
Slurm подготовили для вас особенный продукт! Оставить заявку по ссылке - https://slurm.club/3MeqNEk
Online-курс Java с оплатой после трудоустройства. Каждый выпускник получает предложение о работе
И зарплату на 30% выше ожидаемой, подробнее на сайте академии, ссылка - ttps://clck.ru/fCrQw
29th
Авг
Когда добавляю новую колонку в базу, хочу чтобы ее сразу можно было увидеть в DBGrid
Posted by Chas under Delphi, Пост-обзор
Когда добавляю новую колонку в базу, хочу чтобы ее сразу можно было увидеть в DBGrid новую колонку, в обычном режиме — дизайн тайме нужно кликнуть два раза на TIBQuery и правой кнопкой и выбрать Add all fields.
Как программно добавить новое поле?
Serge_Bliznykov
фактически, Вам нужен такой код:
field := TWideStringField.Create(nil);
with field do begin
Size:= 20;
FieldName := FieldNameAdd;
Dataset := ADODataSet1;
end;
вот, кинул такой код на кнопочку (добавляет отсутствующие в датасете поля):
procedure TForm1.Button1Click(Sender: TObject);
var i: integer;
field : TField;
FieldNameAdd : string;
begin
ADODataSet1.Close;
for I := 0 to ADODataSet1.FieldDefList.Count - 1 do
with ADODataSet1.FieldDefList[I] do
if (FieldClass <> nil) and not (faHiddenCol in Attributes) then
begin
FieldNameAdd := ADODataSet1.FieldDefList.Strings[I];
Field := ADODataSet1.FindField(FieldNameAdd);
if (Field = nil) or (Field.Owner <> ADODataSet1.Owner) then begin
field := TWideStringField.Create(nil);
with field do begin
Size:= 20;
FieldName := FieldNameAdd;
Dataset := ADODataSet1;
end;
with DBGrid1.Columns.Add do
begin
FieldName:= FieldNameAdd;
end;
end;
end;
ADODataSet1.Open;
end;
Похожие статьи
Купить рекламу на сайте за 1000 руб
пишите сюда - alarforum@yandex.ru
Да и по любым другим вопросам пишите на почту
пеллетные котлы
Пеллетный котел Emtas
Наши форумы по программированию:
- Форум Web программирование (веб)
- Delphi форумы
- Форумы C (Си)
- Форум .NET Frameworks (точка нет фреймворки)
- Форум Java (джава)
- Форум низкоуровневое программирование
- Форум VBA (вба)
- Форум OpenGL
- Форум DirectX
- Форум CAD проектирование
- Форум по операционным системам
- Форум Software (Софт)
- Форум Hardware (Компьютерное железо)