0 / 0 / 0
Регистрация: 27.03.2007
Сообщений: 37
Oracle

DBGrid, обновление содержимого столбца

07.11.2007, 10:51. Показов 9400. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
ОЧЕНЬ ПРОШУ ПОМОЧЬ РЕШИТЬ ПРОБЛЕМУ.
Есть запрос,состоящий из 2-х таблиц:
Oracle 11 SQL
1
2
3
 SELECT t.n_tel,fio,sumnmtr,datanmtr,sumnabon,datanabon,sumopl,dataopl,
 TRIM(TO_CHAR((NVL(sumnmtr,0)+NVL(sumnabon,0)-NVL(sumopl,0)) ,'999,990.99')) SUMDOLG,t.ROWID   
 FROM tab1 t ,tab2 tt WHERE N_TEL=TT.N_TEL(+) AND T.PR_PES=TT.PR_PES(+)
Формируется виртуальный столбец -SUMDOLG.который состоит из суммы 3-х столбцов .
Я в форме в DBGrid меняю содержание столбца SUMOPL - при этом мне ОЧЕНЬ надо ,чтобы
изменилось содержание солбца SUMDOLG.
НО он не меняется.Если я закрою окно и по-новому войду в него,то все меняется верно!
В ЧЕМ ДЕЛО? Я очень прошу,помогите,может кто-то сталкивался с такой проблемой.


СУБД-ОРАКЛ,СВЯЗЬ-ADOQuery.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
07.11.2007, 10:51
Ответы с готовыми решениями:

Чтение содержимого ячейки DBGrid-а
И снова добрый вечер) На этот раз мне нужно прочитать данные из столбца ДБГрида в, например, Мэмо, или масив, али комбобокс. Нигде не...

Обновление содержимого БД
Столкнулась с проблемой обновления содержимого БД при работе с одной базой с нескольких компьютером, содержимое БД обновляется только после...

Вывод на печать содержимого stringrid или dbgrid
Здравствуйте.Как можно вывести на печать содержимое stringrid или dbgrid, а в частности adotable???

10
Администратор
 Аватар для mik-a-el
87856 / 53177 / 249
Регистрация: 10.04.2006
Сообщений: 13,764
07.11.2007, 11:24
Цитата Сообщение от moroz
НО он не меняется.Если я закрою окно и по-новому войду в него,то все меняется верно!
В ЧЕМ ДЕЛО? Я очень прошу,помогите,может кто-то сталкивался с такой проблемой.
Это не проблема, так и должно быть Если хотите, чтобы он менялся, то меняйте вручную, либо пересчитывайте данные из базы.
0
Почетный модератор
 Аватар для Lord_Voodoo
8785 / 2538 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
07.11.2007, 12:03
ну просто надо произвести рефреш датасета, т.е. закрыть и открыть и все изменится, просто на событие onchange повесить, но есть проблема, при большом объеме данных будет лихо моргать твой пересчет
0
Администратор
 Аватар для mik-a-el
87856 / 53177 / 249
Регистрация: 10.04.2006
Сообщений: 13,764
07.11.2007, 12:14
Кстати, насколько я помню, в датасете должны быть вычисляемые поля Почему бы их не использовать?
0
Почетный модератор
 Аватар для Lord_Voodoo
8785 / 2538 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
07.11.2007, 12:18
Цитата Сообщение от mik-a-el Посмотреть сообщение
Кстати, насколько я помню, в датасете должны быть вычисляемые поля Почему бы их не использовать?
они пересчитываются ли, при редактировании, просто dbgrid - это крайне смурной компонент в билдере, хотя вполне возможно, что это самое простое решение...
0
Администратор
 Аватар для mik-a-el
87856 / 53177 / 249
Регистрация: 10.04.2006
Сообщений: 13,764
07.11.2007, 12:21
Так тогда можно избавиться от рассчета этого поля в запросе, а считать в вычисляемом поле.
0
Почетный модератор
 Аватар для Lord_Voodoo
8785 / 2538 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
07.11.2007, 12:27
на том и порешили... только я помню программно настраивал - в первый раз, пока не понимаешь, что куда и зачем, это проблема
0
0 / 0 / 0
Регистрация: 27.03.2007
Сообщений: 37
07.11.2007, 15:05  [ТС]
Вот то,что пересчитать?А в какое событие впихнуть ?
C++
1
2
3
4
ADOQuery1->FieldByName("SUMDOLG")->AsFloat =
  ADOQuery1r->FieldByName("SUMNMTR")->AsFloat +
  ADOQuery1->FieldByName("SUMNABON")->AsFloat -
  ADOQuery1->FieldByName("SUMOPL")->AsFloat;
Только ничего не получается.
При изменении столбца SUMOPL в DBGrid никаких изменений не происходит сразу.
Надо закрыть окно и войти в него по-новому-только тогда изменения можно увидеть.
Вопрос:
Событие OnChange() я не могу найти.Есть OnDataChange(),OnStateChange().
0
Почетный модератор
 Аватар для Lord_Voodoo
8785 / 2538 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
07.11.2007, 16:50
нет, эти события зараты в поля датасета, т.е. тебе на конкретном поле надо создать это событие... в хелпе поищи:
In TField события OnChange
OnGetText
OnSetText
OnValidate
0
Гость
08.11.2007, 10:36
Я не знаю как это сделать.
C++
1
ADOQuery1->FieldByName("SUMDOLG")->AsFloat =ADOQuery1->FieldByName("SUMNMTR")->AsFloat+ADOQuery1->FieldByName("SUMNABON")->AsFloat-ADOQuery1->FieldByName("SUMOPL")->AsFloat;
Я так делала,но ничего не меняет.
Если можно,помогите кодом.

Еще делала так:
Запрос в ф-ии FormActive() .Когда меняла значение суммі в столбце,то в событии AfterPost() я закрыла и открыла по-новому свой запрос.Все меняется очень хорошо.НО!!!
При этом аврийно завершается программа-при обращении к ф-ии меню (видит всего-то 1 столбец!
А их 9!).Если я закомментировала строку сменю (как в примере),то при этом заголовки столбцов(на русском) в DBGrid исчезли,появились-английские названия столбцов.Может Вы поможете мне написать ,т.е. вернуть (но как???) заголовки столбцов на русском.
Пример:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
void __fastcall TM_Lsab::ADOQueryPerAfterPost(TDataSet *DataSet)
{
  RecordNumber=ADOQueryPer->RecNo;
  ADOQuery1->SQL->Clear();
  ADOQuery1->Close();
  ADOQuery1->SQL->LoadFromFile("SQL/Baza.sql");
  ADOQuery1->Open();
 // Menu_Baza();  ---Это меню,если его выбросить,то заголовки не на русском 
 
      DataSource1->DataSet = ADOQuery1;
     //Связываем возвращаемый набор данных и визуальные компоненты
      DBGridBaza->DataSource =  DataSource1;
      DBNavigatorBaza->DataSource = DataSource1;
      DataSource1->DataSet->MoveBy(RecordNumber-1);
     DBGridBaza->SelectedIndex=7;
     DBGridBaza->SetFocus();
 }
 
void __fastcall TBazatel::Menu_Baza()
 {
  for (k=0; k<=DBGridBaza->Columns->Count-1;k++)
  {    DBGridBaza->Columns->Items[k]->Title->Color=clSilver;}
 
   DBGridBaza->Columns->Items[0]->Title->Caption="Н-р телефона";
   DBGridBaza->Columns->Items[1]->Title->Caption="Cумма МТР";
 
................
}
Почетный модератор
 Аватар для Lord_Voodoo
8785 / 2538 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
08.11.2007, 13:32
погоди, а зачем тебе название столбцов в этом событии назначать, обычно это все делается в конструкторе, и желательно структуру в DBGrid там же указать, тогда не надо будет после открытия запроса заново именовать title колонок:
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
//---------------------------------------------------------------------------
// Формирование отображения таблиц на экране
void __fastcall TMainForm::SetField()
{
  TColumn *Column;
  for(int i = 0; i < Query1->FieldCount; i++){
    Struct->Add(SetTableField(Query1, Query1->Fields->Fields[i]->FieldName));
    Struct->Fields[i]->DisplayLabel = GridInfo->Strings[i];
    Column = DBGrid1->Columns->Add();
    Column->Field = Struct->Fields[i];
    Column->Alignment = taCenter;
  }
  Query1->Close();
  for(int i = 0; i < Struct->Count; i++){
    Struct->Fields[i]->DataSet = Query1;
  }
  DBGrid1->Columns->Items[9]->Visible = false;
  Query1->Open();
}
 
TField* TMainForm::SetTableField(TQuery *Table, AnsiString FName)
{
  TField *FField;
  switch(Table->FieldByName(FName)->DataType){
    case ftString:
      FField = new TStringField(this);
      FField->FieldName = FName;
      FField->Size = Table->FieldByName(FName)->Size;
      break;
    case ftSmallint:
      FField = new TSmallintField(this);
      FField->FieldName = FName;
      break;
    case ftInteger:
      FField = new TIntegerField(this);
      FField->FieldName = FName;
      break;
    case ftWord:
      FField = new TWordField(this);
      FField->FieldName = FName;
      break;
    case ftFloat:
      FField = new TFloatField(this);
      FField->FieldName = FName;
      break;
    case ftCurrency:
      FField = new TCurrencyField(this);
      FField->FieldName = FName;
      break;
    case ftBCD:
      FField = new TBCDField(this);
      FField->FieldName = FName;
      FField->Size = Table->FieldByName(FName)->Size;
      break;
    case ftDate:
      FField = new TDateField(this);
      FField->FieldName = FName;
      break;
    case ftTime:
      FField = new TTimeField(this);
      FField->FieldName = FName;
      break;
    case ftDateTime:
      FField = new TDateTimeField(this);
      FField->FieldName = FName;
      break;
    case ftAutoInc:
      FField = new TAutoIncField(this);
      FField->FieldName = FName;
      break;
    case ftMemo:
    case ftFmtMemo:
      FField = new TMemoField(this);
      FField->FieldName = FName;
      break;
    case ftBoolean:
      FField = new TBooleanField(this);
      FField->FieldName = FName;
      break;
    case ftUnknown:
      break;
    case ftBytes:
      FField = new TBytesField(this);
      FField->FieldName = FName;
      break;
    case ftVarBytes:
      FField = new TVarBytesField(this);
      FField->FieldName = FName;
      break;
    case ftBlob:
      FField = new TBlobField(this);
      FField->FieldName = FName;
      break;
    case ftGraphic:
      FField = new TGraphicField(this);
      FField->FieldName = FName;
      break;
    case ftParadoxOle:
      break;
    case ftDBaseOle:
      break;
    case ftTypedBinary:
      break;
    case ftCursor:
      break;
  }
  return FField;
}
 
а в конструкторе:
....
  GridInfo = new TStringList();
  GridInfo->Add("Статус");
  GridInfo->Add("Код документа");
  GridInfo->Add("Класс абонента");
  GridInfo->Add("Телефон");
  GridInfo->Add("Номер запроса");
  GridInfo->Add("Регистрация запроса");
  GridInfo->Add("Номер наряда");
  GridInfo->Add("Регистрация наряда");
  GridInfo->Add("Тип дома");
  GridInfo->Add("ID");
  SetField();
....
mik-a-el: Блин, вы задолбали не использовать бб-код [CODE] (кнопочка с решеткой в редакторе)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.11.2007, 13:32
Помогаю со студенческими работами здесь

Обновление содержимого AdoTable
Хай! не подскажите как обновить adotable когда добавляем на первой форме строчку после переходим в другую форму а там не отобразилась...

Обновление данных в DBGrid
Есть три TEdit, ввожу в них данные и нажимаю на button, все данные заносятся в таблицу, в таблице три поля, то есть данные по порядку...

Обновление данных в DBGrid
Как обновить данные в DBGrid после добавления?

Обновление данных в DBGrid
ADOQuery1-&gt;Close(); ADOQuery1-&gt;SQL-&gt;Clear(); ADOQuery1-&gt;SQL-&gt;Add(&quot;INSERT INTO Оплата (ФІО, Логін, Місяць_оплати, Сума,...

Обновление данных в DBGrid
Возможно избитый вопрос, но ответа я не нашёл. Имеется 2 формы, на первой происходит добавление данных через ADOTable1-&gt;Insert(); , на...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Опции темы

Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru