oracle和sqlserver的大小写,关于oracle和SQLServer大小写的处理方法.doc

关于oracle和SQLServer大小写的处理方法.doc

Sqlserver 大小写不区分的处理从数据库Collate到存储过程到函数,各种方法都有,选择适合你的。第一种ALTER TABLE tbALTER COLUMN colname nvarchar100 COLLATE Chinese_PRC_CI_AS不区分大小写ALTER TABLE tbALTER COLUMN colname nvarchar100 COLLATE Chinese_PRC_CS_AS区分大小写alter database 数据库 COLLATE Chinese_PRC_CS_AS 第二种创建如下用户自定义函数UDFCREATE FUNCTION StrCompStr1 VARCHAR50,Str2 VARCHAR50ALTER FUNCTION StrCompStr1 VARCHAR50,Str2 VARCHAR50RETURNS INTEGERASBEGINDECLARE i INTEGERDECLARE Str1 VARCHAR50DECLARE Str2 VARCHAR50DECLARE y INTSET Str1aSET Str2ASET i0SELECT ASCIISUBSTRINGStr1,i1,1SET y1DECLARE iLen INTSET iLen LENLTRIMRTRIMStr1IF LENLTRIMRTRIMStr1 LENLTRIMRTRIMStr2 THENSET iLen LENLTRIMRTRIMStr2WHILE i iLenBEGINIF ASCIISUBSTRINGStr1,i1,1ASCIISUBSTRINGStr2,i1,1 THENSET i i 1ELSEBEGINSET y0BREAKENDENDRETURN yEND测试select *from Table1Where dbo.StrCompField1,aAbB 1 第三种SQL Server 数据库中的文本信息可以用大写字母、小写字母或二者的组合进行存储。例如,姓氏可SMITH、Smith或smith等形式出现。 数据库是否区分大小写取决于 SQL Server 的安装方式。如果数据库区分大小写,当搜索文本数据时,必须用正确的大小写字母组合构造搜索条件。例如,如果搜索名字Smith,则不能使用搜索条件smith或SMITH。另外,如果服务器被安装成区分大小写,则必须用正确的大小写字母组合提供数据库、所有者、表和列的名称。如果提供的名称大小写不匹配,则 SQL Server 返回错误,报告无效的对象名。当使用关系图窗格和网格窗格创建查询时,查询设计器始终正确地反映出服务器是否区分大小写。但是,如果在 SQL 窗格中输入查询,则必须注意使名称与服务器解释名称的方式相匹配。如果服务器是用不区分大小写的选项安装的,则提示若要确定服务器是否区分大小写,请执行存储过程 sp_server_info,然后检查第18 行的内容。如果服务器是用不区分大小写的设置安装的,则 sort_order 选项将设置为不区分大小写。可以从查询分析器运行存储过程。第四种select * from servers where convertvarbinary, nameconvertvarbinary, NRoCKEY第五种如asciia再配合Substring一起用。Oracle 大小写区分的处理白天学习了一下 SQL Server 的大小写处理的情况。SQL Server 中大小写区分的处理。晚上学习学习 Oracle 的大小写处理的情况。还真是彻底不一样啊 查询数据的时候。SQL Server 默认 不区分大小写。 如果要区分,就要额外的设置。Oracle 默认 区分大小写。如果不要区分,就要额外的设置。 下面就是 Oracle 的明细部分了。 首先是测试表/数据SQL CREATE TABLE tab 2 id INT, 3 val VARCHAR210 4 ; 表已创建。 SQL INSERT INTO tab 2 SELECT 1, ABC123 FROM DUAL UNION ALL 3 SELECT 2, abc234 FROM DUALUNION ALL 4 SELECT 3, Abc345 FROM DUAL UNION ALL 5 SELECT 4, aBC456 FROM DUALUNION ALL 6 SELECT 5, aBc567 FROM DUAL; 已创建5行。 操作的例子SQL SELECT 2 * 3 FROM 4 tab 5 WHERE 6 val abc123 SELECT 2 * 3 FROM 4 tab 5 WHERE 6 val ABC123 ALTER SESSION SET NLS_COMPANSI; 会话已更改。 SQL ALTER SESSION SET NLS_SORTbinary_ci; 会话已更改。 SQL SELECT 2 * 3 FROM 4 tab 5 WHERE 6 val abc123 SELECT 2 * 3 FROM 4 tab 5 WHERE 6 val LIKE a ALTER SESSION SET NLS_COMPANSI; 会话已更改。 SQL ALTER SESSION SET NLS_SORTbinary_ci; 会话已更改。 会话更改以后,条件是 val 的,可以实现大小写不敏感但是对于 val LIKE 的查询,还是大小写敏感的。 解决办法,使用正则表达式的方式来变通的处理。 SQL SELECT 2 * 3 FROM 4 tab 5 WHERE 6 REGEXP_LIKE val, a, i; ID VAL 1 ABC123 2 abc234 3 Abc345 4 aBC456 5 aBc567 注1REGEXP_LIKE 的第3个参数i 表示大小写敏感。注2对于环境变量NLS_COMP 与NLS_SORT的设置,会影响REGEXP_LIKE 执行的结果(假如第3个参数不填写的话)。 默认情况下SQL SELECT 2 * 3 FROM 4 tab 5 WHERE 6 REGEXP_LIKE val, a; ID VAL 2 abc234 4 aBC456 5 aBc567 ALTER SESSION SET 之后 SQL SELECT 2 * 3 FROM 4 tab 5 WHERE 6 REGEXP_LIKE val, a; ID VAL 1 ABC123 2 abc234 3 Abc345 4 aBC456 5 aBc567排序的例子SQL SELECT 2 * 3 FROM 4 Tab 5 ORDER BY 6 val; ID VAL - 1 ABC123 3 Abc345 4 aBC456 5 aBc567 2 abc234 默认排序为大小写敏感 SQL ALTER SESSION SET NLS_COMPANSI; 会话已更改。 SQL ALTER SESSION SET NLS_SORTbinary_ci; 会话已更改。 SQL SELECT 2 * 3 FROM 4 Tab 5 ORDER BY 6 val; ID VAL 1 ABC123 2 abc234 3 Abc345 4 aBC456 5 aBc567 关于中文汉字的排序SQL TRUNCATE TABLE Tab; 表被截断。 SQL SQL INSERT INTO tab 2 SELECT 1, 一 FROM DUAL UNION ALL 3 SELECT 2, 二 FROM DUAL UNION ALL 4 SELECT 3, 三 FROM DUAL UNION ALL 5 SELECT 4, 四 FROM DUAL UNION ALL 6 SELECT 5, 五 FROM DUAL;已创建5行。 SQL commit; 提交完成。 按照拼音来排序SQL SELECT 2 * 3 FROM 4 Tab 5 ORDER BY NLSSORTval, NLS_SORTSCHINESE_PINYIN_M; ID VAL 2 二 3 三 4 四 5 五 1 一 按照笔画数来排序SQL SELECT 2 * 3 FROM 4 Tab 5 ORDER BY NLSSORTval, NLS_SORTSCHINESE_STROKE_M; ID VAL 1 一 2 二 3 三 5 五 4 四 按照偏旁部首来排序 SQL INSERT INTO tab 2 SELECT 6, 人 FROM DUAL UNION ALL 3 SELECT 7, 十 FROM DUAL UNION ALL 4 SELECT 8, 土 FROM DUAL UNION ALL 5 SELECT 9, 士 FROM DUAL; 已创建4行。 SQL commit; 提交完成。 SQL SELECT 2 * 3 FROM 4 Tab 5 ORDER BY NLSSORTval, NLS_SORTSCHINESE_RADICAL_M; ID VAL 1 一 2 二 3 三 5 五 6 人 7 十 4 四 8 土 9 士 已选择9行。 Oracle

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值