收藏本站 
广告服务 
网站地图 
>> 我们从网络和杂志上收集了近100000余篇各类电脑技术、网络技术、软件技术等方面的文章教程,我们的收录原则:不是精华拒不收录!
先飞电脑技术网技术文章
网络编程 | 网站建设 | 网络技术 | 设计教程 | 软件教学 | 程序开发 | 数据库开发 | 教育认证 | 硬件维护 | 媒体动画 | 机械电子 |
巧用SQL的全局临时表防止用户重复登录
[ 作者:佚名    转贴自:网络转载    阅读次数:86    更新时间:2007-8-2 14:06:00   录入:刘光勇 ]         
    在我们开发商务软件的时候,常常会遇到这样的一个问题:怎样防止用户重复登录我们的系统?特别是对于银行或是财务部门,更是要限制用户以其工号身份多次登入。

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

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

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

create procedure gp_findtemptable -- 2001/10/26 
21:36 zhuzhichao in nanjing

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

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

(测试环境:服务器:winnt server 4.0 SQL Server7.0 工作站:winnt workstation)

上一篇:解析SQL Server与ASP互操作的时间处理    下一篇:查询分析器不能单步调试的的原因
本类热门文章
·安装SQL Server2K可能引发一个严重问题[95]·巧用SQL的全局临时表防止用户重复登录[86]
·使用SQL Server时最容易忽略的21个问题[98]·如何使用SQL Server中的客户端配置工具[64]
·解析Microsoft Sql Server中的like语句[96]·从SQL Server2000升级到2005的过程解析[56]
·怎样对SQL 数据表和数据库进行迭代操作[75]·SQL应避免使用哪种格式的存储图象文件[65]
·如何运用MSSQL sp自制未公开的加密函数[95]·轻松掌握设计 Sql Server触发器的原理[82]
网站主页 | 收藏本页 | 联系我们 | 广告服务 | 站点地图 | 会员注册 | 招聘信息 | 内容指正

联系QQ:先飞电脑技术网站事务联系QQ,点击可以直接留言. 32933427 电话:13710542091 [世界排名] 鄂ICP备05005890号