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的官方文档(http://docs.oracle.com/database/121/SQLRF/functions122.htm#SQLRF00676 )上,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 中文手册:字符串函数
http://www.postgres.cn/docs/9.4/functions-string.html
Database SQL Language Reference:
http://docs.oracle.com/database/121/SQLRF/functions122.htm#SQLRF00676
http://docs.oracle.com/database/121/SQLRF/functions123.htm#SQLRF00677
http://docs.oracle.com/database/121/SQLRF/functions125.htm#SQLRF00678
http://docs.oracle.com/database/121/SQLRF/functions124.htm#SQLRF00679

《卸甲笔记》-PostgreSQL和Oracle的SQL差异分析之五:函数的差异(四)相关推荐

  1. 《卸甲笔记》-PostgreSQL和Oracle的SQL差异分析之三:rownum和聚合函数

    PostgreSQL是世界上功能最强大的开源数据库,在国内得到了越来越多机构和开发者的青睐和应用.随着PostgreSQL的应用越来越广泛,Oracle向PostgreSQL数据库的数据迁移需求也越来 ...

  2. [推荐]ORACLE PL/SQL编程之五:异常错误处理(知已知彼、百战不殆)

    原文:[推荐]ORACLE PL/SQL编程之五:异常错误处理(知已知彼.百战不殆) [推荐]ORACLE PL/SQL编程之五: 异常错误处理(知已知彼.百战不殆) 继上三篇:ORACLE PL/S ...

  3. oracle sql常用的函数,界别Oracle和SQL Server常用函数

    区分Oracle和SQL Server常用函数 一.数学函数 1.绝对值 S:select abs(-1) value O:select abs(-1) value from dual 2.取整(大) ...

  4. oracle v¥bh,ORACLE数据库sql语言、函数及常用命令

    file=c:\database\ydxt200108170926.dmp log=c:\database\ydxt200108170926.log fromuser=cur touser=cur1 ...

  5. 读书笔记 《精通Oracle PL/SQL》

    Mastering Oracle PL/SQL Practical Solutions 五位作者: Connnor MaDonald Chaim Katz Christopher Beck Joel ...

  6. SQL:DBMS函数的差异(限制输出结果、拼接字段)

    文章目录 限制输出结果 拼接字段 日期和时间处理函数 DBMS函数的差异汇总 限制输出结果 SQL Serve select top 5 prod_name from Products; DB2 se ...

  7. 《O2P卸甲笔记》附录:Oracle XE快速安装

    建议大家使用Oracle XE版本,因为这是唯一在Oracle商业条款中可以免费使用的版本.其他Oracle版本中我没有看到free的字样,因此哪怕是用于开发和学习可能都是有问题的,不要因为学习和开发 ...

  8. 《卸甲笔记》-分组统计查询对比

    统计函数对比 1查询出公司每个月支出的月工资总和 Oracle SQL> select SUM(sal) from emp;SUM(SAL) ----------29025 PPAS scott ...

  9. 《卸甲笔记》-单行函数对比之二

    21验证TRUNC()函数 Oracle SQL> select TRUNC(789.652) 截取小数, TRUNC(789.652,2) 截取两位小数,TRUNC(789.652,-2) 取 ...

  10. 《卸甲笔记》-多表查询之二

    13增加右外连接,显示部门40的信息 Oracle SQL> select *2 from emp e,dept d3 where e.deptno(+)=d.deptno;EMPNO ENAM ...

最新文章

  1. 福利丨网友授课视频分享:机器学习实战-KNN-第一部分
  2. 1 个闭环 + 1 个案例,为你解读实现数据驱动的秘诀
  3. 如何将excel表格内的数据导入至mysql数据库
  4. requests模块发送带headers的Get请求和带参数的请求
  5. 基于Kebernetes 构建.NET Core技术中台
  6. Java中接口、抽象类与内部类学习
  7. 敏捷软件开发:原则、模式与实践——第12章 ISP:接口隔离原则
  8. 机器学习统计学相关书籍
  9. 训练日志 2019.1.25
  10. 小瓦怕扫地机器人_小瓦扫地机器人青春版评测报告
  11. Android apk系列1-------APK签名
  12. 怎么将表中的空格都转变为0???
  13. BZOJ4293 : [PA2015]Siano
  14. PTV-VISSIM交通仿真
  15. 一体机怎么修复音频服务器,多媒体教学一体机没有声音是怎么办?
  16. Ubuntu20.04 重装N卡驱动仍无法解决的问题的解决方法
  17. Unity输入控制物体旋转和延迟缩放-课程作业
  18. canvas实现涂鸦效果--橡皮檫和历史记录
  19. react webpack配置组件路径引用 @与自定义
  20. Squid服务器应用(Squid传统代理、Squid透明代理、ACL访问控制、Squid日志分析、Squid反向代理)

热门文章

  1. 无线网络 设置网关和服务器,我家的网络连接的IP是 192.168.1.223 我想问网关是多少 服务器是...
  2. sphinx的php扩展,替php安装sphinx扩展
  3. 计算机应用基础统考模拟练习系统,网教计算机应用基础统考综合模拟练习题(一)...
  4. php 怎么写配置文件,在PHP中如何把数组写成配置文件
  5. MyEclipse出现红色感叹号解决办法
  6. SSH项目ueditor插件jsp版本
  7. CREATE TABLE TEST_A AS SELECT * FROM TEST_B
  8. hdu-acm steps Common Subsequence
  9. 图像处理之基础---ffmpeg 中的图像缩放
  10. 一些网络爱好者常用的网络工具