您现在的位置:主页 > 数据库 > MS_SQL >

巧用SQL server临时表

来源:建站吧 责任编辑:Jzq8 发表时间:2011-12-08 点击:

  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
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
验证码:点击我更换图片

今日头条

更多>>

推荐图文

  • SQL Server 2005 安全设置教程
  • SQL Server2000连接中的常见错误
  • 剖析SQLServer查询通知之基础篇
  • SQLServer数据加密技术应用研究
  • SQL教程:SQLServer备份和灾难恢复
  • 使用publishing转移MSSQL数据
  • SQL集合函数中利用casewhenthen技巧
  • SQLServer数据挖掘中的几个问题之理解内容类型
  • 数据库置疑?几步搞定SQL数据库修复
Alexa - 客户服务 - 联系方法 - 招聘信息 - 友情链接 - 网站地图 - TAG标签 - RSS订阅
Copyright © 2010-2012 JZQ8.COM. 建站吧|建站去吧 版权所有
冀ICP备09002514号
冀ICP备09002514号 网络报警 企业法人营业执照 中国互联网协会 支付宝付款 网银在线付款