select * from stYNPYCD WHERE  YNPYCD='AJ'
结果:
AJ 1/3.8
Aj 1/4.6
aJ 2/3.8能不能只显示AJ的值!

解决方案 »

  1.   

    sqlserver  可以设置区分大小写
      

  2.   

    --sql2000,就用下面的方法.
    --就是在字段名后加 collate Chinese_PRC_CS_AS_WS 
    --区分大小写、全半角字符的方法--测试数据
    create table 表(fd varchar(10))
    insert into 表
    select aa='aa'
    union all select 'Aa'
    union all select 'AA'   --全角A
    union all select 'A,A'  --全角A,半角,
    union all select 'A,A' --全角A,全角,
    go--查询
    --1.查大写字母
    select * from 表
    where fd collate Chinese_PRC_CS_AS_WS like '%A%'  
    --就是在字段名后加 collate Chinese_PRC_CS_AS_WS --2.查全角
    select * from 表
    where fd collate Chinese_PRC_CS_AS_WS like '%A%'--3.查半角
    select * from 表
    where fd collate Chinese_PRC_CS_AS_WS like '%,%'
    go--删除测试数据
    drop table 表/*--测试结果1.查询大写字母的结果
    fd         
    ---------- 
    Aa
    2.查询全角字符的结果
    fd         
    ---------- 
    AA
    A,A
    A,A
    3.查询半角字符的结果
    fd         
    ---------- 
    A,A(所影响的行数为 1 行)
    --*/
    ================================================================--sql7.0,就用下面的方法.--如果是全部比较
    --下面是测试
    select * from(
    select fd='a'
    union all select 'A'
    ) a
    where cast(fd as varbinary(8000))=cast('A' as varbinary(8000))/*--测试结果
    fd   
    ---- 
    A(所影响的行数为 1 行)
    --*/--如果是部分匹配,就用charindex:--下面是测试
    select * from(
    select fd='a'
    union all select 'A'
    union all select 'aAaa'
    union all select 'aaaa'
    union all select 'cccA'
    ) a
    where charindex(cast('A' as varbinary(8000)),cast(fd as varbinary(8000)))>0/*--测试结果
    fd   
    ---- 
    A
    aAaa
    cccA(所影响的行数为 3 行)
    --*/