博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
《卸甲笔记》-PostgreSQL和Oracle的SQL差异分析之五:函数的差异(四)
阅读量:6819 次
发布时间:2019-06-26

本文共 3012 字,大约阅读时间需要 10 分钟。

PostgreSQL是世界上功能最强大的开源数据库,在国内得到了越来越多机构和开发者的青睐和应用。随着PostgreSQL的应用越来越广泛,Oracle向PostgreSQL数据库的数据迁移需求也越来越多。数据库之间数据迁移的时候,首先是迁移数据,然后就是SQL、存储过程、序列等程序中不同的数据库中数据的使用方式的转换。下面根据自己的理解和测试,写了一些SQL以及数据库对象转换方面的文章,不足之处,尚请多多指教。

1、NLSSORT

Oracle的NLSSORT可以改变取得字段的排序方式。默认的情况下,西文的排序是按照二进制编码的顺序排序。对于汉字按照拼音来排序。可以使用NLSSORT来改变字段的默认排序方式,从而取得不同的顺序。

以中文为例,排序可以有:
按照部首(第一顺序)、笔划(第二顺序)排序(SCHINESE_RADICAL_M)
按照笔划(第一顺序)、部首(第二顺序)排序(SCHINESE_STROKE_M)
按照拼音排序(SCHINESE_PINYIN_M)
等三种。默认是按照拼音来排序。
不使用参数的时候,自动采用Session内的默认值。

PostgreSQL中,对于西文按照二进制,对于汉字只是按照拼音来排序。同一种编码,其余的排序方式尚不支持。

Oracle NLSSORT

SQL> select * from test;NAME---------------横看成岭侧成峰远近高低各不同不识庐山真面目只缘身在此山中SQL> select * from test order by name;NAME---------------不识庐山真面目横看成岭侧成峰远近高低各不同只缘身在此山中SQL> select * from test order by nlssort(name);NAME---------------不识庐山真面目横看成岭侧成峰远近高低各不同只缘身在此山中SQL> select * from test order by nlssort(name, 'NLS_SORT=SCHINESE_STROKE_M');NAME---------------不识庐山真面目只缘身在此山中远近高低各不同横看成岭侧成峰SQL> select * from test order by nlssort(name, 'NLS_SORT=SCHINESE_PINYIN_M');NAME---------------不识庐山真面目横看成岭侧成峰远近高低各不同只缘身在此山中SQL> select * from test order by nlssort(name, 'NLS_SORT=SCHINESE_RADICAL_M');NAME---------------不识庐山真面目只缘身在此山中横看成岭侧成峰远近高低各不同

PostgreSQL NLSSORT

postgres=# select * from test;      name---------------- 横看成岭侧成峰 远近高低各不同 不识庐山真面目 只缘身在此山中(4 行记录)postgres=# select * from test order by name;      name---------------- 不识庐山真面目 横看成岭侧成峰 远近高低各不同 只缘身在此山中(4 行记录)

2、NLS_INITCAP/ NLS_LOWER/ NLS_UPPER

Oracle的NLS_INITCAP(x[,'NLS_SORT=y']) 、NLS_LOWER(x[,'NLS_SORT=y'])、NLS_UPPER(x[,'NLS_SORT=y']) 三个函数都有两个参数,可以根据y参数的不同,提供不同于系统默认值的结果。如果不提供这个参数,那么结果和initcap、lower和upper三个函数是一样的。

另外,Oracle的官方文档( )上,NLS_INITCAP的例子:

SELECT NLS_INITCAP('ijsland') "InitCap"  FROM DUAL;InitCap-------IjslandSELECT NLS_INITCAP('ijsland', 'NLS_SORT = XDutch') "InitCap"  FROM DUAL;InitCap-------IJsland

我这边做不出相同的效果。网上也没搜到。怀疑是老版的Oracle有这种做法,新版已经取消。

PostgreSQL中,对于同一种编码,没有提供多种方式排序。只有简单的Initcap, lower和upper函数。

另外,在实际使用中,这几个带NLS_的方法都几乎用不到。

Oracle NLS_INITCAP/ NLS_LOWER/ NLS_UPPER

SQL> select nls_initcap('ijslang') "test" from dual;test-------IjslangSQL> select nls_initcap('ijslang', 'NLS_SORT=XDutch') "test" from dual;test-------IjslangSQL> select initcap('ijslang') "test" from dual;test-------IjslangSQL> SELECT NLS_LOWER('NOKTASINDA', 'NLS_SORT = XTurkish') "Lowercase" from dual;Lowercase----------noktasindaSQL> SELECT NLS_LOWER('NOKTASINDA') "Lowercase" from dual;Lowercase----------noktasindaSQL> SELECT LOWER('NOKTASINDA') "Lowercase" from dual;Lowercase----------noktasindaSQL> SELECT NLS_UPPER('große') "Uppercase" from dual;Upper-----GRO?ESQL> SELECT NLS_UPPER('große','NLS_SORT=XGerman') "Uppercase" from dual;Upper-----GRO?ESQL> SELECT UPPER('große') "Uppercase" from dual;Upper-----GRO?E

PostgreSQL INITCAP/ LOWER/ UPPER

postgres=# select initcap('ijslang'); initcap--------- Ijslang(1 行记录)postgres=# select LOWER('NOKTASINDA');   lower------------ noktasinda(1 行记录)postgres=# select upper('große'); upper------- GRO?E(1 行记录)

PostgreSQL 9.4.4 中文手册:字符串函数

Database SQL Language Reference:

转载地址:http://qfvzl.baihongyu.com/

你可能感兴趣的文章
sublime 3 text 中运行Java
查看>>
前序遍历
查看>>
loadrunner检查点设置失败,日志中SaveCount无法被正常统计出来
查看>>
循环结构进阶
查看>>
bzoj 2809: [Apio2012]dispatching
查看>>
关于数据库查询时报“query block has incorrect number of result columns”
查看>>
记录一款Unity VR视频播放器插件的开发
查看>>
webApi跨域问题
查看>>
读取文件
查看>>
json字符串转换对象的方法1
查看>>
浅谈网站路径分析 转自“蓝鲸网站分析博客”
查看>>
C# Note36: .NET unit testing framework
查看>>
我的博客第一天
查看>>
margin注意问题
查看>>
事物的回滚
查看>>
Xcode7 iOS9.0 的真机调试
查看>>
Constraint3:check约束 和 null
查看>>
Fabric 1.0环境搭建
查看>>
c冒泡排序
查看>>
第十五篇、OC_同一个View实现两个手势响应
查看>>