SQL 查询中如何区分大小写?
最佳答案
今天做了一下数据库方面的实验操作,同时也在网上查了一些相关的论坛资料,总结一下:
一, MySQL
mysql 中先把两个相同表中其中一个表的数据插到另一个表的后面,ID相同时会提示重复:
insert into table1
select * from table2;
再对其进行满足要求的查询操作:但其中包含大小写,就是没有区分大小写,到网上一搜,用BINARY 就可以了,
select * from (
select * from table1
union all
select * from table2
) as table3
where table3.id>38 and BINARY table3.name='A';
也就是说再查询的时候mysql是不区分大小写的;而且默认定义也不区分,要区分就再字段后加BINARY
CREATE TABLE T(
A VARCHAR(10) BINARY
);
二,SQL 2000
没装2000实验过,网上资料有点,如下:
SQL查询区分大小写方法
SELECT *
FROM 表名
WHERE 字段名='test' collate Chinese_PRC_CS_AI_WS
CI 指定不区分大小写,CS 指定区分大小写。
AI 指定不区分重音,AS 指定区分重音。
Omitted 指定不区分大小写,WS 指定区分大小写。注:hibernate中不适用,具体方法正在查找中...哪位知道,麻烦告诉一下
而这个作者列举的更多:
在SQLServer中区分大小写的几种方法 http://blog.csdn.net/stdotleo/archive/2004/11/23/192262.aspx
今天碰到这个问题了,问了一下朋友,给出了以下几种解决方法,贴出来大家都看一下:
第一种:(蟋蟀)
ALTER TABLE tb
ALTER COLUMN colname nvarchar(100) COLLATE Chinese_PRC_CI_AS
--不区分大小写
ALTER TABLE tb
ALTER COLUMN colname nvarchar(100) COLLATE Chinese_PRC_CS_AS
--区分大小写
alter database 数据库 COLLATE Chinese_PRC_CS_AS
第二种:(tree)
--创建如下用户自定义函数(UDF)
CREATE FUNCTION StrComp(@Str1 VARCHAR(50),@Str2 VARCHAR(50))
--ALTER FUNCTION StrComp(@Str1 VARCHAR(50),@Str2 VARCHAR(50))
RETURNS INTEGER
AS
BEGIN
DECLARE @i INTEGER
--DECLARE @Str1 VARCHAR(50)
--DECLARE @Str2 VARCHAR(50)
DECLARE @y INT
--SET @Str1='a'
--SET @Str2='A'
SET @i=0
--SELECT ASCII(SUBSTRING(@Str1,@i+1,1))
SET @y=1
DECLARE @iLen INT
SET @iLen = LEN(LTRIM(RTRIM(@Str1)))
IF LEN(LTRIM(RTRIM(@Str1))) < LEN(LTRIM(RTRIM(@Str2))) --THEN
SET @iLen = LEN(LTRIM(RTRIM(@Str2)))
WHILE (@i < @iLen)
BEGIN
IF (ASCII(SUBSTRING(@Str1,@i+1,1))=ASCII(SUBSTRING(@Str2,@i+1,1))) --THEN
SET @i = @i +1
ELSE
BEGIN
SET @y=0
BREAK
END
END
RETURN @y
END
测试:
select *
from Table1
Where dbo.StrComp(Field1,'aAbB') =1
第三种:(Oliver)
SQL Server 数据库中的文本信息可以用大写字母、小写字母或二者的组合进行存储。例如,姓氏可以"SMITH"、"Smith"或"smith"等形式出现。
数据库是否区分大小写取决于 SQL Server 的安装方式。如果数据库区分大小写,当搜索文本数据时,必须用正确的大小写字母组合构造搜索条件。例如,如果搜索名字"Smith",则不能使用搜索条件"=smith"或"=SMITH"。
另外,如果服务器被安装成区分大小写,则必须用正确的大小写字母组合提供数据库、所有者、表和列的名称。如果提供的名称大小写不匹配,则 SQL Server 返回错误,报告"无效的对象名"。
当使用关系图窗格和网格窗格创建查询时,查询设计器始终正确地反映出服务器是否区分大小写。但是,如果在 SQL 窗格中输入查询,则必须注意使名称与服务器解释名称的方式相匹配。
如果服务器是用不区分大小写的选项安装的,则
提示 若要确定服务器是否区分大小写,请执行存储过程 sp_server_info,然后检查第 18 行的内容。如果服务器是用不区分大小写的设置安装的,则 sort_order 选项将设置为"不区分大小写"。可以从查询分析器运行存储过程。
第四种:(非云)
select * from servers where convert(varbinary, name)=convert(varbinary, N'RoCKEY')
第五种:()
ascii('a')再配合Substring()一起用
三, Oracle
默认是区分大小写的
SELECT * FROM TABLE1
WHERE NAME='XHONE';
与
SELECT * FROM TABLE1
WHERE NAME='xhone';
结果是不一样的;
要不区分大小写的话就根据下面这段资料说的做哈:
根据关键字查询书籍列表
重点看 “sKeyWords.toLowerCase()” 和“LOWER(B.BOOK_INTRODUCTION) LIKE”记得感谢我哦
sbSql
.append(" SELECT " )
.append( " B.BOOK_ID,")
.append( " B.BOOK_NAME,")
.append( " B.BOOK_INTRODUCTION,")
.append( " B.BOOK_HOST ")
.append(" FROM BOOK_INFO B ")
.append("WHERE LOWER(B.BOOK_INTRODUCTION) LIKE '%")
.append(sKeyWords.toLowerCase())
.append("%");
即为like用法的一种;
也可用lower或者upper选择一种:
SELECT * FROM TABLE1
WHERE NAME=lower('XHONE');
upper同上;
也可同时用lower或者upper;
SELECT * FROM TABLE1
WHERE upper(NAME)=upper('XHONE');
另外还有一种用字符串函数转换的方法:
oracle中实现不区分大小写的字符替换的工具函数
create or replace function StrReplace(
n_Str IN varchar2, -- 目标字符串
n_Search IN varchar2, -- 搜索的字符串
n_Replace IN varchar2) -- 替换成字串
-----------------------------------------------------------------------
-- 用 途 不区分大小写的字符替换函数。
-- 创建者 :Andrew
-----------------------------------------------------------------------
-- 修改记录列表:(按日期的先后顺序逆序排列)
-- 修改时间 修改人 实现的功能说明
-----------------------------------------------------------------------
return varchar2
is
v_Result varchar2(2000); -- 返回结果
v_Pos number; -- sSearch在sStr中的位置
v_Len number; -- sSearch的长度
begin
v_Result := n_Str;
v_Len := length(n_Search);
v_Pos := instr(Upper(v_Result), Upper(n_Search));
while v_Pos <> 0 loop
v_Result := SubStr(v_Result, 1, v_Pos-1) || n_Replace || SubStr(v_Result, v_Pos+v_Len, 2000);
v_Pos := instr(Upper(v_Result), Upper(n_Search), v_Pos+v_Len);
end loop;
return(v_Result);
end StrReplace;
一, MySQL
mysql 中先把两个相同表中其中一个表的数据插到另一个表的后面,ID相同时会提示重复:
insert into table1
select * from table2;
再对其进行满足要求的查询操作:但其中包含大小写,就是没有区分大小写,到网上一搜,用BINARY 就可以了,
select * from (
select * from table1
union all
select * from table2
) as table3
where table3.id>38 and BINARY table3.name='A';
也就是说再查询的时候mysql是不区分大小写的;而且默认定义也不区分,要区分就再字段后加BINARY
CREATE TABLE T(
A VARCHAR(10) BINARY
);
二,SQL 2000
没装2000实验过,网上资料有点,如下:
SQL查询区分大小写方法
SELECT *
FROM 表名
WHERE 字段名='test' collate Chinese_PRC_CS_AI_WS
CI 指定不区分大小写,CS 指定区分大小写。
AI 指定不区分重音,AS 指定区分重音。
Omitted 指定不区分大小写,WS 指定区分大小写。注:hibernate中不适用,具体方法正在查找中...哪位知道,麻烦告诉一下
而这个作者列举的更多:
在SQLServer中区分大小写的几种方法 http://blog.csdn.net/stdotleo/archive/2004/11/23/192262.aspx
今天碰到这个问题了,问了一下朋友,给出了以下几种解决方法,贴出来大家都看一下:
第一种:(蟋蟀)
ALTER TABLE tb
ALTER COLUMN colname nvarchar(100) COLLATE Chinese_PRC_CI_AS
--不区分大小写
ALTER TABLE tb
ALTER COLUMN colname nvarchar(100) COLLATE Chinese_PRC_CS_AS
--区分大小写
alter database 数据库 COLLATE Chinese_PRC_CS_AS
第二种:(tree)
--创建如下用户自定义函数(UDF)
CREATE FUNCTION StrComp(@Str1 VARCHAR(50),@Str2 VARCHAR(50))
--ALTER FUNCTION StrComp(@Str1 VARCHAR(50),@Str2 VARCHAR(50))
RETURNS INTEGER
AS
BEGIN
DECLARE @i INTEGER
--DECLARE @Str1 VARCHAR(50)
--DECLARE @Str2 VARCHAR(50)
DECLARE @y INT
--SET @Str1='a'
--SET @Str2='A'
SET @i=0
--SELECT ASCII(SUBSTRING(@Str1,@i+1,1))
SET @y=1
DECLARE @iLen INT
SET @iLen = LEN(LTRIM(RTRIM(@Str1)))
IF LEN(LTRIM(RTRIM(@Str1))) < LEN(LTRIM(RTRIM(@Str2))) --THEN
SET @iLen = LEN(LTRIM(RTRIM(@Str2)))
WHILE (@i < @iLen)
BEGIN
IF (ASCII(SUBSTRING(@Str1,@i+1,1))=ASCII(SUBSTRING(@Str2,@i+1,1))) --THEN
SET @i = @i +1
ELSE
BEGIN
SET @y=0
BREAK
END
END
RETURN @y
END
测试:
select *
from Table1
Where dbo.StrComp(Field1,'aAbB') =1
第三种:(Oliver)
SQL Server 数据库中的文本信息可以用大写字母、小写字母或二者的组合进行存储。例如,姓氏可以"SMITH"、"Smith"或"smith"等形式出现。
数据库是否区分大小写取决于 SQL Server 的安装方式。如果数据库区分大小写,当搜索文本数据时,必须用正确的大小写字母组合构造搜索条件。例如,如果搜索名字"Smith",则不能使用搜索条件"=smith"或"=SMITH"。
另外,如果服务器被安装成区分大小写,则必须用正确的大小写字母组合提供数据库、所有者、表和列的名称。如果提供的名称大小写不匹配,则 SQL Server 返回错误,报告"无效的对象名"。
当使用关系图窗格和网格窗格创建查询时,查询设计器始终正确地反映出服务器是否区分大小写。但是,如果在 SQL 窗格中输入查询,则必须注意使名称与服务器解释名称的方式相匹配。
如果服务器是用不区分大小写的选项安装的,则
提示 若要确定服务器是否区分大小写,请执行存储过程 sp_server_info,然后检查第 18 行的内容。如果服务器是用不区分大小写的设置安装的,则 sort_order 选项将设置为"不区分大小写"。可以从查询分析器运行存储过程。
第四种:(非云)
select * from servers where convert(varbinary, name)=convert(varbinary, N'RoCKEY')
第五种:()
ascii('a')再配合Substring()一起用
三, Oracle
默认是区分大小写的
SELECT * FROM TABLE1
WHERE NAME='XHONE';
与
SELECT * FROM TABLE1
WHERE NAME='xhone';
结果是不一样的;
要不区分大小写的话就根据下面这段资料说的做哈:
根据关键字查询书籍列表
重点看 “sKeyWords.toLowerCase()” 和“LOWER(B.BOOK_INTRODUCTION) LIKE”记得感谢我哦
sbSql
.append(" SELECT " )
.append( " B.BOOK_ID,")
.append( " B.BOOK_NAME,")
.append( " B.BOOK_INTRODUCTION,")
.append( " B.BOOK_HOST ")
.append(" FROM BOOK_INFO B ")
.append("WHERE LOWER(B.BOOK_INTRODUCTION) LIKE '%")
.append(sKeyWords.toLowerCase())
.append("%");
即为like用法的一种;
也可用lower或者upper选择一种:
SELECT * FROM TABLE1
WHERE NAME=lower('XHONE');
upper同上;
也可同时用lower或者upper;
SELECT * FROM TABLE1
WHERE upper(NAME)=upper('XHONE');
另外还有一种用字符串函数转换的方法:
oracle中实现不区分大小写的字符替换的工具函数
create or replace function StrReplace(
n_Str IN varchar2, -- 目标字符串
n_Search IN varchar2, -- 搜索的字符串
n_Replace IN varchar2) -- 替换成字串
-----------------------------------------------------------------------
-- 用 途 不区分大小写的字符替换函数。
-- 创建者 :Andrew
-----------------------------------------------------------------------
-- 修改记录列表:(按日期的先后顺序逆序排列)
-- 修改时间 修改人 实现的功能说明
-----------------------------------------------------------------------
return varchar2
is
v_Result varchar2(2000); -- 返回结果
v_Pos number; -- sSearch在sStr中的位置
v_Len number; -- sSearch的长度
begin
v_Result := n_Str;
v_Len := length(n_Search);
v_Pos := instr(Upper(v_Result), Upper(n_Search));
while v_Pos <> 0 loop
v_Result := SubStr(v_Result, 1, v_Pos-1) || n_Replace || SubStr(v_Result, v_Pos+v_Len, 2000);
v_Pos := instr(Upper(v_Result), Upper(n_Search), v_Pos+v_Len);
end loop;
return(v_Result);
end StrReplace;
回答时间:2010/10/14 23:15:35
| 回答者:Souidea
其他参考答案(0)
提交失败!请检查错误!错误信息: