iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >怎么协助MySQL实现Oracle高级分析函数
  • 662
分享到

怎么协助MySQL实现Oracle高级分析函数

2023-06-01 01:06:13 662人浏览 薄情痞子
摘要

小编给大家分享一下怎么协助MySQL实现oracle高级分析函数,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Oracle 支持一些独特的语法和函数,在移植到 M

小编给大家分享一下怎么协助MySQL实现oracle高级分析函数,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

Oracle 支持一些独特的语法和函数,在移植到 Mysql 上时或多或少给程序员造成了困扰,下面我们针对 Oracle 的一些特殊用法举例并讲解如何用集算器来完成同样功能。这些方法当然也不限于针对 mysql,对于所有其它数据库也能支持。

         递归语句

a)     select employee_id,first_name,last_name,manager_id

from hr.employees

start with employee_id=102

connect by prior employee_id = manager_id

怎么协助MySQL实现Oracle高级分析函数

(1)   A3 设置序表 A2 的键

(2)   A4 选取起始雇员

(3)   A5 将 A2 中 MANAGER_ID 值转换成记录,以便递归

(4)   A6 获取起始雇员的所有子节点

                                              怎么协助MySQL实现Oracle高级分析函数

b)    select employee_id, first_name,last_name,manager_id

from hr.employees

start with employee_id=104

connect by prior manager_id = employee_id

怎么协助MySQL实现Oracle高级分析函数

(1)   A6 获取起始雇员的所有父节点

怎么协助MySQL实现Oracle高级分析函数

c)     select employee_id,last_name,manager_id,sys_connect_by_path(last_name,'/') path from hr.employees

start with employee_id=102

connect by prior employee_id = manager_id

怎么协助MySQL实现Oracle高级分析函数

(1)   由于 A7 中每条记录的父节点都在本节点之前,故 A8 可以从前往后对 A7 中每条记录依次修改 PATH 值

怎么协助MySQL实现Oracle高级分析函数

         嵌套聚集函数

select avg(max(salary)) avg_max, avg(min(salary)) avg_min

from hr.employees

group by department_id

怎么协助MySQL实现Oracle高级分析函数

(1)   A2 中 A1.query 也可以改用 A1.cursor

怎么协助MySQL实现Oracle高级分析函数

         聚集分析函数 FIRST 和 LAST

SELECT department_id,

MIN(salary) KEEP (DENSE_RANK FIRST ORDER BY commission_pct) worst,

MAX(salary) KEEP (DENSE_RANK LAST ORDER BY commission_pct) best

FROM hr.employees

GROUP BY department_id

ORDER BY department_id

怎么协助MySQL实现Oracle高级分析函数

(1)   A2 已按 DEPARTMENT_ID 排序,则 A3 分组时可采用 group@o

(2)   FIRST/LAST 取排序的后第一组 / 最后一组,而 Oracle 排序时 null 排在最后,所以 LAST 会取到的最后一组就是 null 值所在组。maxp/minp 求具有最大值 / 最小值的所有行时排除了 null,所以在 A4 是用 ifn(COMMISSION_PCT,2) 保证 null 值时最大

(3)   A5 中,DEPARTMENT_ID=null 时采用采用比所有 DEPARTMENT_ID 都大的 power(2,32) 来保证这一行排在最后

如果数据量大,还可以采用游标方式。

怎么协助MySQL实现Oracle高级分析函数

(1)    A3 中,min([if(COMMISSION_PCT,2), SALARY]) 求出 COMMISSION_PCT 最小时的 SALARY 最小值,即 COMMISSION_PCT 排名第一时 SALARY 最小值,max 类似

怎么协助MySQL实现Oracle高级分析函数

         占比函数 ratio_to_report

a)      SELECT last_name, salary, RATIO_TO_REPORT(salary) OVER () AS rr

FROM hr.employees

WHERE job_id = 'PU_CLERK'

ORDER BY last_name

怎么协助MySQL实现Oracle高级分析函数

       怎么协助MySQL实现Oracle高级分析函数

b)      SELECT department_id,last_name, salary, RATIO_TO_REPORT(salary) OVER (partition by department_id) AS rr

FROM hr.employees

WHERE department_id in (20,60)

ORDER BY department_id,last_name

怎么协助MySQL实现Oracle高级分析函数

(1)    A2 中已按 DEPARTMENT_ID 排序,则 A3 可用 groups@o 分组聚集

怎么协助MySQL实现Oracle高级分析函数

         多重分组

SELECT department_id, job_id, sum(salary) total

FROM hr.employees

WHERE department_id in (30, 50)

GROUP BY grouping sets((department_id, job_id), department_id)

怎么协助MySQL实现Oracle高级分析函数

(1)    因为 A3 和 A4 均对 DEPARTMENT_ID 有序,故 A5 可 merge,ifn(JOB_ID,fill("z",10))) 用来保证 JOB_ID 为 null 排在后面

也可以采用游标方式。

怎么协助MySQL实现Oracle高级分析函数

(1)    A3 中 A2.group 要求 A2 对 DEPARTMENT_ID 有序

(2)    A4 对 A3 每一组求和并将结果插入此组末尾

还可以采用管道方式。

怎么协助MySQL实现Oracle高级分析函数

(1)   A3 创建管道,并附加分组求和

(2)   A4 将 A2 中数据推送到 A3,注意此动作只有在 A2 中数据有实际取出行为才执行

(3)   A5 创建管道,并附加分组求和

(4)   A6 将 A3 结果推送到 A5,此处也可以直接将 A2 中数据推送到 A5,但会增加时间复杂度

(5)   A7 保留 A3 的数据

(6)   循环读取 A2,每次只取 1000 条,减少内存占用

(7)   A10 对 A3 和 A5 中数据排序,因为算法是稳定的,所以 JOB_ID 为 null 的排在后面

怎么协助MySQL实现Oracle高级分析函数

以上是“怎么协助Mysql实现Oracle高级分析函数”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网数据库频道!

您可能感兴趣的文档:

--结束END--

本文标题: 怎么协助MySQL实现Oracle高级分析函数

本文链接: https://www.lsjlt.com/news/227524.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么协助MySQL实现Oracle高级分析函数
    小编给大家分享一下怎么协助MySQL实现Oracle高级分析函数,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Oracle 支持一些独特的语法和函数,在移植到 M...
    99+
    2023-06-01
  • MySQL中怎么实现一个分析函数
    本篇文章为大家展示了MySQL中怎么实现一个分析函数,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1. 实现rownum12SET @rn:=0;SELE...
    99+
    2024-04-02
  • Mysql似oracle分析函数sum over的实现方法是什么
    这篇文章主要介绍“Mysql似oracle分析函数sum over的实现方法是什么”,在日常操作中,相信很多人在Mysql似oracle分析函数sum over的实现方法是什么问题上存在疑惑,小编查阅了各式...
    99+
    2024-04-02
  • Oracle数据库高级应用:乘法运算实例分析
    Oracle数据库作为业界领先的关系型数据库管理系统,具有强大的功能和灵活的应用,能够支持各种复杂的数据处理需求。在数据库应用中,常常需要进行各种数值运算,如加减乘除等。本文将重点介绍...
    99+
    2024-03-02
    数据库 oracle 乘法 sql语句
  • MySQL数据库SQL语句高级操作实例代码分析
    本文小编为大家详细介绍“MySQL数据库SQL语句高级操作实例代码分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“MySQL数据库SQL语句高级操作实例代码分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一...
    99+
    2023-07-02
  • 异步协程开发指南:实现高并发的实时数据分析
    异步协程开发指南:实现高并发的实时数据分析,需要具体代码示例引言:随着互联网的高速发展,数据量呈现爆炸性增长,很多应用场景需要实时处理大规模数据。传统的同步编程方式往往难以应对这样的需求,而异步协程编程模型可以帮助我们利用并发性能,高效地处...
    99+
    2023-12-09
    异步 协程 高并发
  • SQL 窗口函数实现高效分页查询的案例分析
    🍺不闻不若闻之,闻之不若见之,见之不若知之,知之不若行之。学至于行之而止矣。——荀子 大家好!我是只谈技术不剪发的 Tony 老师。 在使用 SQL 语句实...
    99+
    2024-04-02
  • 怎么在Python中使用pandas函数实现数据分析
    本篇文章给大家分享的是有关怎么在Python中使用pandas函数实现数据分析,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。python有哪些常用库python常用的库:1.r...
    99+
    2023-06-14
  • MySQL怎么实现数据分页
    MySQL可以使用LIMIT和OFFSET关键字来实现数据分页。LIMIT用于限制查询结果的记录数,OFFSET用于指定查询结果的起...
    99+
    2023-08-24
    MySQL
  • Oracle递归函数怎么用java实现
    在Java中,你可以通过创建一个递归函数来实现Oracle递归。以下是一个使用Java实现Oracle递归的示例:```javapu...
    99+
    2023-09-26
    Oracle java
  • Python中怎么实现数据分析
    今天就跟大家聊聊有关Python中怎么实现数据分析,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。为什么选择Python进行数据分析?Python是一门动态的、面向对象的脚本语言,同时...
    99+
    2023-06-20
  • thinkphp怎么实现大数据分析
    这篇文章主要讲解了“thinkphp怎么实现大数据分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“thinkphp怎么实现大数据分析”吧!一、什么是thinkphpthinkphp是一种基...
    99+
    2023-07-05
  • 浅析php+mysql怎么实现读写分离
    MySQL作为目前最流行的数据库之一,在应用中大量被使用。在高并发和数据量较大的情况下,由于MySQL的读写并发性能不足,为了提高MySQL的并发性能,读写分离成为了必要的方案。读写分离的原理是将读操作和写操作分别放在不同的MySQL实例上...
    99+
    2023-05-14
    读写分离 php mysql
  • PHP MySQL怎么实现数据分页
    这篇文章主要讲解了“PHP MySQL怎么实现数据分页”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PHP MySQL怎么实现数据分页”吧!SQL ...
    99+
    2024-04-02
  • MySQL中怎么实现数据切分
    MySQL中怎么实现数据切分,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。  什么是MySQL数据切分  "Shard"...
    99+
    2024-04-02
  • MySQL自定义变量实现row_number分析函数的问题示例
    小编给大家分享一下MySQL自定义变量实现row_number分析函数的问题示例,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!MySQL经常用自定义变量实现复杂查询,比如row_numbe...
    99+
    2024-04-02
  • mysql上亿数据秒级查询怎么实现
    要实现MySQL上亿数据的秒级查询,需要考虑以下几个方面:1. 数据分库分表:将数据分散存储在多个数据库和表中,以减少单个数据库或表...
    99+
    2023-10-27
    mysql
  • 如何实现MySQL底层优化:查询缓存的高级使用和性能分析
    如何实现MySQL底层优化:查询缓存的高级使用和性能分析摘要:MySQL是一款广泛使用的关系型数据库管理系统,它的查询缓存功能可以有效提升查询性能。本文将介绍MySQL查询缓存的高级使用方法和性能分析,包括查询缓存的启用、使用查询缓存实例、...
    99+
    2023-11-09
    性能分析 查询缓存 MySQL底层优化
  • PHP中怎么实现一个分页函数
    PHP中怎么实现一个分页函数,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。写列表性质的页面,几乎都要写上一段分页的程序。最近小阳终于决心一劳永逸—&am...
    99+
    2023-06-17
  • 怎么使用Pandas实现MySQL日期函数
    本文小编为大家详细介绍“怎么使用Pandas实现MySQL日期函数”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么使用Pandas实现MySQL日期函数”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、前言环...
    99+
    2023-07-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作