PDA

Ver la Versión Completa : error al llamar a una funcion del datamodule


Lettar
07-08-2020, 11:29:18
hola, necesito hacer una validacion simple de usuario y contraseña y para eso cree una funcion en el datamodule y ocupe un query para revisar si existia un usuario con ese nombre y contraseña
function TDataModule3.VerificarInicioSesion(Usuario, contraseña: string):boolean;
Var
Vusuario,Vpassword:string;
begin
//Verificacion de usuario
Vusuario:=#39+usuario+#39;
Vpassword:=#39+contraseña+#39;
Qingreso.close;
Qingreso.SQL.Clear;
with Qingreso do
begin
SQL.add('select usuario,contraseña');
SQL.add('from usuario');
SQL.add('where usuario = :usuario');
SQL.add('and contraseña = :contraseña');
prepare;
parambyname('usuario').AsString:= VUsuario;
parambyname('contraseña').AsString:= Vpassword;
open;
end;
result :=Qingreso.IsEmpty;

end;

y luego la llame de la unidad1 verificando si los edits no estaban vacios
//Confirmar que estén los campos llenos
if (Eusuarioingr.text <>'') and (contraseñaedit.Text <> '') then
begin
//revisar si existe el usuario
if unit3.DataModule3.VerificarInicioSesion(Eusuarioingr.Text,contraseñaedit.Text) then
begin
LIS.Visible:=false;

end;
end;
pero al ejecutarlo me sale 'access violation at address 00d84af5 in module proyect1.exe ' el error ocurre cuando llamo a la función, ni siquiera entra a ejecutarla alguien me dice como puedo solucionarlo o ideas sobre lo que estoy haciendo mal?

kuan-yiu
07-08-2020, 11:57:48
Un 'acces violation' suele deberse a que intentas acceder a algo que no existe, bien porque aún no ha sido creado o no está inicializado o lo has liberado antes de tiempo.

Neftali [Germán.Estévez]
07-08-2020, 12:43:28
Hay 2 formas de crear Formularios/Datamodules en los proyectos de delphi.

O se crean automáticamente al inicio y se mantienen en memoria o los creas y los destruyes cuando necesites. Cada sistema tiene sus ventajas y sus inconvenientes.

Revisa las opciones de tu proyecto. Eso te puede dar una pista de los que se están creando solos y los que no.

https://i.postimg.cc/T3j2gCWR/Autocreate.png

Y ese Datamodule3 no está en la lista y no lo estás creando tú ahí está el problema.

También puedes:
1) Poner un Breakpoint en esa línea.
2) Ejecutar el programa paso a paso
3) Cuando el programa se detenga, ver el contenido de DataModule3 (si no está asignado estará a nil).

ElKurgan
07-08-2020, 13:26:18
Además de lo que te han contestado los compañeros, es muy común que se haya creado primero el formulario antes que el datamodule. Por defecto, Delphi lo hace así. Por tanto, si tu formulario al crearse intenta validar el usuario, no funcionará.

Pero como dice Germán, si vas a las opciones del proyecto y seleccionas el datamodule y lo arrastras para que sea el primero en crearse, puede que ya no aparezca el error

No se si van por ahí los tiros

Un saludo

Lettar
07-08-2020, 19:39:55
revise que el datamodule se creara primero y asi es, vi donde especificamente daba el error y es en el open; cuando se ejecuta el query, le saque los parametros y concatene, cambien el open por un execsql aunque se que ese se una para insert y aun asi me sale el mismo error

Lettar
08-08-2020, 02:49:11
al final puse un query en el form1 y la conecte al datamodule e hice la función de ahí y me funciono bien, pero gracias igual a los que contestaron