美图齐众专注资阳网站设计 资阳网站制作 资阳网站建设
资阳网站建设公司服务热线:028-86922220

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

巧用SQLserver临时表

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

成都创新互联公司一直秉承“诚信做人,踏实做事”的原则,不欺瞒客户,是我们最起码的底线! 以服务为基础,以质量求生存,以技术求发展,成交一个客户多一个朋友!为您提供成都网站建设、网站建设、成都网页设计、小程序开发、成都网站开发、成都网站制作、成都软件开发、app开发定制是成都本地专业的网站建设和网站设计公司,等你一起来见证!

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

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

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

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

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

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

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


网页名称:巧用SQLserver临时表
URL分享:http://www.zsjierui.cn/article/cdssodg.html

其他资讯