SQL中代替Like语句的另一种写法

王朝mssql·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

比如查找用户名包含有"c"的所有用户, 可以用

use mydatabase

select * from table1 where username like'%c%"

下面是完成上面功能的另一种写法:

use mydatabase

select * from table1 where charindex('c',username)gt;0

这种方法理论上比上一种方法多了一个判断语句,即gt;0, 但这个判断过程是最快的, 我想信80%以上的运算都是花在查找字符串及其它的运算上, 所以运用charindex函数也没什么大不了. 用这种方法也有好处, 那就是对%,|等在不能直接用like查找到的字符中可以直接在这charindex中运用, 如下:

use mydatabase

select * from table1 where charindex('%',username)gt;0

也可以写成:

use mydatabase

select * from table1 where charindex(char(37),username)gt;0

ASCII的字符即为%

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航