MySQL和Oracle开发差异
1) 数据类型差异
|
Oracle |
MySQL |
注释 |
|
单独创建序列来实现 |
自动增长的数据类型 |
|
|
varchar2 |
varchar |
|
|
number |
tinyint,smallint,mediumint,int,bigint float,double |
|
|
clob |
text,mediumtext,longtext |
|
|
date |
datetime |
|
|
无 |
enum |
|
|
raw |
binary(n),varbinary(n) |
|
|
无 |
bit(n) |
|
|
blob |
blob,mediumblob,longblob |
2) 内建函数差异
|
Oracle |
MySQL |
注释 |
|
length |
char_length |
|
|
substr |
substring |
|
|
nvl |
ifnull |
|
|
decode |
case |
|
|
to_char |
date_format,time_format |
|
|
to_date |
str_to_date |
|
|
trunc |
cast |
|
|
to_number |
cast |
|
|
date+/-n |
date_add |
|
|
date1-date2 |
datediff |
3) SQL语句差异
|
操作 |
Oracle |
MySQL |
|
创表指定表空间 |
create table…tablespace x |
没有表空间,使用默认存储引擎 |
|
CTAS建表 |
create table…as select…不能新增字段和改变字段属性 |
create table t1(a int,b int) as select a,b,a,b from t2可以选择新的字段和字段属性 |
|
表结构复制 |
create table t1 as select * from t2 where 1=0,只复制字段定义,不包括约束 |
create table t1 like t2,复制包括约束 |
|
全局分区索引 |
create index…global partition by |
无 |
|
重命名列 |
alter table t1 rename c1 to c2 |
alter table t1 change c1 c2 |
|
修改列类型 |
alter table t1 modify c1 integer |
alter table t1 change c1 c1 int |
|
修改列缺省值 |
alter table t1 modify c1 default 0 |
alter table t1 change c1 c1 int default 0 |
|
修改列非空 |
alter table t1 modify c1 not null |
alter table t1 change c1 c1 int not null |
|
重命名表 |
rename t1 to t2 |
alter table t1 rename t2 rename table t1 to t2 |
|
删除索引 |
drop index idx1 |
alter table t1 drop index idx1 drop index idx1 on t1 |
|
重命名索引 |
alter index idx1 rename to idx2 |
删除重建 |
|
重建索引 |
alter index idx1 rebuild |
无 |
|
禁用索引 |
alter index idx1 unusable |
无 |
|
删除表 |
drop table t1,如果表不存在报错 |
drop table if exists t1,判断表是否存在,存在删除,不存在不报错 |
|
重命名视图 |
rename v1 to v2 |
rename view v1 to v2 |
|
左右连接 |
select * from t1,t2 where t1.c1=t2.c2(+); select * from t1,t2 where t1.c1(+)=t2.c2; |
select * from t1 left join t2 on t1.c1=t2.c2; select * from t1 right join t2 on t1.c1=t2.c2; |
|
交集 |
select intersect select |
select inner join select;使用inner join代替 |
|
差集 |
Select minus select |
select left join where,使用left join where代替 |
|
获取固定值 |
select 1 from dual |
select 1 |
|
字段连接 |
select c1||c2 from t1 |
select concant(c1,c2) from t1 |
|
结果子查询 |
select * from (select * from t) |
select * from (select * from t) t1 结果集需要有别名 |
|
Merge |
merge into |
replace into |
|
行号 |
rownum |
无,需要使用用户变量来实现 |
|
分析函数 |
max() over() min() over() …… |
无,需要自行实现 |
|
位图索引 |
create bitmap index |
无 |
|
Top查询 |
select * from (select rownum from t1 order by c1) where rownum>=1 and rownum<=5 |
select * from t1 order by c1 limit 5 |
|
语句内部临时表 |
with as |
无 |
|
创建存储过程/ |
create or replace procedure |
create procecure |
|
创建函数 |
create or replace function |
create function |
|
创建视图 |
create or replace view |
create view |
|
创建触发器 |
create or replace trigger |
create trigger |
|
创建包 |
create or replace package |
无 |
|
创建用户 |
create user u1 identified by p1 default tablespace x temporary tablespace y |
create user u1 identified by p1 |
|
修改密码 |
alter user u1 identified by p2 |
mysqladmin -u u1 -p p1 password p2 |
|
大小写 |
不区分 |
缺省数据库、表名区分大小写,列名不区分; 可以设置lower_case_table_names=1都不分区 |
3) 子程序差异
Oracle中创建的匿名PL/SQL块、PL/SQL函数和存储过程,MySQL需要全部重新实现
MySQL和Oracle开发差异的更多相关文章
- mybatis中mysql和oracle的差异
1.applicationContext.xml中的配置差异: 在applicationContext.xml的数据源dataSource的配置中,mysql数据库需要心跳包的配置,而oracle中不 ...
- SQLServer、MySQL、Oracle语法差异小集锦
一.差异集锦 在建表的时候,只有自增的语法不同. 下面给出3种数据库通用的建表与初始化测试语句: CREATE TABLE Country( Id int PRIMARY KEY, Name ) ); ...
- MySQL,Oracle,PostgreSQL通过web方式管理维护, 提高开发及运维效率
在开发及项目运维中,对数据库的操作大家目前都是使用客户端工具进行操作,例如MySQL的客户端工具navicat,Oracle的客户端工具 PL/SQL Developer, MSSQL的客户端工具查询 ...
- 开发中mysql和oracle的区别
首先就不描述mysql与oracle在整个数据库系统上的区别了,仅从程序员开发的角度来说: 1.主键: mysql一般会用到一个自增的属性,例如设置一个id字段,类型设置为auto increment ...
- MySQL,Oracle,PostgreSQL,mongoDB 通过web方式管理维护, 提高开发及运维效率
在开发及项目运维中,对数据库的操作大家目前都是使用客户端工具进行操作,例如MySQL的客户端工具navicat,Oracle的客户端工具 PL/SQL Developer, MSSQL的客户端工具查询 ...
- 谈谈 mysql和oracle的使用感受 -- 差异
之前一直使用mysql作为存储数据库,虽然中间偶尔使用sqlite作为本地数据库存储,但没有感觉多少差别. 后来遇上了oracle,且以其作为主要存储,这下就不得不好好了解其东西了.oracle作为商 ...
- MySQL与Oracle 差异比较之四条件循环语句
循环语句 编号 类别 ORACLE MYSQL 注释 1 IF语句使用不同 IF iv_weekly_day = 'MON' THEN ii_weekly_day := 'MON';ELS ...
- 【无私分享:ASP.NET CORE 项目实战(第十二章)】添加对SqlServer、MySql、Oracle的支持
目录索引 [无私分享:ASP.NET CORE 项目实战]目录索引 简介 增加对多数据库的支持,并不是意味着同时对多种数据库操作,当然,后面,我们会尝试同时对多种数据库操作,这可能需要多个上下文,暂且 ...
- qlserver、Mysql、Oracle三种数据库的优缺点总结
这篇文章主要介绍了sqlserver.Mysql.Oracle三种数据库的优缺点总结,需要的朋友可以参考下 一.sqlserver优点:易用性.适合分布式组织的可伸缩性.用于决策支持的数据仓库功能 ...
随机推荐
- Floodlight 处理交换机增加/移除过程
Floodlight 使用的是Netty架构,在Controller.java 入口函数中显示创建ServerBootstrap,设置套接字选项,ChannelPipeline,此时监听套接 ...
- go编程基础
可见性规则: go语言,根据函数名首字母大小写区分private,和pulic. 函数名首字母小写为private 函数名首字母大写为public
- 深入分析redis cluster 集群
深入分析redis cluster 集群安装配置详解 下面小编来为各位介绍一篇深入分析redis cluster 集群安装配置详解,如果你希望做数据库集群就可以来看看此文章的哦. http://rub ...
- 读一读Scktsrvr.exe的源程序
读一读Scktsrvr.exe的源程序 使用DELPHI做多层开发的朋友们都应该对Scktsrvr.exe这个程序不陌生的,Borland公司在DELPHI中给出了它的源代码.这是一个900来行的程序 ...
- 腾讯文学动作密集 疑为手Q发力移动阅读铺路
移动互联网的门票之争并未结束,百度收购91无线,阿里投资新浪微博.UC浏览器,网易推易信.云音乐等等,都是互联网巨头争夺移动互联网门票的最佳案例.不过,上述任何巨头都不可忽视腾讯这个“狠角色” ...
- Delphi “Invalid floating point operation.”错误的解决方法(使用System单元提供的Set8087CW函数禁用浮点异常)
这两天用webbrower写东西,有时候打开SSL加密网站时会出现”Invalid floating point operation.”的错误,上网搜了下,把解决方法贴上. 导致原因 在Delphi2 ...
- 做一个牛XX的身份证号验证类(支持15位和18位)
原文:做一个牛XX的身份证号验证类(支持15位和18位) #region 是否合法的中国身份证号码 protected bool IsChineseID() { if (str.Length == 1 ...
- Android笔记二十七.Service组件入门(一).什么是Service?
转载请表明出处:http://blog.csdn.net/u012637501(嵌入式_小J的天空) 一.Service 1.Service简单介绍 Service为Android四大组件之中 ...
- 新出台的治理iMessage垃圾短信的规则
工信部拟制定<通信短信息服务管理规定>,为治理垃圾短信提供执法根据.当中,对于苹果iMessage垃圾信息泛滥现象,工信部也将跟踪研究技术监測和防范手段.这意味着长期以来处于监管" ...
- SRM 638 Div2
2333... 因为TC过少的参与者.加上不断fst 我掉了div2该. 幸运的是完成的背div1该.. 250 水的问题 500 水的问题.. 直接bfs扩展即可了 注意判重. 我还用康托展开了真 ...