巧用SQL server临时表
创始人
2024-07-14 06:30:35
0

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

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

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

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

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

  1. create procedure gp_findtemptable   
  2.  
  3. /* 寻找以操作员工号命名的全局临时表  
  4. * 如无则将out参数置为0并创建该表,如有则将out参数置为1  
  5. * 在connection断开连接后,全局临时表会被SQL Server自动回收  
  6. * 如发生断电之类的意外,全局临时表虽然还存在于tempdb中,  
  7. 但是已经失去活性  
  8. * 用object_id函数去判断时会认为其不存在.  
  9. */  
  10. @v_userid varchar(6), -- 操作员工号  
  11. @i_out int out -- 输出参数 0:没有登录 1:已经登录  
  12. as  
  13. declare @v_sql varchar(100)  
  14. if object_id(''''tempdb.dbo.##''''+@v_userid) is null  
  15. begin  
  16. set @v_sql = ''''create table ##''''+@v_userid+  
  17. ''''(userid varchar(6))''''  
  18. exec (@v_sql)  
  19. set @i_out = 0 
  20. end  
  21. else  
  22. set @i_out = 1   

 

 

 

 

 

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

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

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...