新葡 京娱乐网址:巧用SQL server的全局临时表防止用户重复登录临时表

在我们开拓商务软件的时刻,新葡京娱乐网址经常会碰到这样的一个问题:如何防止用户重复登录我们的系统?分外是对付银行或是财务部门,更是要限定用户以其工号身份多次登入。可能会有人说在用户信息表中加一字段判断用户工号登录的状态,登录后写1,退出时写0,且


当前位置: 主页 >


在我们开拓商务软件的时刻,新葡 京娱乐网址经常会碰到这样的一个问题:如何防止用户重复登录我们的系统?分外是对付银行或是财务部门,更是要限定用户以其工号身份多次登入。

可能会有人说在用户信息表中加一字段判断用户工号登录的状态,登录后写1,退出时写0,且登录时判断其标志位是否为1,如是则不让该用户工号登录。然则这样那势必会带来新的问题:如发生象断电之类弗成预知的征新葡 京娱乐网址象,系统长短正常退出,无法将标志位置为0,那么下次以该用户工号登录则弗成登入,这该怎么办呢?

或许我们可以换新葡 京娱乐网址一下思路:有什么器械是在connection断开后可以被系统自动收受接收的呢?对了,SQL Server的临时表具备这个特点!然则我们这里的这种环境不能用局部临时表,由于局部临时表对付每一个connection来说都是一个自力的工具,是以只能用全局临时表来达到我们的目的。

好了,环境已经晴明话了,我们可以写一个象下面这样简单的存储历程:

create procedure gp_findtemptable -- 2001/10/26

21:36 zhuzhichao in nanjing

/* 探求以操作员工号命名的全局临时表

* 如无则将out参数置为0并创建该表,如有则将out参数置为1

* 在connection断开连接后,全局临时表会被SQL Server自动收受接收

* 如发生断电之类的意外,全局临时表虽然还存在于tempdb中,

然则已经掉去活性

* 用object_id函数去判断时会觉得其不存在.

*/

@v_userid varchar(6), -- 操作员工号

@i_out int out -- 输出参数 0:没有登录 1:已经登录

as

declare @v_sql varchar(100)

if object_id(''''tempdb.dbo.##''''+@v_userid) is null

begin

set @v_sql = ''''create table #新葡 京娱乐网址#''''+@v_userid+

新葡 京娱乐网址9;'''(userid varchar(6))''''

exec (@v_sql)

set @i_out = 0

end

else

set @i_out = 1

在这个历程中,我们看到假如以用户工号命名的全局临时表不存在时历程会去创建一张并把out参数置为0,假如已经存在则将out参数置为1。

这样,我们在我们的利用法度榜样中调用该历程时,假如取得的out参数为1时,我们可以绝不虚心地跳出一个message奉告用户说”对不起,此工号正被应用!”

(测试情况:办事器:winnt server 4.0 SQL Server7.0 事情站:winnt workstation)

发表评论
加载中...

相关文章