oracle 和 mysql 和区别
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 和区别的更多相关文章
- 关系和非关系型数据库区别(以及oracle和mysql的区别)
一.关系型数据库 关系型数据库,是指采用了关系模型来组织数据的数据库. 关系模型是在1970年由IBM的研究员E.F.Codd博士首先提出的,在之后的几十年中,关系模型的概念得到了充分的发展并逐 ...
- 关系型数据库和非关系型数据库区别、oracle与mysql的区别
一.关系型数据库 关系型数据库,是指采用了关系模型来组织数据的数据库. 关系模型是在1970年由IBM的研究员E.F.Codd博士首先提出的,在之后的几十年中,关系模型的概念得到了充分的发展并逐 ...
- Oracle与MySQL的区别
1. Oracle是大型数据库而Mysql是中小型数据库,Oracle市场占有率达40%,Mysql只有20%左右,同时Mysql是开源的而Oracle价格非常高. 2. Oracle支持大并发,大访 ...
- Oracle与MySQL的区别对比
本文对数据库Oracle与MySQL进行了区别对比,其中从并发性.一致性.事务.数据持久性等十三方面进行了对比. 本文摘自 51cto 一.并发性 并发性是oltp数据库最重要的特性,但并发涉及到资源 ...
- Oracle,sqlserver,mySQl的区别和联系:
1.日期处理方式 2.对保留字和关键字的处理方式: Oracle,sqlserver,mySQl的保留字不可以用作列字段,关键字可以,但他们对关键字的处理方式又不同: Oracle:关键字作为列时:用 ...
- Oracle与MySQL使用区别
与MySQL通过创建不同的数据库来存储表 Oracle提出表空间(tablespace)的概念作为逻辑上的存储区域来存储表, 而不同的表空间由不同的用户来管理 用户可以授予权限或角色 举例: 使用PL ...
- Oracle和Mysql的区别 转载
一.并发性 并发性是oltp数据库最重要的特性,但并发涉及到资源的获取.共享与锁定. mysql:mysql以表级锁为主,对资源锁定的粒度很大,如果一个session对一个表加锁时间过长,会让其他se ...
- 3.oracle与mysql的区别
1.自动增长的数据类型处理 MYSQL有自动增长的数据类型,插入记录时不用操作此字段,会自动获得数据值.ORACLE没有自动增长的数据类型,需要建立一个自动增长的序列号,插入记录时要把序列号的 ...
- Oracle 和 MySQL的区别(不完整)
1. Oracle对单双引号要求的很死,一般不准用双引号,不然会报错.MySQL 单双引号都可以. 2. 事务提交方式:Oracle 默认手动提交,MySQL 默认自动提交. 3. 分页:MySQL有 ...
随机推荐
- jq03--基础函数
我们继续学习jq的一些函数,包括向jq对象添加.删除CSS属性以及遍历DOM树. 1.获取.设置CSS类 addClass()--向被选元素添加1个或多个类属性 .importance{font-we ...
- (转)python高级:列表解析和生成表达式
一.语法糖的概念 “糖”,可以理解为简单.简洁,“语法糖”使我们可以更加简洁.快速的实现这些功能. 只是Python解释器会把这些特定格式的语法翻译成原本那样复杂的代码逻辑 我们使用的语法糖有: if ...
- JavaMail学习之一-邮件传输协议
协议:规定好的格式就是协议.就像http协议有请求协议和响应协议,邮件传输也分为发.收邮件的协议. 邮件协议分3种: 发邮件的:SMTP (Simple Mail Transport Protoca ...
- 使用 Chrome 生成 UUID
打开Chrome,键入 Ctrl + Shift + J,打开 JS 控制台,然后输入下面的JS代码: function getGUID( ) { function _p8(s) { var p = ...
- 全网最详细使用Scrapy时遇到0: UserWarning: You do not have a working installation of the service_identity module: 'cannot import name 'opentype''. Please install it from ..的问题解决(图文详解)
不多说,直接上干货! 但是在运行爬虫程序的时候报错了,如下: D:\Code\PycharmProfessionalCode\study\python_spider\30HoursGetWebCraw ...
- Django之模型系统
Django模型简介 Django 模型是与数据库相关的,与数据库相关的代码一般写在 models.py 中 Django 支持 sqlite3, MySQL, oracle,PostgreSQL等数 ...
- sass中@的作用
总结一下sass中用到@的地方. 1.继承@extend SASS允许一个选择器,继承另一个选择器.比如,现有class1: .class1 { border: 1px solid #ddd; } c ...
- node服务端搭建学习笔记
咳咳,终于迈出这一步了...这篇文章将是边学边写的真正笔记...用于mark下学习过程中的点滴~ 开篇先把我学习参考的文章来源给出,以表示对前人的尊敬: https://github.com/nswb ...
- Term Weighting
对文本分词后,接下来需要对分词后的每个term计算一个权重,重要的term应该给与更高的权重.举例来说,“什么产品对减肥帮助最大?”的term weighting结果可能是: “什么 0.1,产品 0 ...
- Go 程序执行顺序
在一个 go 程序中通常包含:包.常量.变量.init().main()等元素,如果同时存在多个包,包之间存在依赖关系,每个包中存在多个 init 函数,每个文件中存在多个 init 函数,那么问题来 ...