利用SQL Server的全局临时表防止用户重复登录

原创 2001年11月07日 13:11:00

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

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

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

        好了,情况已经明朗话了,我们可以写一个象下面这样简单的存储过程:

 <?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

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+'(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)

SQL全局临时表防止用户重复登录

为了防止用户的重复登录,在一开始想到的一种方法: 在用户表中添加一个字段,登录后写1,退出后写0.这样子在用户登录进行检查的时候判断这个字段是否为0,如果是0那么就可以登录;但是这样子就又带来了新的问...
  • lypf19900912
  • lypf19900912
  • 2013年06月28日 09:41
  • 3039

利用SQL Server的全局临时表防止用户重复登录(或者全局临时表的使用和生命周期)

  在我们开发商务软件的时候,常常会遇到这样的一个问题:怎样防止用户重复登录我们的系统?特别是对于银行或是财务部门,更是要限制用户以其工号身份多次登入。   可能会有人说在用户信息表中加一字段判断用户...
  • wangzh2008
  • wangzh2008
  • 2005年09月28日 12:02
  • 3017

利用SQL Server的全局临时表防止用户重复登录

在我们开发商务软件的时候,常常会遇到这样的一个问题:怎样防止用户重复登录我们的系统?特别是对于银行或是财务部门,更是要限制用户以其工号身份多次登入。        可能会有人说在用户信息表中加一字段判...
  • cngkqy
  • cngkqy
  • 2007年09月27日 16:43
  • 575

利用sql server的全局临时表防止用户重复登录

在我们开发商务软件的时候,常常会遇到这样的一个问题:怎样防止用户重复登录我们的系统?特别是对于银行或是财务部门,更是要限制用户以其工号身份多次登入。 可能会有人说在用户信息表中加一字段判断用户工号登录...
  • CherryPeng
  • CherryPeng
  • 2010年09月17日 17:09
  • 539

利用SQL的全局临时表防止用户重复登录

在我们开发商务软件的时候,常常会遇到这样的一个问题:怎样防止用户重复登录我们的系统?特别是对于银行或是财务部门,更是要限制用户以其工号身份多次登入。    可能会有人说在用户信息表中加一字段判断用户工...
  • qiang218
  • qiang218
  • 2007年05月17日 09:40
  • 390

sql server中的用户临时表和全局临时表的区别

临时表分为: 本地临时表,仅限于当前访问者访问,创建方法去如下: create table #TableName(表结构) 储存于数据库tempdb内(硬盘),当前用户断开连接,自动删除 如果...
  • fyifei0558
  • fyifei0558
  • 2012年08月06日 10:02
  • 1311

Sqlserver 中临时表和全局临时表

SQL Server 支持临时表。临时表就是那些名称以井号 (#) 开头的表。如果当用户断开连接时没有除去临时表,SQL Server 将自动除去临时表。临时表不存储在当前数据库内,而是存储在系统数据...
  • hank5658
  • hank5658
  • 2010年04月29日 18:33
  • 11445

利用SQLServer的全局临时表防止用户重复登录

  • zgqtxwd
  • zgqtxwd
  • 2008年04月26日 13:08
  • 137

利用SQLServer的全局临时表防止用户重复登录

利用SQLServer的全局临时表防止用户重复登录 http://other.mblogger.cn/axislover/posts/151898.aspx 在我们开发商务软件的时候,常常会遇到这样的...
  • wuhuif
  • wuhuif
  • 2007年01月08日 13:30
  • 785

利用的全局临时表防止用户重复登录

  • zgqtxwd
  • zgqtxwd
  • 2008年04月27日 23:27
  • 174
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:利用SQL Server的全局临时表防止用户重复登录
举报原因:
原因补充:

(最多只允许输入30个字)