select * from tablename whete colname='!%_'

解决方案 »

  1.   

    搜索通配符字符
    可以搜索通配符字符。有两种方法可指定平常用作通配符的字符: 使用 ESCAPE 关键字定义转义符。在模式中,当转义符置于通配符之前时,该通配符就解释为普通字符。例如,要搜索在任意位置包含字符串 5% 的字符串,请使用: 
    WHERE ColumnA LIKE '%5/%%' ESCAPE '/'在上述 LIKE 子句中,前导和结尾百分号 (%) 解释为通配符,而斜杠 (/) 之后的百分号解释为字符 %。在方括号 ([ ]) 中只包含通配符本身。要搜索破折号 (-) 而不是用它指定搜索范围,请将破折号指定为方括号内的第一个字符: 
    WHERE ColumnA LIKE '9[-]5'下表显示了括在方括号内的通配符的用法。符号 含义 
    LIKE '5[%]' 5% 
    LIKE '5%' 5 后跟 0 个或更多字符的字符串 
    LIKE '[_]n' _n 
    LIKE '_n' an, in, on (and so on) 
    LIKE '[a-cdf]' a, b, c, d, or f 
    LIKE '[-acdf]' -, a, c, d, or f 
    LIKE '[ [ ]' [ 
    LIKE ']' ] 
    如果使用 LIKE 进行字符串比较,模式字符串中的包括起始空格和/或尾随空格在内的所有字符都有意义。如果查询比较要求返回包含"abc "(abc 后有一个空格)的所有行,则不会返回列值为"abc"(abc 后没有空格)行。但是反过来,情况并非如此。可以忽略模式所要匹配的表达式中的末尾空格。如果查询比较要求返回包含"abc"(abc 后没有空格)的所有行,则将返回以"abc"开始且具有零个或多个末尾空格的所有行。
      

  2.   

    [ ] 指定范围 ([a-f]) 或集合 ([abcdef]) 中的任何单个字符。 WHERE au_lname LIKE '[C-P]arsen' 将查找以arsen 结尾且以介于 C 与 P 之间的任何单个字符开始的作者姓氏,例如,Carsen、Larsen、Karsen 等。 
      

  3.   

    like '%[!][%][_]%'
    或者
    like '%/!/%/_%' ESCAPE '/'
      

  4.   

    象这样:like '5[%]'
    like '5[!]'
    .....也就是给通配符加上方括号就行了