您的位置:首页 > 编程语言 > Delphi

Delphi在C/S架构项目中考虑到SQLServer客户端断电的用户登录问题

2012-10-03 13:52 375 查看
在C/S架构项目中,往往限制同一时间一个账号只能登录一次,考虑到客户端突然断电的情况。

登录前要验证临时表是否存在,登录后要创建临时表。

// 注册已经登录的账户
function TfrmLogin.RegUserLogined(AdoConn: TADOConnection;
AUserID: string): Boolean;
var
Qry: TADOQuery;
SQLStr: string;
begin
//
try
QryCreate(Qry,AdoConn);
try
SQLStr := Format('CREATE TABLE ##XXX%s(%s INT); ', [AUserID, AUserID]);
Qry.SQL.Text := SQLStr;
Qry.ExecSQL;
finally
Qry.Free;
end;
except
Result := False;
Exit;
end;
Result := True;
end;
// 判断账户是否已经登录
function TfrmLogin.ThisUserHadLogined(AdoConn: TADOConnection;
AUserID: string): Boolean;
var
Qry: TADOQuery;
SQLStr: string;
begin
//
try
QryCreate(Qry,AdoConn);
try
SQLStr := Format('SELECT OBJECT_ID(N''tempdb..##XXX%s'', N''U'') AS TabID', [AUserID]);
Qry.SQL.Text := SQLStr;
Qry.Open;
result := not Qry.FieldByName('TabID').IsNull;
finally
Qry.Free;
end;
except
Result := False;
Exit;
end;
end;

procedure TfrmLogin.QryCreate(var aQuery: TADOQuery; Connecion: TAdoConnection);
begin
aQuery := TADOQuery.create(nil);
aQuery.Connection := Connecion;
end;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐