Oracle 迁移至MySQL部分语句的转换

php中文网
发布: 2016-06-07 17:35:42
原创
1366人浏览过

前几天把系统从oracle往mysql上迁移,很多的语句是比较简单的,就是一些函数的修改如to-date等

oracle 迁移至mysql部分语句的转换

[日期:2014-02-27] 来源:Linux社区  作者:jimmy609 [字体:]

前几天把系统从Oracle往mysql上迁移,很多的语句是比较简单的,就是一些函数的修改如to-date等

但是也有几个比较棘手的,这里记录下

第一、row_number() over(partition by 

首先要了解下oracle中这个函数的用法,看个例子

select t.*,row_number() over(partition by t.owner order by y.createDate desc) rn from test t

这个语句的意思就是,把test这个表的数据按照owner 分组并且给每个分组的里面的数据加上一个序列号,数据格式如下

id      name      owner  createDate  rn

1        aa            001                              1

2          bb          001                              2

3          cc            001                            3

4          dd            002                            1

5          ee          002                              2

6            ff            003                              1

NameGPT
NameGPT

免费的名称生成器,AI驱动在线生成企业名称及Logo

NameGPT 68
查看详情 NameGPT

数据搞得不太正规,但是应该能够看懂它的意思吧,

但是在mysql中是没有这个函数的于是乎,找啊找,,总算找了个解决方法,如下

SELECT
    heyf_tmp.*,
    IF(@pdept=heyf_tmp.owner ,@rn:=@rn+1,@rn:=1) AS rn,
    @pdept:=heyf_tmp.owner
FROM
    (
        SELECT
            yv.*
        FROM
            test yv
        ORDER BY
            yv.owner  ,
            yv.createDate  DESC
    )
    heyf_tmp ,
    (
        SELECT
            @rn :=0 ,
            @pdept := NULL ,
            @rn:=0
    )
    aa


具体是什么意思,不是很清楚,不过先解决问题再说

第二、oracle树形查询

oracle树形查询现成的方法

select distinct t.id as id, t.name

from test t
                start with id=‘’
              connect by prior id = parentid

但是mysql中是没有这个方法的,于是只能自己定义函数或者过程,我这里用的是过程

如下

CREATE PROCEDURE Pro_GetTreeList`(in pid varchar(36))
begin
  declare lev int;
  set lev=1;
  drop table if exists tmp1;   
  CREATE TABLE tmp1(id VARCHAR(40),name varchar(50),parentid varchar(40) ,levv INT);   
  INSERT tmp1 SELECT id,name,parent_id,1 FROM `test` WHERE parent_id=pid;   
  while  row_count()>0
    do    set lev=lev+1;   
    INSERT tmp1 SELECT t.id,t.name,t.parent_id,lev from testt join tmp1 a on t.parent_id=a.id AND levv=lev-1;--查出子节点
  end while ;   
  INSERT tmp1 SELECT id,name,parent_id,0 FROM test WHERE id=pid;  --查出当前节点
end


这个存储过程应该都能看懂吧,就不做多解释了

linux

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号