登陆时的密码大小写判断

当密码没有加密时,数据库一般默认是大小写不区分的,这时不管你输入的是大写的还是小写的都可以登陆,刚开始用第二种方法虽然也可以解决但是是比较麻烦的.

解决方法一:

Alter TABLE 表名 
Alter COLUMN 列名 varchar(
100) COLLATE Chinese_PRC_CS_AS

解决方法二:

对登陆的密码大小写进行逐一判断

ALTER FUNCTION [dbo].[StringUpperLowerValidate]
(
@strInput VARCHAR(
128),
@strExist VARCHAR(
128
)
RETURNS BIT
AS
BEGIN
DECLARE @position   INT 
DECLARE @Result   BIT
SET @position 
= 1

WHILE @position 
<= DATALENGTH(@strExist)
    BEGIN
   IF( ASCII(SUBSTRING(@strExist, @position, 
1))= ASCII(SUBSTRING(@strInput, @position, 1)))
    BEGIN
     SET @position 
= @position + 1 
     SET @Result
=1
    END
   ELSE
    BEGIN
     SET @Result
=0
     
break
    END
    END
    
RETURN @Result

END

//不区分大小写(作用于表中存储的数据)
Alter TABLE 表名
Alter COLUMN 列名 varchar(
100) COLLATE Chinese_PRC_CI_AS

//区分大小写
Alter TABLE 表名
Alter COLUMN 列名 varchar(
100) COLLATE Chinese_PRC_CS_AS

//区分大小写(作用于表名、字段名……)
alter database 数据库 collate chinese_prc_cs_as

//不区分大小写
alter database 数据库 collate chinese_prc_ci_as
Tag标签: SQL存储过程
posted @ 2008-03-21 11:11 tatung zhang 阅读(79) 评论(2)  编辑 收藏

  回复  引用  查看    
#1楼 2008-03-21 13:21 | 阿不      
就是数据库的大小写区分问题。
但就这个case来说,你应该更多的使用Membership的功能。
  回复  引用  查看    
#2楼 [楼主]2008-03-22 10:54 | tatung zhang      
是的,用Membership可以方便许多.^-^

标题  
姓名  
主页
Email (博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      
该文被作者在 2008-04-07 14:23 编辑过
"五向定位"职业成长路线公开课(上海、南京、大连)
Google站内搜索


相关链接: