Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/22: Рейтинг темы: голосов - 22, средняя оценка - 4.86
12 / 12 / 2
Регистрация: 19.03.2012
Сообщений: 175
1

Ошибка: не удается найти строку для обновления. ADOQuery

25.03.2014, 19:46. Показов 4477. Ответов 6
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте, уважаемые! Пишу программу для расчета стоимости ремонта квартир. Программа использует Access, содержащий две таблицы: Demont (прайс с ценами на демонтаж) и Zakaz (в нее помещаем выбранные данные для заказа из таблицы Demont). Скриншот внешнего вида, для лучшего понимания, внизу. Принцип работы такой. На OnCreate открываем эти таблицы, кликаем два раза на нужной строке в верхнем DBGrid, проверяем указано ли количество в предыдущей строке, если да, то строка добавляется в нижний DBGrid (соответственно и в таблицу Zakaz), если не указано, то выводим мессагу "неверное количество", ставим фокус на последнюю строку столбца "количество", и ничего не добавляем.
Если сразу, после добавления, ввести количество и попытаться добавить новый пункт к заказу, то тогда и вылетает эта ошибка: "не удается найти строку для обновления. Некоторые значения могли быть изменены со времени ее последнего чтения". Я так и не смог понять где и что не так. Помогите, пожалуйста.
Сам код добавления новой строки в нижний DBGrid (sDBGrid1 - нижний, DBGrid1 - верхний).
Delphi
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
procedure TForm1.Zakaz;
begin
 
if ADOQuery2.RecordCount <> 0 then
begin
ADOQuery2.Post;
      //ADOQuery2.Last;
      //sDBGrid1.DataSource.DataSet.FieldByName('Count').FocusControl;
end;
ADOQuery2.SQL.Clear;
ADOQuery2.SQL.Add('SELECT * FROM Zakaz');
ADOQuery2.Active:=True;
 
 
if ADOQuery2.RecordCount = 0 then
begin
  Adoquery2.Insert;
  Adoquery2.FieldByName('Naimen').Value:=ADOQuery1.FieldByName('Naimen').AsString;
  Adoquery2.FieldByName('Ed_Izm').Value:=ADOQuery1.FieldByName('Ed_izm').AsString;
  Adoquery2.FieldByName('Price').Value:=ADOQuery1.FieldByName('Price').asInteger;
  ADOQuery2.Post;
end else
begin
  ADOQuery2.Last;
  if ADOQuery2.FieldByName('Count').AsInteger > 0 then
    begin
      Adoquery2.Insert;
      Adoquery2.FieldByName('Naimen').Value:=ADOQuery1.FieldByName('Naimen').AsString;
      Adoquery2.FieldByName('Ed_Izm').Value:=ADOQuery1.FieldByName('Ed_izm').AsString;
      Adoquery2.FieldByName('Price').Value:=ADOQuery1.FieldByName('Price').asInteger;
      ADOQuery2.Post;
    end else
    begin
      ShowMessage('Неверное количество');
      ADOQuery2.Last;
      sDBGrid1.DataSource.DataSet.FieldByName('Count').FocusControl;
    end;
end;
end;
Миниатюры
Ошибка: не удается найти строку для обновления. ADOQuery  
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
25.03.2014, 19:46
Ответы с готовыми решениями:

Delphi Ошибка "Не удается найти строку для обновления" не ADOQuery
Три DBGrid 'а связаны через ADOTable,DataSourse и ADOConnection. При первом запуске программы...

Ошибка: "Не удается найти строку для обновления"
Подключена с помощью ADO. На другой диск сделана копия программы. Одновременно открываются две...

Ошибка "Не удается найти строку для обновления" при выполнении триггера
Есть код триггера,( не судите строго если написано неправильно что то укажите если можно) ...

Не удается найти строку для обновления
Доброго времени суток, не могу разобраться с ошибкой &quot;Не удается найти строку для обновления....

6
12 / 12 / 2
Регистрация: 19.03.2012
Сообщений: 175
28.03.2014, 11:08  [ТС] 2
Неужели никто не знает?
0
пофигист широкого профиля
4735 / 3168 / 860
Регистрация: 15.07.2013
Сообщений: 18,255
28.03.2014, 11:14 3
Цитата Сообщение от Vyazan Посмотреть сообщение
procedure TForm1.Zakaz;
begin
if ADOQuery2.RecordCount <> 0 then
begin
ADOQuery2.Post;
Что делает этот Post?
0
12 / 12 / 2
Регистрация: 19.03.2012
Сообщений: 175
28.03.2014, 16:39  [ТС] 4
Сохраняет первую запись
0
пофигист широкого профиля
4735 / 3168 / 860
Регистрация: 15.07.2013
Сообщений: 18,255
28.03.2014, 17:00 5
Цитата Сообщение от Vyazan Посмотреть сообщение
Сохраняет первую запись
Какую первую запись, если перед этим вызовом Post нет вызова ни Insert, ни Edit?
0
12 / 12 / 2
Регистрация: 19.03.2012
Сообщений: 175
28.03.2014, 17:24  [ТС] 6
Ну да. Получается, что лишняя строчка. Убрал. Проблема не решилась. Кину весь код, может дело не в этой процедуре.
Delphi
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
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
unit Unit1;
 
interface
 
uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, sSkinManager, Grids, DBGrids, DB, ADODB, acDBGrid, ComCtrls,
  sTreeView, StdCtrls, Mask, DBCtrls, sDBEdit, sMaskEdit, sCustomComboEdit,
  sCurrEdit, sDBCalcEdit, sEdit, sGroupBox, sLabel, sDBText, ExtCtrls,
  sButton, inifiles;
 
type
  TForm1 = class(TForm)
    sSkinManager1: TsSkinManager;
    ADOConnection1: TADOConnection;
    ADOQuery1: TADOQuery;
    DataSource1: TDataSource;
    sTreeView1: TsTreeView;
    ADOQuery2: TADOQuery;
    DataSource2: TDataSource;
    DBGrid1: TsDBGrid;
    sDBGrid1: TsDBGrid;
    ADOQuery2Sum: TIntegerField;
    sButton1: TsButton;
    Label1: TsLabel;
    ADOQuery2Naimen: TWideStringField;
    ADOQuery2Ed_izm: TWideStringField;
    ADOQuery2Count: TIntegerField;
    ADOQuery2Price: TBCDField;
    sCalcEdit1: TsCalcEdit;
    sLabel1: TsLabel;
    procedure FormCreate(Sender: TObject);
    procedure DBGrid1KeyDown(Sender: TObject; var Key: Word;
      Shift: TShiftState);
    procedure Zakaz;
    procedure DBGrid1DblClick(Sender: TObject);
 
    procedure sDBGrid1DblClick(Sender: TObject);
    procedure sDBGrid1CellClick(Column: TColumn);
    procedure sDBGrid1MouseMove(Sender: TObject; Shift: TShiftState; X,
      Y: Integer);
    procedure DBGrid1MouseMove(Sender: TObject; Shift: TShiftState; X,
      Y: Integer);
    procedure ADOQuery2CalcFields(DataSet: TDataSet);
    procedure sDBGrid1ScrollData(Sender: TObject);
    procedure sButton1Click(Sender: TObject);
    procedure FormDestroy(Sender: TObject);
    procedure sTreeView1Click(Sender: TObject);
 
  private
    { Private declarations }
  public
    { Public declarations }
  end;
 
var
  Form1: TForm1;
  ini:TiniFile;
 
implementation
 
{$R *.dfm}
 
procedure TForm1.FormCreate(Sender: TObject);
var
  i,c:integer;
begin
Ini:=TiniFile.Create(extractfilepath(paramstr(0))+'Settings.ini');
c:=Ini.ReadInteger('Settings Table1', 'Count',1);
  for i:=0 to c-1 do DBGrid1.Columns.Items[i].Width:=ini.ReadInteger('Settings Table1', 'Width Colums'+IntToStr(i),30);
 
c:=Ini.ReadInteger('Settings Table2', 'Count',1);
  for i:=0 to c-1 do sDBGrid1.Columns.Items[i].Width:=ini.ReadInteger('Settings Table2', 'Width Colums'+IntToStr(i),30);
 
ADOQuery2.SQL.Clear;
ADOQuery2.SQL.Add('SELECT * FROM Zakaz');
ADOQuery2.Active:=True;
 
ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Add('SELECT * FROM Demont');
ADOQuery1.Active:=True;
end;
 
procedure TForm1.DBGrid1KeyDown(Sender: TObject; var Key: Word;
  Shift: TShiftState);
begin
if key = 13 then
begin
  Zakaz;
end;
end;
 
procedure TForm1.Zakaz;
begin
 
if ADOQuery2.RecordCount <> 0 then
begin
ADOQuery2.Post;
      //ADOQuery2.Last;
      //sDBGrid1.DataSource.DataSet.FieldByName('Count').FocusControl;
end;
ADOQuery2.SQL.Clear;
ADOQuery2.SQL.Add('SELECT * FROM Zakaz');
ADOQuery2.Active:=True;
 
 
if ADOQuery2.RecordCount = 0 then
begin
  Adoquery2.Insert;
  Adoquery2.FieldByName('Naimen').Value:=ADOQuery1.FieldByName('Naimen').AsString;
  Adoquery2.FieldByName('Ed_Izm').Value:=ADOQuery1.FieldByName('Ed_izm').AsString;
  Adoquery2.FieldByName('Price').Value:=ADOQuery1.FieldByName('Price').asInteger;
  ADOQuery2.Post;
end else
begin
  ADOQuery2.Last;
  if ADOQuery2.FieldByName('Count').AsInteger > 0 then
    begin
      Adoquery2.Insert;
      Adoquery2.FieldByName('Naimen').Value:=ADOQuery1.FieldByName('Naimen').AsString;
      Adoquery2.FieldByName('Ed_Izm').Value:=ADOQuery1.FieldByName('Ed_izm').AsString;
      Adoquery2.FieldByName('Price').Value:=ADOQuery1.FieldByName('Price').asInteger;
      ADOQuery2.Post;
    end else
    begin
      ShowMessage('Íåâåðíîå êîëè÷åñòâî');
      ADOQuery2.Last;
      sDBGrid1.DataSource.DataSet.FieldByName('Count').FocusControl;
    end;
end;
end;
 
procedure TForm1.DBGrid1DblClick(Sender: TObject);
begin
Zakaz;
end;
 
 
 
procedure TForm1.sDBGrid1DblClick(Sender: TObject);
begin
ADOQuery2.Edit;
if sDBGrid1.Options = [dgTitles,dgIndicator,dgColumnResize,dgColLines,dgRowLines,dgTabs,dgRowSelect,dgConfirmDelete,dgCancelOnExit] then
sDBGrid1.Options:=[dgEditing,dgTitles,dgIndicator,dgColumnResize,dgColLines,dgRowLines,dgTabs,dgConfirmDelete,dgCancelOnExit]
else
//sDBGrid1.Options:=[dgTitles,dgIndicator,dgColumnResize,dgColLines,dgRowLines,dgTabs,dgRowSelect,dgConfirmDelete,dgCancelOnExit];
end;
 
procedure TForm1.sDBGrid1CellClick(Column: TColumn);
begin
ADOQuery2.Edit;
end;
 
procedure TForm1.sDBGrid1MouseMove(Sender: TObject; Shift: TShiftState; X,
  Y: Integer);
begin
ADOQuery2.edit;
end;
 
procedure TForm1.DBGrid1MouseMove(Sender: TObject; Shift: TShiftState; X,
  Y: Integer);
begin
if ADOQuery2.RecordCount <> 0 then
ADOQuery2.Edit;
end;
 
procedure TForm1.ADOQuery2CalcFields(DataSet: TDataSet);
begin
ADOQuery2Sum.AsInteger:=ADOQuery2Price.AsInteger*ADOQuery2Count.AsInteger;
end;
 
procedure TForm1.sDBGrid1ScrollData(Sender: TObject);
begin
sDBGrid1.Options:=[dgTitles,dgIndicator,dgColumnResize,dgColLines,dgRowLines,dgTabs,dgRowSelect,dgConfirmDelete,dgCancelOnExit];
end;
 
 
 
procedure TForm1.sButton1Click(Sender: TObject);
var
  i:integer;
begin
i:=0;
if ADOQuery2.RecordCount > 0 then
begin
sdbgrid1.datasource.dataset.first;
while not sdbgrid1.datasource.dataset.eof do
  begin
   i:=i+sdbgrid1.datasource.dataset.fieldbyname('Sum').asinteger;
    sdbgrid1.datasource.dataset.next;
  end;
end;
//Edit1.Text:=(IntToStr(i))+' ðóá.';
sCalcEdit1.Text:= (IntToStr(i));
end;
 
procedure TForm1.FormDestroy(Sender: TObject);
var
 
  i:integer;
begin
  Ini:=TiniFile.Create(extractfilepath(paramstr(0))+'Settings.ini');
    for i:=0 to DbGrid1.Columns.Count-1 do
  begin
  ini.Writeinteger('Settings Table1', 'Width Colums'+IntToStr(i), (DBGrid1.Columns[i].width));
  end;
 ini.Writeinteger('Settings Table1', 'Count',DbGrid1.Columns.Count);
 
  for i:=0 to sDbGrid1.Columns.Count-1 do
  begin
  ini.Writeinteger('Settings Table2', 'Width Colums'+IntToStr(i), (sDBGrid1.Columns[i].width));
  end;
 ini.Writeinteger('Settings Table2', 'Count',sDbGrid1.Columns.Count);
  ini.Free;
end;
 
procedure TForm1.sTreeView1Click(Sender: TObject);
begin
if sTreeView1.Selected.Text = 'Äåìîíòàæíûå ðàáîòû' then
begin
ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Add('SELECT * FROM Demont');
ADOQuery1.Active:=True;
end;
 
if sTreeView1.Selected.Text = 'Îáùåñòðîèòåëüíûå ðàáîòû' then
begin
ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Add('SELECT * FROM Obshie');
ADOQuery1.Active:=True;
end;
 
if sTreeView1.Selected.Text = 'Îêíà/Äâåðè/Áàëêîí' then
begin
ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Add('SELECT * FROM Okna');
ADOQuery1.Active:=True;
end;
 
if sTreeView1.Selected.Text = 'Ñàíòåõíè÷åñêèå ðàáîòû' then
begin
ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Add('SELECT * FROM Santeh');
ADOQuery1.Active:=True;
end;
 
 
end;
 
end.
0
0 / 0 / 0
Регистрация: 30.05.2016
Сообщений: 9
01.06.2018, 09:17 7
Проблема заключяется в том что у тебя два раза указан Post Просто ты переводишь Query в режим редактирования insert а после сохраняешь post а потом снова используешь post при отключенном режиме редактирования
0
01.06.2018, 09:17
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
01.06.2018, 09:17
Помогаю со студенческими работами здесь

Не удается найти строку для обновления ADO
доброго времени суток. есть база на mysql. есть проблема при изменении у записи значения 1...

ADOQuery Ошибка: 'Не удаётся открыть фильтр'
что не так? procedure TForm1.Edit1Change(Sender: TObject); begin if Length(Edit1.Text) &lt;&gt; 0...

Не удаётся установить обновления через Центр обновления Windows
После отката системы не получается обновиться через Центр обновления Windows. Поиск обновлений...

Ошибка: "Не удается запустить программу: Не удается найти указанный файл"
Написал вот такую вот мини програмку ( я только начинаю учиться) #include &lt;iostream&gt; #include...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru