当前位置:七道奇文章资讯安全技术网络技术
日期:2010-09-19 00:11:00  来源:本站整理

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奉告用户说”对不起,此工号正被利用!”

 

本文引用地址: 与您的QQ/MSN好友分享!

  您对本文章有什么看法或着疑问吗?请到论坛谈论您的关注和倡议是我们前行的参考和动力      相关文章 没有相关文章


  以上是“SQL server暂时表的巧妙操纵[网络技术]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • Windows 搭配 IIS7 PHP MySQL 环境
  • sqlserver索引的原理及索引成立的注意事项小结
  • SQL Join的一些总结(实例)
  • SQL的Join利用图解教程
  • SQL中JOIN和UNION辨别、用法及示例介绍
  • 关于SQL中CTE(公用表表达式)(Common Table Expression)的总结
  • mysql Out of memory (Needed 16777224 bytes)的错误办理
  • mysql提醒[Warning] Invalid (old?) table or database name问题的办理办法
  • mysql启用skip-name-resolve情势时呈现Warning的处理办法
  • mysql启用skip-name-resolve情势时呈现Warning的处理办法
  • MySQL Order By语法介绍
  • <b>MySQL ORDER BY 的实现解析</b>
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .