1、mysql 有枚举类型,oracle 没有; mysql不支持number、varchar2类型,报错。
2、oracle 支持全外连接,mysql 不支持
  select e.ename, e.sal, d.dname from emp e full join dept d on e.deptno=d.deptno;
3、mysql 不支持交集和差集用法
  select * from emp where sal>2500 intersect select * from emp where job='MANAGER';
  select * from emp where job='MANAGER' minus select * from emp where sal>2500;
4、oracle 两个日期可以直接相减,结果为相差的天数;mysql 也可以相减,但结果无意义。
  select now()-'2018-7-1'; // 20180714011927
  select sysdate-to_date('2018-7-1', 'yyyy-mm-dd') from dual; // 13.0697453703704
  mysql 要使用datediff()函数,oracle 没有这个函数
  select datediff(now(), '2018-7-1'); // 13
5、oracle 的 nvl 函数对应mysql 是ifnull 函数;oracle 可以使用中文别名排序,mysql必须是英文别名才可以排序
  select ename, (nvl(sal, 0)+ nvl(comm, 0))*12 "年薪" from emp order by "年薪" desc;
  select ename, (ifnull(sal, 0)+ ifnull(comm, 0))*12 as yearly_salary from emp order by yearly_salary desc;
6、oracle 连接字段使用 ||, mysql 使用函数 concat()。
  select concat(ename,',', empno) from emp; -- oracle 也有这个函数,但只能传两个参数
7、插入查询删除时日期时间格式不同
  oracle:
  insert into emp(empno,hiredate) values(11, to_date('1997-7-1', 'yyyy-mm-dd'));
  select * from emp where hiredate = to_date('1997-7-1', 'yyyy-mm-dd');
  delete from emp where hiredate = to_date('1997-7-1', 'yyyy-mm-dd');

  mysql:
  insert into emp(empno,hiredate) values(11, '1997-7-1'); -- 插入日期时间方式不同
  select * from emp where hiredate = '1997-7-1'; -- 查询日期时间方式不同
  delete from emp where hiredate = '1997-7-1';
8、oracle 插入多行的语法:

  create table test (name VARCHAR2(10));
  insert all
  into test values('天')
  into test values('道')
  into test values('酬')
  into test values('勤')
  select * from dual;
  或者
  insert into test
  select '孟' from dual
  union
  select '子' from dual;

  mysql 插入多行的语法:
  create table test (name VARCHAR(10));
  INSERT into test VALUES('天'),('道'),('酬'),('勤');

9、mysql 不支持从回收站删除表
  drop table test;
  create table test(id varchar(10));
  drop table test purge;
10、修改表名语法不同
  oracle:
    rename emp to emp1;
    rename emp1 to emp;
  mysql:
    alter table student rename stu;
    alter table stu rename student;
11、mysql
  修改字段类型语法:alter table student modify column name varchar(10) null default '小明' commt '姓名' after id;
        或者:alter table student modify name varchar(10);
  oracle
  修改字段类型语法:alter table student modify(name varchar2(10)); -- mysql不能加括号
12、mysql 可以省略 from dual ,oracle 不可以省略。
13、oracle 支持 delete tablename,mysql 必须写delete from tablename。
14、select e.ename, e.sal, d.dname from emp e join dept d; // oracle语法错误,没有笛卡尔积;mysql可以执行,有笛卡尔积

15、mysql 不支持
update emp set (job, sal, comm) = (select job, sal, comm from emp where ename='SCOTT') where ename='SMITH';

oracle 和 mysql 和区别的更多相关文章

  1. 关系和非关系型数据库区别(以及oracle和mysql的区别)

    一.关系型数据库 关系型数据库,是指采用了关系模型来组织数据的数据库.    关系模型是在1970年由IBM的研究员E.F.Codd博士首先提出的,在之后的几十年中,关系模型的概念得到了充分的发展并逐 ...

  2. 关系型数据库和非关系型数据库区别、oracle与mysql的区别

    一.关系型数据库 关系型数据库,是指采用了关系模型来组织数据的数据库.    关系模型是在1970年由IBM的研究员E.F.Codd博士首先提出的,在之后的几十年中,关系模型的概念得到了充分的发展并逐 ...

  3. Oracle与MySQL的区别

    1. Oracle是大型数据库而Mysql是中小型数据库,Oracle市场占有率达40%,Mysql只有20%左右,同时Mysql是开源的而Oracle价格非常高. 2. Oracle支持大并发,大访 ...

  4. Oracle与MySQL的区别对比

    本文对数据库Oracle与MySQL进行了区别对比,其中从并发性.一致性.事务.数据持久性等十三方面进行了对比. 本文摘自 51cto 一.并发性 并发性是oltp数据库最重要的特性,但并发涉及到资源 ...

  5. Oracle,sqlserver,mySQl的区别和联系:

    1.日期处理方式 2.对保留字和关键字的处理方式: Oracle,sqlserver,mySQl的保留字不可以用作列字段,关键字可以,但他们对关键字的处理方式又不同: Oracle:关键字作为列时:用 ...

  6. Oracle与MySQL使用区别

    与MySQL通过创建不同的数据库来存储表 Oracle提出表空间(tablespace)的概念作为逻辑上的存储区域来存储表, 而不同的表空间由不同的用户来管理 用户可以授予权限或角色 举例: 使用PL ...

  7. Oracle和Mysql的区别 转载

    一.并发性 并发性是oltp数据库最重要的特性,但并发涉及到资源的获取.共享与锁定. mysql:mysql以表级锁为主,对资源锁定的粒度很大,如果一个session对一个表加锁时间过长,会让其他se ...

  8. 3.oracle与mysql的区别

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

  9. Oracle 和 MySQL的区别(不完整)

    1. Oracle对单双引号要求的很死,一般不准用双引号,不然会报错.MySQL 单双引号都可以. 2. 事务提交方式:Oracle 默认手动提交,MySQL 默认自动提交. 3. 分页:MySQL有 ...

随机推荐

  1. 大数据技术之_19_Spark学习_04_Spark Streaming 应用解析小结

    ========== Spark Streaming 是什么 ==========1.SPark Streaming 是 Spark 中一个组件,基于 Spark Core 进行构建,用于对流式进行处 ...

  2. 【STM32H7教程】第14章 STM32H7的电源,复位和时钟系统

    完整教程下载地址:http://forum.armfly.com/forum.php?mod=viewthread&tid=86980 第14章       STM32H7的电源,复位和时钟系 ...

  3. js实现隔行变色-------Day40

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/marSmile_tbo/article/details/31837367 就这样開始了自己的第二个项 ...

  4. C语言 for循环之阶乘的算法

    int n; scanf("%d", &n); int fact = 1; int i = 1; while ( i <= n ) { fact *=i; i++; ...

  5. TCP与UDP的差别以及TCP三次握手、四次挥手

    UDP: 1.UDP面向报文,无需建立连接,不可靠,数量小,高层就解决差错重传,无需拥塞控制 2.支持音频.视频传输 3.检查和检验UDP包头和数据和伪首部 4.分组开销小(头部8个字节),提供最大努 ...

  6. 解决ajax跨域问题的一种方法

    解决ajax跨域问题的一种方法 前后端分离经常用json来传输数据,比较常见的问题就有ajax跨域请求的错误问题,这里是我的一种解决方法: 在java中加入如下的注解类: import org.spr ...

  7. JDK1.10+scala环境的搭建之linux环境(centos6.9)

    ---恢复内容开始--- 第一步:安装jdk1.10版本 进入网页 http://oracle.com/technetwork/java/javase/downloads/index.html  下载 ...

  8. WINDOWS 下 修改APACHE 并发数

    某次,配置大型站点.日IP过2W. 刚解析完,就特别卡,每个页面都是慢吞吞的打开的. 至少30秒.但是,3389进入服务器很快,CPU 内存都是几乎为0. 想到WINDOWS下使用的是APACHE,并 ...

  9. 关于 IOC和spring基本配置详解

    Spring 中的两个概念 IOC控制反转(也叫依赖注入DI): AOP面向切面编程: 控制反转:当某个java对象需要(依赖)另一个java对象是,不是直接创建依赖对象,而是由实现IOC的容器来创建 ...

  10. 《Mysql技术内幕,Innodb存储引擎》——Innodb体系结构

    Innodb体系结构 Innodb存储引擎主要包括内存池以及后台线程. 内存池:多个内存块组成一个内存池,主要维护进程/线程的内部数据.缓存磁盘数据,修改文件前先修改内存.redo log 后台线程: ...