Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 08.10.2010, 18:00
amok amok вне форума
Прохожий
 
Регистрация: 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.
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 17:13.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter