百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

浅谈Oracle和mysql数据语法的区别

yuyutoo 2024-12-18 17:59 5 浏览 0 评论

Oracle数据和Mysql数据库都是十分常见的数据库,使用都很广泛,使用过的人会发现在写sql语句时两者之间大多数语法是相通的,但是也有一些地方语法不一样,今天我们一起来浅聊一下它们的区别吧。

通过查阅资料和自身的经验我一共整理了10点区别,具体如下。

1.oracle中select语句后边的from是不能省略的,如果没有实际的表,可以用dual作为from的目的表,mysql中from则是可以省略的,例如查看系统当前日期,oracle中语法为:select sysdate from dual;mysql中为select CURRENT_DATE;

2.orcle支持全连接语法,通过full join关键字实现,mysql则没有全连接对应的关键字,只能通过union取左外连接和右外连接的合集来实现全连接。

例如:查看所有员工对应的部门,以及所有部门下边的员工。Oracle中语法为:

Select * from emp full join dept on emp.deptno=dept.deptno;

Mysql中语法为:

Select * from emp left join dept on emp.deptno=dept.deptno union Select * from emp right join dept on emp.deptno=dept.deptno;

3.oracle中分组语句如果某列名不作为分组依据,及没有出现在group by后,则该列名是不允许放到select后边的,mysql则没有此限制。

4. Oracle左连接,右连接可以使用(+)来实现. MySQL只能使用left join ,right join等关键字。例如:

oracle右连接

select * from a,b where a.id(+)=b.id;

左连接:

select * from a,b where a.a2=b.b2(+);

mysql右连接:

select * from a right join b on a.id=b.id;

左连接:

select * from a left join b on a.a2=b.b2;

5.Orcle可以使用||将多列连接到一起,mysql需要使用函数才可以。例如:查找员工的工资,在oracle中可以这样:

select name||’’s’||’ sallry’||’ is ’||sal from emp;

在mysql中只能

select CONCAT(ename,"'s"," sallary"," is ",sal) from emp;

6.Oracle可通过rownum获取前n条记录,MySQL通过limit来获取前n条记录,但二者的写法略有不同,在Oracle中rownum作为where条件的一部分,而MySQL中limit不是where条件的一部分。

rownum语法如下:

SELECT * FROM XJ_STUDENT WHERE ROWNUM = 1; -- 查询第一条数据
SELECT * FROM XJ_STUDENT WHERE ROWNUM <= 10; -- 获取前10条数据

但rownum不支持查询后几条或第n(n>1)条数据,例如以下sql是不支持的

SELECT * FROM XJ_STUDENT WHERE ROWNUM > 2;
SELECT * FROM XJ_STUDENT WHERE ROWNUM = 3;

limit 语法如下:

SELECT * from fw_department limit 3; -- 查询前3条数据
SELECT * from fw_department limit 2, 4; -- 从第2(序号从0开始)条开始,查4条记录

7. Oracle 中可用with来构建一个临时表,但MySQL不支持with,对应临时表,MySQL可通过小括号的方式来处理,但构建的临时表必须设置临时表名。

-- Oracle with使用

WITH TMPTAB AS (SELECT A.DEPID FROM FW_DEPARTMENT A);
SELECT DEPID FROM TMPTAB;

-- MySQL 构建临时表使用(此处必须给括号中的临时表设置表名)

select b.depid from (select depid from fw_department) b;

8. ORACLE没有自动增长的数据类型,需要建立一个自动增长的序列号,插入记录时要把序列号的下一个值赋于此字段。 MYSQL有自动增长的数据类型,插入记录时不用操作此字段,会自动获得数据值。

9. ORACLE里只可以用单引号包起字符串,MYSQL里可以用双引号包起字符串。在插入和修改字符串前必须做单引号的替换:把所有出现的一个单引号替换成两个单引号。

10.oracle中空值只有null,mysql中空值有两种形态一种是null,另一种是‘’。过滤null时只能使用is null,过滤‘’时要使用=‘’。

以上就是oracle和mysql最常见的几点语法区别,当然实际区别远远不止这些。

相关推荐

TCP协议原理,有这一篇就够了

先亮出这篇文章的思维导图:TCP作为传输层的协议,是一个软件工程师素养的体现,也是面试中经常被问到的知识点。在此,我将TCP核心的一些问题梳理了一下,希望能帮到各位。001.能不能说一说TC...

Win10专业版无线网络老是掉线的问题

有一位电脑基地的用户,使用...

学习计算机网络需要掌握以下几方面基础知识

计算机基础知识操作系统:了解常见操作系统(如Windows、Linux)的基本操作和网络配置,例如如何设置IP地址、子网掩码、网关和DNS服务器等,以及如何通过命令行工具(如ping、tr...

网络工程师的圣经!世界级网工手绘268张图让TCP/IP直接通俗易懂

要把知识通俗地讲明白,真的不容易。——读者说TCP/IP从字面意义上讲,有人可能会认为TCP/IP是指TCP和IP两种协议。实际生活当中有时候也确实就是这两种协议。然而在很多情况下,它只是...

三分钟了解通信知识TCP与IP协议(含“通信技术”资料分享)

TCP/IPTCP/IP分层模型①应用层...

网闸与防火墙:网络安全设备的差异与应用

在网络安全领域,网闸(安全隔离网闸,GAP)和防火墙(Firewall)是两类重要的防护设备。尽管它们都服务于网络安全防护,但在设计理念、技术原理、安全效能及适用场景等方面存在显著差异,以下从五个维度...

S7-300的TCP/IP通信

一、首先在项目中创建2个S7-300的站点;二、硬件组态中,设置合适的TCP/IP地址,在同一网段内;...

西门子S7-1500 PLC的 MODBUS TCP通信

MODBUSTCP使MODBUS_RTU协议运行于以太网,MODBUSTCP使用TCP/IP和以太网在站点间传送MODBUS报文,MODBUSTCP结合了以太网物理网络和网络标准TC...

系统规划与管理师新版备考必备:第7章考点思维导图解析

备考系统规划与管理师的小伙伴们,福利又来啦!今天为大家带来《系统规划与管理师(第2版)》第7章考点的思维导图,助你高效梳理重点,让备考更有方向!...

TCP/IP、Http、Socket 有何区别与联系?

HTTP协议对应于应用层,Socket则是对TCP/IP协议的封装和应用(程序员层面上)。HTTP是应用层协议,主要解决如何包装数据。而我们平时说的最多的Socket是什么呢?实际上...

西门子PLC串口协议与以太网通信协议对比

西门子plc品牌众多,通信协议的类型就更多了,具体可分为串口协议和以太网通信协议两大类。...

网络编程懒人入门(十三):一泡尿的时间,快速搞懂TCP和UDP的区别

本文引用了作者Fundebug的“一文搞懂TCP与UDP的区别”一文的内容,感谢无私分享。1、引言...

程序员必备的学习笔记《TCP/IP详解(一)》

为什么会有TCP/IP协议在世界上各地,各种各样的电脑运行着各自不同的操作系统为大家服务,这些电脑在表达同一种信息的时候所使用的方法是千差万别。就好像圣经中上帝打乱了各地人的口音,让他们无法合作一样...

一文读懂TCP/IP协议工作原理和工作流程

简述本文主要介绍TCP/IP协议工作原理和工作流程。含义TCP/IP协议,英文全称TransmissionControlProtocol/InternetProtocol,包含了一系列构成互联网...

如何在 Windows 10 和 Windows 11 上重置 TCP/IP 堆栈

传输控制协议/Internet协议,通常称为TCP/IP,是您的WindowsPC如何与Internet上的其他设备进行通信的关键部分。但是当事情出错时会发生什么?你如何解决它?幸运的...

取消回复欢迎 发表评论: