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

本文涉及的产品
云原生数据库 PolarDB PostgreSQL 版,标准版 2核4GB 50GB
云原生数据库 PolarDB MySQL 版,通用型 2核8GB 50GB
简介:

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

rownum

rownum是Oracle内部的一个伪列,用来表示数据在结果集中的行数。它是在同一层SQL中结果集查询出来以后,排序以前进行的操作。Oracle的rownum必须从1开始。如果使用>1这样的条件,将一条数据都取不到。Oracle中,把检索结果取出来后,在画面上分页显示的功能,都是使用rownum,并且使用多层子查询来实现的。
PostgreSQL中,没有rownum这样的伪列,但是提供了 limit 和 offset 两个关键字来实现类似的功能。limit表示取得记录的条数。而 offset 是指偏移位置,也就是表示从第几条开始取数据(offset从0开始)。

Oracle rownum

SQL> select rownum, id, name from student;

    ROWNUM         ID NAME
---------- ---------- ----------
         1          1 张一
         2          2 王二
         3          3 李三
         4          4 赵四

SQL> select rownum ,id,name from student order by name;

    ROWNUM         ID NAME
---------- ---------- ----------
         3          3 李三
         2          2 王二
         1          1 张一
         4          4 赵四

SQL>  select rownum ,id,name from (select * from student order by name);

    ROWNUM         ID NAME
---------- ---------- ----------
         1          3 李三
         2          2 王二
         3          1 张一
         4          4 赵四

SQL> select rownum, id, name from student where rownum >1 order by name;

未选定行

SQL> select * from
  2  (
  3  select a.*, rownum rn
  4  from (select * from student)a
  5  where rownum <=3
  6  )
  7  where rn >2;

        ID NAME               RN
---------- ---------- ----------
         3 李三                3
AI 代码解读

PostgreSQL limit 和 offset

postgres=# select * from student;
 id | name
----+------
  1 | 张一
  2 | 王二
  3 | 李三
  4 | 赵四
(4 行记录)

postgres=# select * from student order by name;
 id | name
----+------
  3 | 李三
  2 | 王二
  1 | 张一
  4 | 赵四
(4 行记录)

postgres=# select * from student limit 2;
 id | name
----+------
  1 | 张一
  2 | 王二
(2 行记录)

postgres=# select * from student offset 2;
 id | name
----+------
  3 | 李三
  4 | 赵四
(2 行记录)

postgres=# select * from student limit 1 offset 2;
 id | name
----+------
  3 | 李三
(1 行记录)
AI 代码解读

聚合函数

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

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

Oracle 聚合函数

SQL> desc achieve;
 名称                                      是否为空? 类型
 ----------------------------------------- -------- ----------------------------
 ID                                        NOT NULL NUMBER(38)
 NAME                                               VARCHAR2(10)
 ACHIEVE                                            VARCHAR2(10)

SQL> select * from achieve;

        ID NAME       ACHIEVE
---------- ---------- ----------
         1 赵大       5200
         2 钱二       4500
         3 孙三       6000
         4 李四       8000
         5 周五

SQL>  select min(achieve) from achieve;

MIN(ACHIEV
----------
4500

SQL>  select max(achieve) from achieve;

MAX(ACHIEV
----------
8000

SQL>  select count(achieve) from achieve;

COUNT(ACHIEVE)
--------------
             4

SQL> select sum(achieve) from achieve;

SUM(ACHIEVE)
------------
       23700

SQL> select avg(achieve) from achieve;

AVG(ACHIEVE)
------------
        5925
AI 代码解读

PostgreSQL 聚合函数

postgres=# \d achieve;
         数据表 "public.achieve"
  栏位   |         类型          | 修饰词
---------+-----------------------+--------
 id      | integer               | 非空
 name    | character varying(10) |
 achieve | character varying(10) |
索引:
    "achieve_pkey" PRIMARY KEY, btree (id)

postgres=# select * from achieve;
 id | name | achieve
----+------+---------
  1 | 赵大 | 5200
  2 | 钱二 | 4500
  3 | 孙三 | 6000
  4 | 李四 | 8000
  5 | 周五 |
(5 行记录)

postgres=# select min(achieve) from achieve;
 min
------
 4500
(1 行记录)

postgres=# select max(achieve) from achieve;
 max
------
 8000
(1 行记录)

postgres=# select count(achieve) from achieve;
 count
-------
     4
(1 行记录)

postgres=# select sum(achieve) from achieve;
错误:  函数 sum(character varying) 不存在
第1行select sum(achieve) from achieve;
            ^
提示:  没有匹配指定名称和参数类型的函数. 您也许需要增加明确的类型转换.
postgres=# select avg(achieve) from achieve;
错误:  函数 avg(character varying) 不存在
第1行select avg(achieve) from achieve;
            ^
提示:  没有匹配指定名称和参数类型的函数. 您也许需要增加明确的类型转换.
postgres=# select sum(achieve::int) from achieve;
  sum
-------
 23700
(1 行记录)

postgres=# select avg(cast(achieve as int)) from achieve;
          avg
-----------------------
 5925.0000000000000000
(1 行记录)

AI 代码解读
相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
目录
打赏
0
0
0
0
39
分享
相关文章
CTE vs 子查询:深入拆解PostgreSQL复杂SQL的隐藏性能差异
本文深入探讨了PostgreSQL中CTE(公共表表达式)与子查询的选择对SQL性能的影响。通过分析两者底层机制,揭示CTE的物化特性及子查询的优化融合优势,并结合多场景案例对比执行效率。最终给出决策指南,帮助开发者根据数据量、引用次数和复杂度选择最优方案,同时提供高级优化技巧和版本演进建议,助力SQL性能调优。
凌晨2点报警群炸了:一条sql 执行200秒!搞定之后,我总结了一个慢SQL查询、定位分析解决的完整套路
凌晨2点报警群炸了:一条sql 执行200秒!搞定之后,我总结了一个慢SQL查询、定位分析解决的完整套路
凌晨2点报警群炸了:一条sql 执行200秒!搞定之后,我总结了一个慢SQL查询、定位分析解决的完整套路
【SQL周周练】:利用行车轨迹分析犯罪分子作案地点
【SQL破案系列】第一篇: 如果监控摄像头拍下了很多车辆的行车轨迹,那么如何利用这些行车轨迹来分析车辆运行的特征,是不是能够分析出犯罪分子“踩点”的位置
74 15
【MySQL】SQL分析的几种方法
以上就是SQL分析的几种方法。需要注意的是,这些方法并不是孤立的,而是相互关联的。在实际的SQL分析中,我们通常需要结合使用这些方法,才能找出最佳的优化策略。同时,SQL分析也需要对数据库管理系统,数据,业务需求有深入的理解,这需要时间和经验的积累。
100 12
自动化测试项目实战笔记(一):JDK、Tomcat、MySQL、Jpress环境安装和搭建
这篇文章是关于自动化测试项目实战笔记,涵盖了JDK、Tomcat、MySQL、Jpress环境的安装和搭建过程,以及测试用例和常见问题总结。
198 1
自动化测试项目实战笔记(一):JDK、Tomcat、MySQL、Jpress环境安装和搭建
手机短信SQL分析技巧与方法
在手机短信应用中,SQL分析扮演着至关重要的角色
Struts 2携手AngularJS与React:探索企业级后端与现代前端框架的完美融合之道
【8月更文挑战第31天】随着Web应用复杂性的提升,前端技术日新月异。AngularJS和React作为主流前端框架,凭借强大的数据绑定和组件化能力,显著提升了开发动态及交互式Web应用的效率。同时,Struts 2 以其出色的性能和丰富的功能,成为众多Java开发者构建企业级应用的首选后端框架。本文探讨了如何将 Struts 2 与 AngularJS 和 React 整合,以充分发挥前后端各自优势,构建更强大、灵活的 Web 应用。
125 0
如何在 Oracle 中配置和使用 SQL Profiles 来优化查询性能?
在 Oracle 数据库中,SQL Profiles 是优化查询性能的工具,通过提供额外统计信息帮助生成更有效的执行计划。配置和使用步骤包括:1. 启用自动 SQL 调优;2. 手动创建 SQL Profile,涉及收集、执行调优任务、查看报告及应用建议;3. 验证效果;4. 使用 `DBA_SQL_PROFILES` 视图管理 Profile。
ORACLE SQL优化之ORA-03150&ORA-02055&ORA-02063
                                                                                                             >   
4953 0

推荐镜像

更多
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问