Oracle项目转Mysql的sql语句改造总结

10 篇文章 0 订阅
7 篇文章 0 订阅

最近公司有个项目需要将之前的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)
 

### 回答1: 要将Oracle SQL语句化为MySQL SQL语句,需要注意以下几点: 1. 日期和时间函数:MySQLOracle的日期和时间函数有些差异,需要对部分函数进行调整。例如,将Oracle的sysdate函数替换为MySQL的current_date函数,将Oracle的to_char函数替换为MySQL的date_format函数。 2. 字符串函数:OracleMySQL的字符串函数用法有些不同。例如,将Oracle的substr函数替换为MySQL的substring函数,将Oracle的instr函数替换为MySQL的locate函数。 3. 数据类型:某些数据类型在OracleMySQL中的表示方式不同,需要将其进行换。例如,将Oracle的number类型换为MySQL的decimal类型,将Oracle的varchar2类型换为MySQL的varchar类型。 4. 分页查询:OracleMySQL分页查询的语法也有所差异。在Oracle中,可以使用rownum来进行分页,而在MySQL中,可以使用limit和offset来实现。因此,在换查询语句时,需要将Oracle的rownum替换为MySQL的limit和offset。 5. NULL值处理:OracleMySQL对NULL值的处理方式也有些差异。在Oracle中,可以使用is null和is not null来判断NULL值,而在MySQL中,可以使用is null和is not null,也可以使用isnull函数。 总之,将Oracle SQL语句化为MySQL SQL语句需要注意这些差异,并根据具体情况进行适当调整和换。实际操作中,可以参考MySQL的官方文档和手册,以便获得更详细和准确的换规则和示例。 ### 回答2: 将Oracle SQL语句化为MySQL SQL语句通常需要注意以下几个方面: 1. 数据类型:OracleMySQL的数据类型有所不同,需要根据情况进行换。例如,将Oracle的NUMBER数据类型换为MySQL的INT或FLOAT类型。 2. 函数和操作符:OracleMySQL支持的函数和操作符有所不同,需要根据需求进行调整和替换。例如,将Oracle的TO_CHAR函数换为MySQL的DATE_FORMAT函数。 3. 子查询和连接:OracleMySQL的子查询和连接语法也有所差异,需要进行适当调整。例如,将Oracle的子查询使用WITH语句换为MySQL的内部子查询。 4. 约束和索引:OracleMySQL的约束和索引语法也有差异,需要进行相应修改。例如,将Oracle的UNIQUE约束换为MySQL的UNIQUE关键字。 下面是一个具体的例子,将OracleSQL语句换为MySQLSQL语句Oracle SQL语句: SELECT emp_name, hire_date FROM employees WHERE emp_id = 100; MySQL SQL语句: SELECT emp_name, hire_date FROM employees WHERE emp_id = 100; 这是一个简单的例子,在实际换过程中可能会遇到更多的复杂情况,需要根据具体需求进行相应的调整和修改。同时需要注意两种数据库的差异,以免出现语法错误或逻辑错误。另外,还可以通过使用一些第三方工具来自动完成SQL语句换,可以节省时间和精力。 ### 回答3: 要将Oracle SQL语句化为MySQL SQL语句,需要注意一些Oracle特有的函数、关键字和语法在MySQL中可能没有或有不同的实现。下面是一些常见的化技巧: 1. 字符串连接: Oracle中使用"||"作为字符串连接符,而MySQL使用"CONCAT"函数。例如: Oracle:SELECT firstname || ' ' || lastname FROM employees; MySQL:SELECT CONCAT(firstname, ' ', lastname) FROM employees; 2. 日期格式化: Oracle中使用"TO_CHAR"函数进行日期格式化,而MySQL使用"DATE_FORMAT"函数。例如: Oracle:SELECT TO_CHAR(hiredate, 'YYYY/MM/DD') FROM employees; MySQL:SELECT DATE_FORMAT(hiredate, '%Y/%m/%d') FROM employees; 3. 行号: 在Oracle中,可以使用"ROWNUM"来获取行号,而MySQL需要使用子查询和变量来实现类似的功能。例如: Oracle:SELECT * FROM employees WHERE ROWNUM <= 10; MySQL:SELECT * FROM employees WHERE id <= (SELECT id FROM employees ORDER BY id LIMIT 1 OFFSET 9); 4. 分页查询: 在Oracle中使用"ROWNUM"和"FETCH FIRST"实现分页查询,而MySQL使用"LIMIT"和"OFFSET"。例如: Oracle:SELECT * FROM employees WHERE ROWNUM > 10 AND ROWNUM <= 20; MySQL:SELECT * FROM employees LIMIT 10 OFFSET 10; 5. 自增主键列: 在Oracle中使用"SEQUENCE"和"TRIGGER"来生成自增主键值,而MySQL使用"AUTO_INCREMENT"关键字。例如: Oracle:CREATE SEQUENCE seq_emp_id START WITH 1 INCREMENT BY 1; CREATE TRIGGER tr_emp_id BEFORE INSERT ON employees FOR EACH ROW BEGIN SELECT seq_emp_id.nextval INTO :NEW.id FROM dual; END; MySQL:CREATE TABLE employees (id INT PRIMARY KEY AUTO_INCREMENT, firstname VARCHAR(50), lastname VARCHAR(50)); 需要注意的是,这只是一些常见的化技巧,具体的化还需要根据具体的SQL语句数据库结构进行调整和适配。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值