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

Вниз

Как не вставлять пустую запись?   Найти похожие ветки 

 
Санёк   (2004-04-22 09:11) [0]

В конструкции:

with DataSet do if State in [dsInsert, dsEdit] then Post;

есть одно, но: вставляется пустая запись, как можно этого избежать, ведь DataSet знает, что она пустая, как это определить мне.


 
Reindeer Moss Eater ©   (2004-04-22 09:14) [1]

TField.IsNull


 
DenK_vrtz ©   (2004-04-22 09:15) [2]

Поставить у поля Required=true или в описании таблицы у поля not null


 
Санёк   (2004-04-22 09:17) [3]

Это по полю, а как узнать что новая запись? Ведь в гриде мы добавляем её, и если ничего не напишем в ней то она не сохраняется, т.е. он как то узнает, что она новая, как?


 
Johnmen ©   (2004-04-22 09:18) [4]

>вставляется пустая запись,

Что говороит о безграмотно спроектированной таблице...


 
Санёк   (2004-04-22 10:33) [5]

Вот так сделано в DevExpress, но как сделать на стандартном датасете

 Result := EditState * [dceInsert, dceEdit] <> [];
 Result := Result and (Provider.FEditingRecordIndex <> cxNullEditingRecordIndex);

Result - Это типа стоит вставлять или нет


 
stud ©   (2004-04-22 11:13) [6]

with DataSet do if State in [dsInsert, dsEdit] then Post;
ты постиш любую запись даже пустую. проверяй, например по значениям ключевых полей если они пустые значит не пост а кансел


 
Соловьев ©   (2004-04-22 11:16) [7]


> сохраняется, т.е. он как то узнает, что она новая, как?

if State in [dsInsert] then


 
Санёк   (2004-04-22 12:13) [8]

Ну а как грид узнает? Он не знает же какие ключевые поля?


 
stud ©   (2004-04-22 12:20) [9]

так если ты ничего в поля не вносил значит они не изменялись. у него же вроде есть св-во модифед или что-то подобное.


 
Санёк   (2004-04-22 12:48) [10]

Во вроде работает:

 with DataSet do
   if (State = dsEdit) or
      ( (State = dsInsert) and Modified ) then Post;

Всем спасибо.



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

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

Наверх




Память: 0.48 MB
Время: 0.044 c
8-1077375996
Cerber
2004-02-21 18:06
2004.05.16
Прозрачность.


11-1069064483
Revolter
2003-11-17 13:21
2004.05.16
Помогите с прозрачностью


1-1083318130
siriusP
2004-04-30 13:42
2004.05.16
Как запретить класть на TPanel компоненты?


1-1083727727
russko
2004-05-05 07:28
2004.05.16
Многоуровневый выпадающий список


3-1082388148
Nazer
2004-04-19 19:22
2004.05.16
UDF Функции