zoukankan      html  css  js  c++  java
  • 全局临时表的应用 Timothy

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

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

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

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

    create procedure gp_findtemptable 

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

     * 如无则将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告诉用户说对不起,此工号正被使用!

    转自中国站长下载...

  • 相关阅读:
    与WinRT组件进行操作
    clr via c# 运行时序列化
    clr via c# 程序集加载和反射(2)
    clr via c# 程序集加载和反射集(一)
    clr via c# clr寄宿和AppDomain (一)
    cir from c# 托管堆和垃圾回收
    浏览器页面的生命周期
    C#常用泛型集合
    Params修饰符
    ASP.net应用程序的生命周期
  • 原文地址:https://www.cnblogs.com/haiyang1985/p/1395054.html
Copyright © 2011-2022 走看看