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

Вниз

Null   Найти похожие ветки 

 
Zlod3y   (2004-07-16 10:50) [0]

В числовое поле при использовании метода Insert в таблицу сразу записывается 0! Мне не нужен этот ноль, нужно пустое поле.....и я поступаю сл. образом:

with DataModule1.Table1 do begin
.....
FieldValues["Field_name"]:=null;
.....
Post;     //<-здесь возникает искличительная ситуация
end;


Конечно я обрабатываю такую искличительную ситуацию оч. просто:

with DataModule1.Table1 do begin
.....
FieldValues["Field_name"]:=null;
.....
try
Post;    //<-здесь возникает искличительная ситуация
except
//здесь пусто
end;
refresh;
end;


Refresh делаю потому-что после Post таблица переводится в режим dsEdit...

Как мне избежать этой исключительной ситуации?


 
Ega23 ©   (2004-07-16 10:57) [1]

Default на это поле NULL поставь.


 
Anatoly Podgoretsky ©   (2004-07-16 11:05) [2]

Эту строчку убрать из кода программы
FieldValues["Field_name"]:=null;


 
Zlod3y   (2004-07-16 11:22) [3]


> Anatoly Podgoretsky ©   (16.07.04 11:05) [2]
> Эту строчку убрать из кода программы
> FieldValues["Field_name"]:=null;

Тогда в поле запишется "0"


 
Соловьев ©   (2004-07-16 12:26) [4]


> Мне не нужен этот ноль, нужно пустое поле.....

FieldByName("field").Clear;


 
Reindeer Moss Eater ©   (2004-07-16 12:28) [5]

> FieldValues["Field_name"]:=null;

FieldValues - это Variant
Вариант со значением null для числового поля это ноль.
Все по-честному.


 
Viktor1   (2004-07-16 12:37) [6]

Возможно стоит по умолчанию 0 в Accesse.
Открой таблицу в самом Accessе. Там внизу есть "Значение по умолчанию", так оно при созданиии цислового поля сразу стовится 0.


 
Reindeer Moss Eater ©   (2004-07-16 12:39) [7]

Значение по умолчанию вставится в поле если из приложения придет запрос на апдейт записи в котором поле это не упомянуто вообще.
В противном случае никакой defaul туда не попадет.


 
Reindeer Moss Eater ©   (2004-07-16 12:40) [8]

на инсерт конечно же, а не на апдейт.


 
Viktor1   (2004-07-16 13:20) [9]

При следющем открытии поле где по умолчанию 0 , в Gride будет забито нулями.


 
Reindeer Moss Eater ©   (2004-07-16 13:24) [10]

Ну и при чем здесь какой-то грид?
И тем более какой-то символ отображаемый в этом гриде и к физическому полю таблицы имеющий весьма отдаленное отношение?

У человека есть явное присвоение значения полю датасета.
Никакое DEFAULT значение в это поле ни в одном движке никогда не попадет.

Хоть десять гридов позови на помошь.


 
D.J.Star   (2004-07-16 18:33) [11]


> В числовое поле при использовании метода Insert в таблицу
> сразу записывается 0! Мне не нужен этот ноль, нужно пустое
> поле.....и я поступаю сл. образом:
>
> with DataModule1.Table1 do begin
> .....
> FieldValues["Field_name"]:=null;
> .....
> Post;     //<-здесь возникает искличительная ситуация
> end;
>
>
> Конечно я обрабатываю такую искличительную ситуацию оч.
> просто:
>
> with DataModule1.Table1 do begin
> .....
> FieldValues["Field_name"]:=null;
> .....
> try
> Post;    //<-здесь возникает искличительная ситуация
> except
> //здесь пусто
> end;
> refresh;
> end;
>
>
> Refresh делаю потому-что после Post таблица переводится
> в режим dsEdit...
>
> Как мне избежать этой исключительной ситуации?

Ну вы чё, братва!!! Null это "0", а пустое значение - это "nil"!
Во всяком случае нужно преереструктуизировать таблицу и отменить обязательное присвоение значение полю.


 
Reindeer Moss Eater ©   (2004-07-16 18:40) [12]

Ну вы чё, братва!!! Null это "0", а пустое значение - это "nil"!
Братва тут перетерла и порешила что null это вариант, а nil это Pointer.


 
Zlod3y   (2004-07-17 09:14) [13]

Всё братва.....спасибки всем :-)....всё-таки решил ничего не делать и оставить всё как было

ЗЫ. D.J.Star ты не прав. nil - это указатель на пустоту, а null - это даже не ноль :^)

ЗЫ2. а вариант в котором мне значение по умолчанию для поля пришлось отвергнуть, подробности "почему?" мне лень описывать.



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

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

Наверх




Память: 0.49 MB
Время: 0.054 c
1-1091052611
НовиЧок
2004-07-29 02:10
2004.08.15
Всё тот-же манифест XP


3-1090388844
RavenD
2004-07-21 09:47
2004.08.15
Блокирует ли FireBird записи?


6-1087452695
anton.
2004-06-17 10:11
2004.08.15
Как создать TCPServer в Runtime?


6-1084746834
w666w
2004-05-17 02:33
2004.08.15
ПОМОГИТЕ!!! как прикрутить к IEParser у события WebBrowser а


11-1078768582
Валерий
2004-03-08 20:56
2004.08.15
как менять хинт в Delphi в зависимости от цвета