08.10.2010, 18:00
|
Прохожий
|
|
Регистрация: 08.10.2010
Сообщения: 1
Репутация: 10
|
|
Проблема редактирования DBGrid
Есть такая связка ADOConnection->ADODataSet->ADODataSource->DBGrid. Туда вывожу таблицу базы данных из двух полей(столбцов). По двойному щелчку редактирую ячейку всё хорошо, но когда в этой таблице в базе данных поставить одно из полей как Primary Key или Unique при редактировании появляется ошибка - исключение "недостаточно сведений из основной таблицы для обновления".
Код:
unit Unit1;
interface
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, StdCtrls, DB, ADODB, Grids, Wwdbigrd, Wwdbgrid, DBGrids;
type
TForm1 = class(TForm)
ADOConnection: TADOConnection;
ADODataSet: TADODataSet;
DataSource: TDataSource;
Button1: TButton;
Memo: TMemo;
DBGrid1: TDBGrid;
procedure FormCreate(Sender: TObject);
procedure FormClose(Sender: TObject; var Action: TCloseAction);
procedure Button1Click(Sender: TObject);
private
{ Private declarations }
public
{ Public declarations }
end;
var
Form1: TForm1;
memocnt: Integer;
implementation
{$R *.dfm}
procedure TForm1.FormCreate(Sender: TObject);
begin
try
ADOConnection.Open;
Memo.Lines.Add(IntToStr(memocnt)+'Соединился');
memocnt:=memocnt+1;
except
Memo.Lines.Add(IntToStr(memocnt)+' | '+'Ошибка');
end;
end;
procedure TForm1.FormClose(Sender: TObject; var Action: TCloseAction);
begin
ADOConnection.Close;
end;
procedure TForm1.Button1Click(Sender: TObject);
begin
ADODataSet.Active:=False;
ADODataSet.CommandText:='CALL "DBA"."DefaultCurrent"("table_name" = '+''''+'id'+''''+',"order_val" = '+''''+'name'+''''+')';
//тоже самое, что и
//ADODataSet.CommandText:='select * from dba.info;';
ADODataSet.Active:=True;
end;
end.
Admin: Пользуемся тегами!
Последний раз редактировалось Admin, 08.10.2010 в 18:02.
|