SQL CHARINDEX函数返回字符或者字符串在另一个字符串中的起始位置。CHARINDEX函数调用方法如下:
CHARINDEX ( expression1 , expression2 [ , start_location ] )
Expression1是要到expression2中寻找的字符中,start_location是CHARINDEX函数开始在expression2中找expression1的位置。
SQL CHARINDEX函数返回一个整数,返回的整数是要找的字符串在被找的字符串中的位置。假如SQL CHARINDEX函数没有找到要找的字符串,那么函数整数“0”。让我们看看下面的函数命令执行的结果:
CHARINDEX('SQL', 'Microsoft SQL Server')
这个函数命令将返回在“Microsoft SQL Server”中“SQL”的起始位置,在这个例子中,CHARINDEX函数将返回“S”在“Microsoft SQL Server”中的位置11。
接下来,我们看这个CHARINDEX命令:
CHARINDEX('7.0', 'Microsoft SQL Server 2000')
在这个例子中,CHARINDEX返回零,因为字符串“7.0” 不能在“Microsoft SQL Server”中被找到,retrue0;
public static bool IsSafeKeyWord(string name)//name前台注册的用户名
{
string sql = "select COUNT(*) from 数据表 where CHARINDEX(‘非法字词的字段或字词如,日麻痹等’,'" + name.ToSafeSql() + "')>0";
object obj = OrmRainbow.Gateway.Default.ExecuteScalar(sql);
if (obj != null)
{
return Convert.ToInt32(obj)>0?false:true;
}
else
return false;
}