[转]登陆时的密码大小写判断

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

解决方法一:

AlterTABLE表名
AlterCOLUMN列名varchar(
100 )COLLATEChinese_PRC_CS_AS

解决方法二:

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

ALTERFUNCTION[dbo].[StringUpperLowerValidate]
(
@strInputVARCHAR(
128 ),
@strExistVARCHAR(
128 )
)
RETURNSBIT
AS
BEGIN
DECLARE@positionINT
DECLARE@ResultBIT
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

// 不区分大小写(作用于表中存储的数据)
AlterTABLE表名
AlterCOLUMN列名varchar(
100 )COLLATEChinese_PRC_CI_AS

// 区分大小写
AlterTABLE表名
AlterCOLUMN列名varchar(
100 )COLLATEChinese_PRC_CS_AS

// 区分大小写(作用于表名、字段名……)
alterdatabase数据库collatechinese_prc_cs_as

// 不区分大小写
alterdatabase数据库collatechinese_prc_ci_as

你可能感兴趣的:(大小写)