网站首页 > 网管员之家  > 数据库 > 当前主题    站内搜索    首页  上一页  下一页  尾页  页次1/1         新用户申请  老用户登录  返回首页
作者信息   主题: 如何用SQL Server临时表放置用户重复登录?[转]26720

白瑞德


发表主题: 2957
发表回复: 4616
网站暂行积分: 13487


【人类幸存者】



  发表时间: 2011-6-7 16:09:10             


SQL server临时表是经常需要用到的,下面就教您如何使用SQL server临时表解决防止用户重复登录问题,供您参考。 在我们开发商务软件的时候,常常会遇到这样的一个问题:怎样防止用户重复登录我们的系统?
浪漫烛光 www.langmanzg.com


浪漫烛光 www.langmanzg.com

特别是对于银行或是财务部门,更是要限制用户以其工号      
浪漫烛光 www.langmanzg.com


浪漫烛光 www.langmanzg.com

SQL server临时表是经常需要用到的,下面就教您如何使用SQL server临时表解决防止用户重复登录问题,供您参考。
浪漫烛光 www.langmanzg.com


浪漫烛光 www.langmanzg.com

  在我们开发商务软件的时候,常常会遇到这样的一个问题:怎样防止用户重复登录我们的系统?特别是对于银行或是财务部门,更是要限制用户以其工号身份多次登入。
浪漫烛光 www.langmanzg.com


浪漫烛光 www.langmanzg.com

  可能会有人说在用户信息表中加一字段判断用户工号登录的状态,登录后写1,退出时写0,且登录时判断其标志位是否为1,如是则不让该用户工号登录。但是这样那势必会带来新的问题:如发生象断电之类不可预知的现象,系统是非正常退出,无法将标志位置为0,那么下次以该用户工号登录则不可登入,这该怎么办呢?
浪漫烛光 www.langmanzg.com


浪漫烛光 www.langmanzg.com

  或许我们可以换一下思路:有什么东西是在connection断开后可以被系统自动回收的呢?对了,SQL Server临`Dw_IjZY:[1T'Q/时表具备这个特性!但是我们这里的这种情况不能用局部SQL server临时表,因为局部临时表对于每一个connection来说都是一个独立的对象,因此只能用全局临时表来达到我们的目的。
浪漫烛光 www.langmanzg.com


浪漫烛光 www.langmanzg.com

  好了,情况已经明朗话了,我们可以写一个象下面这样简单的存储过程:
浪漫烛光 www.langmanzg.com


浪漫烛光 www.langmanzg.com

create procedure gp_findtemptable       
浪漫烛光 www.langmanzg.com

/* 寻找以操作员工号命名的全局临时表    * 如无则将out参数置为0并创建该表,如有则将out参数置为1    * 在connection断开连接后,全局临时表会被SQL Server自动回收    * 如发生断电之类的意外,全局临时表虽然还存在于tempdb中,    但是已经失去活性    * 用object_id函数去判断时会认为其不存在.    */    
浪漫烛光 www.langmanzg.com

@v_userid varchar(6), -- 操作员工号    
浪漫烛光 www.langmanzg.com

@i_out int out -- 输出参数 0:没有登录 1:已经登录    
浪漫烛光 www.langmanzg.com

as    
浪漫烛光 www.langmanzg.com

declare @v_sql varchar(100)    
浪漫烛光 www.langmanzg.com

if object_id(''''tempdb.dbo.##''''+@v_userid) is null    
浪漫烛光 www.langmanzg.com

    begin    
浪漫烛光 www.langmanzg.com

        set @v_sql = ''''create table ##''''+@v_userid+    ''''(userid varchar(6))''''    
浪漫烛光 www.langmanzg.com

        exec (@v_sql)    
浪漫烛光 www.langmanzg.com

        set @i_out = 0   
浪漫烛光 www.langmanzg.com

    end    
浪漫烛光 www.langmanzg.com

else    
浪漫烛光 www.langmanzg.com

    set @i_out = 1      
浪漫烛光 www.langmanzg.com


浪漫烛光 www.langmanzg.com


浪漫烛光 www.langmanzg.com

    在这个过程中,我们看到如果以用户工号命名的全局临时表不存在时过程会去创建一张并把out参数置为0,如果已经存在则将out参数置为1。
浪漫烛光 www.langmanzg.com


浪漫烛光 www.langmanzg.com

  这样,我们在我们的应用程序中调用该过程时,如果取得的out参数为1时,我们可以毫不客气地跳出一个message告诉用户说”对不起,此工号正被使用!”
浪漫烛光 www.langmanzg.com


浪漫烛光 www.langmanzg.com





  每当你几乎快被困难击倒,丧失斗志的时候,你就想想背后还有无数等你倒下捅刀子的SB,就充满了力量。
新用户注册   返回首页
首页  上一页  下一页  尾页  页次1/1   转到第