最近公司有个项目需要将之前的Oracle版本转换为Mysql版本,除了需要修改配置外,最主要的就是sql语句的修改,现将改造过程中修改过的sql函数记录如下:

1.日期转换:
to_char --> date_format(a.order_date,'%Y-%m-%d %H:%i:%s')
to_date  --> str_to_date(#{orderDate},'%Y-%m-%d %H:%i:%s')

2.获取当前日期 sysdate --> sysdate()

3.字符串拼接 || --> concat()

4.格式化数据 TRUNC() 
①截取日期 trunc(sysdate,'yyyy') --> date_format(sysdate(),'%Y')
②取整TRUNC() --> FLOOR()

5.条件判断 decode()  --> case when then end
(case id when '0' then '1' else '0' end) treeLeaf

6.为空判断 nvl() --> ifnull()

7.行转列 wm_concat() --> group_concat()

8.时间为空校验 confirmedDate != ‘ ’,如果拿传入的时间类型参数与空字符串''进行对比判断则会引发异常. 只保  confirmedDate != null

9.年龄计算  
(SELECT TRUNC((to_char(sysdate, 'yyyyMMdd') - to_char(birth_date, 'yyyyMMdd')) /10000) as age   
-->
(SELECT date_format(sysdate(), '%Y-%m-%d') - date_format(birth_date, '%Y-%m-%d') as age

10.本级及下级区域查询
方法一:
START WITH id = #{areaCode} CONNECT BY PRIOR id = PARENT_ID   
-->  
(id = #{areaCode} or PARENT_IDS like concat('%',#{areaCode},'%') )
方法二:
START WITH id = #{areaCode} CONNECT BY PRIOR id = PARENT_ID   
--> 
FIND_IN_SET(a.id, getSOChildList(0))
新增mysql函数 getSOChildList(param)

DELIMITER //
CREATE DEFINER=`root`@`%` FUNCTION getSOChildList(rootId VARCHAR(10000)) RETURNS varchar(10000) CHARSET utf8
BEGIN 
       DECLARE pTemp VARCHAR(10000);  
       DECLARE cTemp VARCHAR(10000);  
      
       SET pTemp = '$';  
       SET cTemp =cast(rootId as CHAR); 
      
       WHILE cTemp is not null DO  
         SET pTemp = concat(pTemp,',',cTemp); 
         SELECT group_concat(ID) INTO cTemp FROM SYS_OFFICE   
         WHERE FIND_IN_SET(PARENT_ID,cTemp)>0;
       END WHILE;  
       RETURN pTemp;  
     END
//

11.前一天  
sysdate-1 --> date_sub(sysdate(),interval 1 day)

12.获取行号 ROWNUM 关键字
SELECT
(@rowNum:=@rowNum+1) as  ROWNUM,
a.* from(
SELECT
    *
FROM
    DRUG_INVENTORY_OUT_SUB
)a,(Select (@rowNum :=0) ) b

13.获取两个日期之间的月份间隔:
month_between(date1,date2)--> timestampdiff(month,date1,date2)

14. 日期月份累加(示例为在原日期上加3个月):
add_months(date1,3)--> DATE_ADD(date1,INTERVAL 3)
获取2天后的日期:
sysdate+2 --> date_add(sysdate(),interval 2 day)

15.nextval自增序列实现:
<1>.--创建Sequence管理表 sequence
DROP TABLE IF EXISTS sequence;
CREATE TABLE sequence (
name VARCHAR(50) NOT NULL,
current_value INT NOT NULL,
increment INT NOT NULL DEFAULT 1,
PRIMARY KEY (name)
) ENGINE=InnoDB;
--创建好表之后插入值定义序列名、初始值、自增幅度
INSERT INTO sequence VALUES ('testSeq', 0, 1);
<2>--创建获取当前值的函数 currval()

DROP FUNCTION IF EXISTS currval;
DELIMITER $
CREATE FUNCTION currval (seq_name VARCHAR(50))
RETURNS INTEGER
LANGUAGE SQL
DETERMINISTIC
CONTAINS SQL
SQL SECURITY DEFINER
COMMENT ''
BEGIN
DECLARE value INTEGER;
SET value = 0;
SELECT current_value INTO value
FROM sequence
WHERE name = seq_name;
RETURN value;
END
$
DELIMITER ;
--创建取下一个值的函数 nextval()

DROP FUNCTION IF EXISTS nextval;
DELIMITER $
CREATE FUNCTION nextval (seq_name VARCHAR(50))
RETURNS INTEGER
LANGUAGE SQL
DETERMINISTIC
CONTAINS SQL
SQL SECURITY DEFINER
COMMENT ''
BEGIN
UPDATE sequence
SET current_value = current_value + increment
WHERE name = seq_name;
RETURN currval(seq_name);
END
$
DELIMITER;

<3>使用时通过调用nextval()并传入序列名参数即可返回下一个自增值:
示例:
SELECT NEXTVAL('testSeq') as NEXTVAL;

16.to_number('123') --> cast('123' as SIGNED INTEGER)

Oracle项目转Mysql的sql语句改造总结相关推荐

  1. mysql执行sql语句按钮_mysql执行sql语句过程

    开发人员基本都知道,我们的数据存在数据库中(目前最多的是mysql和oracle,由于作者更擅长mysql,所以这里默认数据库为mysql),服务器通过sql语句将查询数据的请求传入到mysql数据库 ...

  2. MysQL高级SQL语句|进阶语句|select语句(一)【图文细解】

    MysQL高级SQL语句 一.SQL语句的概述 SELECT DISTINCT WHERE AND.OR IN BETWEEN 通配符 LIKE ORDER BY GROUP BY HAVING 二. ...

  3. sql oracle复制一张表里,Oracle如何复制表的sql语句

    以下的文章主要是介绍Oracle复制表的sql语句,其中包括如何复制表结构的sql.以及如何复制相关表的结构又复制表中的数据sql.以下就是相关内容的具体介绍,望你浏览完以下的内容会有所收获. 如下, ...

  4. MySQL的SQL语句转PostgreSQL的SQL语句工具编写总结

    1.起因在学习基于vue+springboot的前后端分离项目时,因项目需求变更,需要将mysql数据库全部迁移到postgersql数据库的需求,因而编写了一个基于jave的sql语句转换工具 2. ...

  5. oracle查看执行过的语句,oracle 查询执行过的SQL语句

    MySQL开启日志记录查询/执行过的SQL语句 作为后端开发者,遇到数据库问题的时候应该通过分析SQL语句来跟进问题所在,该方法可以记录所有的查询/执行的SQL语句到日志文件. 方法有几种,但是个人觉 ...

  6. oracle 执行带参数的sql语句_Oracle动态SQL语句的简单执行

    在使用ODP.NET进行Oracle编程时,有时候SQL语句非常复杂,需要采用动态构造查询语句的情况,有两种方法可以构造动态的SQL语句,并执行返回结果集. 1.在数据访问层构造SQL语句 例如下面的 ...

  7. windows下bat处理执行Mysql的sql语句

    这篇文章主要介绍了windows下bat批处理执行Mysql的sql语句,需要的朋友可以参考下 有时候我们需要用bat来定时执行mysql那么就可以参考下面的代码 直接上代码: @ECHO OFF S ...

  8. shell实行mysql语句_【Mysql】shell运行mysql的sql语句_MySQL

    bitsCN.com [Mysql]shell运行mysql的sql语句 shell本身是一种脚本语言,所以不能像java一样通过api去连接数据库.shell还是要借助mysql本身的一些运行脚本才 ...

  9. PHP获取MySQL执行sql语句的查询时间

    PHP获取MySQL执行sql语句的查询时间 1. $t1=microtime(true); mysql_query($sql); echo microtime(true)-$t1; 2. //计时开 ...

最新文章

  1. mysql read timed out_java.sql.SQLException: Socket read timed out
  2. zigbee 协议栈的时钟和定时器分频
  3. HDFS读写文件实例与解析
  4. 从操作系统层面描述线程的五种状态
  5. 前端基础-html-标题标签
  6. nrm : 无法加载文件 E:\node\node_global\nrm.ps1,因为在此系统上禁止运行脚本
  7. 解决XP IIS(HTTP 500内部服务器错误)
  8. c#定时备份mysql数据库_C# 定时备份数据库工具源码下载
  9. 梳理的关于mongodb的基础使用命令:----查询记录点--推荐使用:
  10. 看MASTER围棋有感
  11. 【翻译】在5分钟内了解HTTP3,同时补课HTTP 1.1, HTTP 2.0
  12. sql数据库如何分离
  13. 华为性格测试挂的原因是什么?这局怎么破?
  14. graphpad折线图教程_GraphPad Prism 8.0绘制误差连线并填充颜色图
  15. Oxygen XML Editor Professional文档的强大工具
  16. VR中多模式异步协作的挑战和设计考虑因素
  17. 支付宝密钥及文件生成方式
  18. pandas画柱状图,线形图
  19. office 2013 已停止工作;word excel 打开任何文件
  20. HTTP状态码206和416

热门文章

  1. 中创向心力:信——超级个体进化论第2期分享会在郑州成功举办
  2. Linux kali 2019.4以及其他版本网址、BT种子(国内可下)
  3. 在线洗衣洗鞋系统,洗鞋店小程序
  4. js判断是否是百度手机浏览器访问
  5. Spring Boot支付宝集成手机网站支付
  6. 导航栏:navbar
  7. 图形领域GPU标准之战逐鹿并行计算
  8. ChinaJoy+人工智能!3D AR酷炫体验游戏崭露头角
  9. Windows平台本地搭建PHP环境,超详细!(Apache+PHP+Mysql)
  10. C# 数组截取某一段的值