天天看点

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

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

rownum是oracle内部的一个伪列,用来表示数据在结果集中的行数。它是在同一层sql中结果集查询出来以后,排序以前进行的操作。oracle的rownum必须从1开始。如果使用>1这样的条件,将一条数据都取不到。oracle中,把检索结果取出来后,在画面上分页显示的功能,都是使用rownum,并且使用多层子查询来实现的。

postgresql中,没有rownum这样的伪列,但是提供了 limit 和 offset 两个关键字来实现类似的功能。limit表示取得记录的条数。而 offset 是指偏移位置,也就是表示从第几条开始取数据(offset从0开始)。

oracle rownum

postgresql limit 和 offset

聚合函数是标准sql语言中的函数,主要包括求计数(count),求最大值(max),求最小值(min),求和(sum)和求平均数(avg)等几个。oracle和postgresql都支持聚合函数。但是对求和(sum)和求平均数(avg)而言,oracle和postgresql有一些不同。

对求和(sum)和求平均数(avg)而言,oracle由于内部有自动类型转换,所以对于字符型数字(数据类型是字符,但是里面的数据都是数字)可以直接使用。而postgresql内部没有自动类型转换,所以对于字符型数字而言,必须先使用类型转换,转换成数字后再使用函数进行计算。

oracle 聚合函数

postgresql 聚合函数