我正在做一个比较复杂的查询系统,查询条件有多个,请问SQL语句中除了用'%"通配符之外,还有其他的通配符吗,因为我要用在 = 号后面的,而 '%' 是用于 Like 之后的比如:Where name = '%'   类似这样的

解决方案 »

  1.   

    =号后边没有通配符,你可以查询SQL Server联机手册。%也不是SQL,而是SQL Server的T-SQL语言,别的数据库的SQL可能采取的是更为标准的通配符,至少是SQL Server在通配符方面不标准,SQL难以移植。
      

  2.   

    很复杂的可以考虑SQL的全文检索在全文检索里面可以用 * ,它的功能就类似' %
      

  3.   

    % 包含零个或更多字符的任意字符串。 WHERE title LIKE '%computer%' 将查找处于书名任意位置的包含单词 computer 的所有书名。 
    _(下划线) 任何单个字符。 WHERE au_fname LIKE '_ean' 将查找以 ean 结尾的所有 4 个字母的名字(Dean、Sean 等)。 
    [ ] 指定范围 ([a-f]) 或集合 ([abcdef]) 中的任何单个字符。 WHERE au_lname LIKE '[C-P]arsen' 将查找以arsen 结尾且以介于 C 与 P 之间的任何单个字符开始的作者姓氏,例如,Carsen、Larsen、Karsen 等。 
    [^] 不属于指定范围 ([a-f]) 或集合 ([abcdef]) 的任何单个字符。 WHERE au_lname LIKE 'de[^l]%' 将查找以 de 开始且其后的字母不为 l 的所有作者的姓氏。 使用 ESCAPE 子句的模式匹配可搜索包含一个或多个特殊通配符的字符串。例如,customers 数据库中的 discounts 表可能存储含百分号 (%) 的折扣值。若要搜索作为字符而不是通配符的百分号,必须提供 ESCAPE 关键字和转义符。例如,一个样本数据库包含名为 comment 的列,该列含文本 30%。若要搜索在 comment 列中的任何位置包含字符串 30% 的任何行,请指定由 WHERE comment LIKE '%30!%%' ESCAPE '!' 组成的 WHERE 子句。如果不指定 ESCAPE 和转义符,SQL Server 将返回所有含字符串 30 的行。下例说明如何在 pubs 数据库 titles 表的 notes 列中搜索字符串"50% off when 100 or more copies are purchased":SELECT notes FROM titles WHERE notes LIKE '50%% off when 100 or more copies are purchased' ESCAPE '%'
      

  4.   

    % ? 还可用些sqlserver的字符串函数 如patindex等