Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Conexión con bases de datos (https://www.clubdelphi.com/foros/forumdisplay.php?f=2)
-   -   Integridad sobre un campo que puede ser NULL (https://www.clubdelphi.com/foros/showthread.php?t=18270)

gluglu 07-02-2005 19:47:58

Integridad sobre un campo que puede ser NULL
 
Hola Amigos,

Como puedo asegurar que al insertar un nuevo registro en un DBGrid, el campo clave no esté duplicado pero permitiendo NULL.

Me explico un poco más, el campo clave permite tanto valores NULL como cualquier otro valor. Ahora eso sí, cuando sea diferente de NULL, quiero que sea único.

En la definición de la tabla no puedo usar ni PRIMARY KEY, ni tampoco UNIQUE ya que ambas me exigen la condición de NOT NULL.

Adicionalmente me encuentro con que al insertar un registro en el DBGrid, hasta que no pido al usuario el código clave (y este pulsa Intro), no puedo comprobar si esta ya existe. Y si busco en la tabla algún registro (después de haber pulsado Intro) con esa clave, me encuentra el propio registro que me encuentro editando en ese momento en el DBGrid, incluso aunque todavía no haya realizado un POST.

Un saludo a todos !

gluglu 08-02-2005 12:11:45

Código Delphi [-]
procedure TNombre.IBQueryCAMPOValidate(Sender: TField);
var
  Txt : AsString
begin
  IBQueryCheck.SQL.Clear;
  IBQueryCheck.SQL.Add('Select * from TABLA');
  IBQueryCheck.SQL.Add('where CAMPO = :Txt');
  IBQueryCheck.ParamByName('Txt1').AsString := IBQueryCAMPO.Value;
  IBQueryCheck.Prepare;
  IBQueryCheck.Open;
  If not IBQueryCheck.Eof then begin
    ShowMessage('Ya existe un registro con ese Clave');
    abort;
  end;

end;


La franja horaria es GMT +2. Ahora son las 11:11:07.

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi