Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2007.09.30;
Скачать: CL | DM;

Вниз

Проблема автоинкримента и ClientDataSet а!   Найти похожие ветки 

 
YURA-007   (2007-05-23 19:52) [0]

Всем добрый вечер! При добавлении новой записи в ClientDataSet, точнее при сохранении записи, автоинкрементное поле не генерируется, а остаётся пустым, в результате после добавления второй записи(точнее сохранении), выскакивает Key Violation. Почему поле не генерируется, в Table всё работает отлично. БД Paradox Зарание спасибо!


 
Johnmen ©   (2007-05-24 09:10) [1]

AutoGenerateValue и далее по теме.


 
YURA-007   (2007-05-24 10:23) [2]


> AutoGenerateValue и далее по теме.


> Если это вы о свойстве автоинкрементного поля, то его значение
> и у Table и у ClientDataSet = arNone(по умолчанию), но я
> менял его на arAutoInc, и у Table и у ClientDataSet, но
> результат тот же самый – у Table при сохранении записи поле
> генерируется, у ClientDataSet нет!
> И какими бы я способами не пытался сохранять, добавлять
> не разу это поле не сгенерировалось!


 
Johnmen ©   (2007-05-24 10:30) [3]

Приводи полное описание связок (в первую очередь CDS) и алгоритма работы.


 
YURA-007   (2007-05-24 11:46) [4]

Соединение самое простое
ClientDataSet1 - ProviderName->DataSetProvider1
DataSetProvider1 - DataSet->Table1
DataSource1 – DataSet-> ClientDataSet1
DBGrid1 и DBNavigator1 – DataSource-> DataSource1

В редактор полей ClientDataSet добавлены все поля из Table, в том числе и автоинкремент.
Ну а сам Table1, со своим личным DataSource2, DBGrid2 и DBNavigator2  настроены и работают как положено.

------
var
 Form1: TForm1;
 MySavePoint: integer;
 Modified: boolean;
-------

Procedure FormCreate
begin
Table1.Open;
ClientDataSet1.FileName:="Save.XML";
ClientDataSet1.Open;
ClientDataSet1.SaveToFile("", dfXML);
Mysavepoint:=ClientDataSet1.SavePoint;
end;

Добавление, сохранение происходит через навигатор.
И есть две кнопки
1. В базу
begin
ClientDataSet1.ApplyUpdates(-1);
Table1.Refresh;
MySavePoint:=ClientDataSet1.SavePoint;
Modified:=false;
end;

2. В файл
begin
MySavePoint:=ClientDataSet1.SavePoint;
Modified:=true;
end;

Причём если нажать В базу, при сохранении, то добавляемая строка в Table записывается как положено, а в ClientDataSet, как всегда без генерации.
С кодом проблем я думаю быть не может, его практически нет. Может флаг какой у ClientDataSet1 или DataSetProvider1, или я что-то не правильно соеденил, ваще не пойму.


 
YURA-007   (2007-05-24 18:44) [5]

Что-то толи нет мастеров, толи не хотят мастера помочь мне!


 
Shaman_ ©   (2007-05-25 22:41) [6]

может и есть у CDS возможность автоматом загружать значение автоинкрементного поля после applyupdates, но я так и не нашел у этого класса такой возможности.  Приходится каждый раз вручную запрашивать сгенерированные базой значения и добавлять в CDS



Страницы: 1 вся ветка

Текущий архив: 2007.09.30;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.027 c
2-1189010873
Виктор007
2007-09-05 20:47
2007.09.30
Формат map файла


2-1188545064
_Iv_
2007-08-31 11:24
2007.09.30
Массив и ресурсы(*.res)


2-1188571097
sashap
2007-08-31 18:38
2007.09.30
Отправка символа другому окну


15-1188811524
Alien1769
2007-09-03 13:25
2007.09.30
Демонстрация "правильной" работы в системе Клиент-Сервер


3-1179895908
RomanLN
2007-05-23 08:51
2007.09.30
Как организовать запрос для DBGrid