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

本文介绍了解决SQL数据库中密码大小写敏感性的两种方法:一是通过修改表的列属性来实现整体区分或不区分大小写;二是提供了一个自定义函数逐字符比较密码大小写。

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

解决方法一:

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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值