最新Oracle 和 mysql 的对比参照----开发篇(转)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS MySQL,高可用系列 2核4GB
简介:   Oracle mysql 对比版本 Release 10.2.0.1.0 XE  windowsXP 5.

 

 

Oracle

mysql

对比版本

Release 10.2.0.1.0 XE  windowsXP

5.0.45-community-nt-log MySQL Community Edition (GPL)

当作计算器

SQL> select 1+1 from dual;

mysql> select 1+1;

mysql> select 1+1 from dual;

显示表结构

SQL> desc 表名

mysql> desc 表名;

SQL> describe 表名

mysql> describe 表名;

 

mysql> explain  表名;

注意:explain 也可以用来获取执行计划。

需要访问:

User_tables、user_tab_cols、USER_COL_COMMENTS、USER_INDEXES等等字典表。

mysql> show columns from 表名;

 

bin>mysqlshow 库名 表名

日期的概念

一个完全不同于字符串的类型。日期类型没有所谓的格式,日期就是日期,只有在显示的时候可以指定转换成的字符串的格式。绝对不会允许2008-00-00这种情况出现。对于日期转换为另一个日期相对比较简单,比如selecttrunc(sysdate) from dual;

可以方便的和字符串进行比较、转换 。允许0000-00-00这种情况出现作为null的替代品方便处理(个人不认为这样比较方便,反而给我造成困惑)。对于字符串转换为日期比较简单,比如CREATETABLE `datetime` (

 `dt` datetime NOT NULL default'0000-00-00 00:00:00',

  PRIMARY KEY  (`dt`)

);

INSERT INTO `datetime` VALUES('2008-01-01 00:00:00');

select * from `datetime`;

日期类型

date

datetime

Date

日期

Time

时间

Timestamp

如果表中其他字段变化,此类型的字段自动更新为当前系统时间。

Timestamp

保存了毫秒级别的时间

不清楚

日期函数

SQL> select trunc(sysdate) from dual;

mysql> select curdate();

mysql> select current_date;

SQL> select sysdate from dual;

mysql> select sysdate();

mysql> select now();

SQL> select to_char(sysdate,'HH24:Mi:SS') from dual;

注意此处返回结果为字符串,而不是日期类型。Oracle不提供和mysql中time类型相应的类型。

mysql> select current_time;

mysql> select curtime();

注意:此处返回的是time类型。就是时间17:22:14这种时间。Oracle中没有此类型。

毫秒级别:

SQL> select current_timestamp from dual;

需要使用函数MICROSECOND。目前还不会。

日期格式化

SQL> select to_char(sysdate,'yyyy-mm-dd') from dual;

mysql> select date_format(now(),'%Y-%m-%d');

SQL> select to_char(sysdate,'hh24-mi-ss') from dual;

mysql> select time_format(now(),'%H-%i-%S');

日期函数

(增加一天)

SQL> select sysdate+1 from dual;

结果:2008-2-20 19:34:27

mysql> select date_add(now(),interval 1 day);

mysql>select now()+interval 1 day;

日期函数

(增加一个月)

SQL> select add_months(sysdate,1) from dual;

结果:2008-3-19 19:34:27

mysql> select date_add(now(),interval 1 month);

mysql>select now()+interval 1 month;

别名

SQL> select 1 as a from dual;

mysql> select 1 as a;

SQL> select 1 a from dual;

mysql> select 1 a;

字符串截取函数

SQL> select substr('abcdefg',1,5) from dual;

结果:abcde

mysql> selectsubstr('abcdefg',1,5);

结果:abcde

去除空格:

select trim('abc   ') from dual;

去除空格:

select trim('abc   ') fromdual;

字符串拼接:

SELECT CONCAT('a',' test') from dual;

结果:a test

SELECT CONCAT('a',' test');

结果:a test

注意oracle中||为字符串拼接

select 'a'||' test' from dual;

结果:a test

注意mysql中||为或操作符。

select 0||1;

结果1;

Select 0||0;

结果0。

判断是否包含:

select instr('abcd','bcd') from dual;

结果:2

mysql> SELECT INSTR('foobarbar', 'bar');

结果:4

另有正则表达式。

另有SUBSTRING_INDEX(str,delim,count)函数

执行sql脚本

SQL >@a.sql

1:mysql> source a.sql

执行外部shell脚本

SQL>host test.sh

目前还不会

SQL>! cd ..

改表名

SQL> alter table T rename to T1;

mysql> alter table t rename t1;

mysql> alter table T1 rename to  T;

执行命令

;<回车>

;<回车>

/

go

r

ego

run

 

distinct用法

SQL> select distinct 列1 from 表1;

mysql> select distinct 列1 from 表1;

SQL> select distinct 列1,列2 from 表1;

mysql> select distinct 列1,列2 from 表1;

注释

--

--

/* */

/*与*/

REM

#

限制返回记录条数为5条

SQL> select * from 表名 where rownum<=5;

mysql> select * from 表名 limit 5;

分页查询

select *

from (

select row_.*, rownum rownum_

from (

yourSqlHere ) row_

where rownum <= 100)

where rownum_ > 20;

select * from limit 20,100;

外连接

 (+)

left join

LEFT OUTER JOIN

left outer join

RIGHT OUTER JOIN

 

查询索引

SQL> select index_name,table_name from user_indexes;

mysql> show index from 表名 [FROM 库名];

通配符

“%”

“%”和“_”

如果存在则更新,否则插入

Merge into

Replace into

参见,mysql的replace没有oracle的merge严格:

http://www.bitbybit.dk/carsten/blog/?p=128#comment-50048

SQL语法

SELECT selection_list 选择哪些列

SELECT selection_list 选择哪些列

FROM table_list 从何处选择行

FROM table_list 从何处选择行

WHERE primary_constraint 行必须满足什么条件

WHERE primary_constraint 行必须满足什么条件

GROUP BY grouping_columns 怎样对结果分组

注意:oracle如果需要排序必须指定order by 子句。

GROUP BY grouping_columns 怎样对结果分组

注意:即使不存在order by子句,mysql也会按照group by 的列进行排序。甚至还能为group by 语句指定asc/desc子句。

HAVING secondary_constraint 行必须满足的第二条件

HAVING secondary_constraint 行必须满足的第二条件

ORDER BY sorting_columns 怎样对结果排序

ORDER BY sorting_columns 怎样对结果排序

Oracle的结果集限定语句见:”分页查询”

注意:oracle的rownum和mysql的Limit完全不同。

LIMIT count 结果限定

对not in null的处理,是关于三值逻辑的问题。

CREATE TABLE a

( code INT );

INSERT INTO a

     VALUES (2);

INSERT INTO a

     VALUES (NULL);

SELECT 1

  FROM DUAL

 WHERE 1 NOT IN (SELECT code  FROM a);

结果:无返回结果。

CREATE TABLE a

( code INT );

INSERT INTO a

     VALUES (2);

INSERT INTO a

     VALUES (NULL);

SELECT 1

  FROM DUAL

 WHERE 1 NOT IN (SELECT code FROM a);

结果:无返回结果

对not exists的处理

CREATE TABLE a

( code INT );

INSERT INTO a

     VALUES (2);

INSERT INTO a

     VALUES (NULL);

SELECT 1

  FROM DUAL

 WHERE NOT EXISTS (SELECT 1

                     FROM a WHERE a.code = 1);

结果:1

CREATE TABLE a

( code INT );

INSERT INTO a

     VALUES (2);

INSERT INTO a

     VALUES (NULL);

SELECT 1

  FROM DUAL

 WHERE NOT EXISTS (SELECT 1

                     FROM aWHERE a.code = 1);

结果:1

获取sql语句执行计划

SQL>EXPLAIN PLAN FOR   select * from t;

然后

SQL>select * from table(DBMS_XPLAN.DISPLAY)

Mysql> explain select * from t;

执行计划对照

全表扫描: TABLE ACCESS FULL

Type=all

Where条件过滤:FILTER

Extra=Using where

排序:SORT ORDER BY

Extra=Using filesort

   
   

事务管理

默认不自动提交

innoDB支持事务

默认自动提交autocommit

阻塞读取方式

 

 

Unique index的区别。

又是关于三值逻辑的问题。

CREATE TABLE hr.t (

   ID INT NOT NULL,

   DATA CHAR(30) DEFAULT NULL,

   UNIQUE (ID, DATA)

  );

 

INSERT INTO hr.t

     VALUES (1, NULL);

 

INSERT INTO hr.t

     VALUES (1, NULL);

mysql> CREATE TABLE t (

   ID INT NOT NULL,

   DATA CHAR(30) DEFAULT NULL,

   UNIQUE (ID, DATA)

  );

INSERT INTO t

     VALUES (1, NULL);

INSERT INTO t

     VALUES (1, NULL);

select * from t;

Query OK, 0 rows affected

Query OK, 1 row affected

Query OK, 1 row affected

+----+------+

| ID | DATA |

+----+------+

|  1 | NULL |

|  1 | NULL |

+----+------+

2 rows in set

ORA-00001: 违反唯一约束条件 (HR.SYS_C003999)

再次感谢yueliangdao0608对mysql内容的支持。

http://blog.csdn.net/fenixshadow/article/details/2106546

 

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
7月前
|
Oracle 关系型数据库 MySQL
Oracle linux 8 二进制安装 MySQL 8.4企业版
Oracle linux 8 二进制安装 MySQL 8.4企业版
270 1
|
9月前
|
SQL Oracle 关系型数据库
MySQL 和 Oracle 的区别?
本文对比了Oracle和MySQL数据库的多个方面。Oracle适用于大型数据库,支持高并发和大访问量,市场占有率为40%,安装占用空间较大,约3G;而MySQL适合中小型应用,是开源免费的,安装仅需152M。两者在主键生成、字符串处理、SQL语句、事务处理等方面存在差异。Oracle功能更为强大,尤其在企业级应用中表现突出,而MySQL则以简单易用见长。
1168 7
MySQL 和 Oracle 的区别?
|
8月前
|
Oracle 关系型数据库 MySQL
使用崖山YMP 迁移 Oracle/MySQL 至YashanDB 23.2 验证测试
这篇文章是作者尚雷关于使用崖山YMP迁移Oracle/MySQL至YashanDB 23.2的验证测试分享。介绍了YMP的产品信息,包括架构、版本支持等,还详细阐述了外置库部署、YMP部署、访问YMP、数据源管理、任务管理(创建任务、迁移配置、离线迁移、校验初始化、一致性校验)及MySQL迁移的全过程。
|
10月前
|
监控 Oracle 关系型数据库
Mysql、Oracle审计日志的开启
通过上述步骤,可以在 MySQL 和 Oracle 数据库中启用和配置审计日志。这些日志对于监控数据库操作、提高安全性和满足合规性要求非常重要。确保正确配置审计参数和策略,定期查看和分析审计日志,有助于及时发现并处理潜在的安全问题。
640 11
|
11月前
|
JavaScript 安全 Java
java版药品不良反应智能监测系统源码,采用SpringBoot、Vue、MySQL技术开发
基于B/S架构,采用Java、SpringBoot、Vue、MySQL等技术自主研发的ADR智能监测系统,适用于三甲医院,支持二次开发。该系统能自动监测全院患者药物不良反应,通过移动端和PC端实时反馈,提升用药安全。系统涵盖规则管理、监测报告、系统管理三大模块,确保精准、高效地处理ADR事件。
505 1
|
监控 前端开发 Java
【技术开发】接口管理平台要用什么技术栈?推荐:Java+Vue3+Docker+MySQL
该文档介绍了基于Java后端和Vue3前端构建的管理系统的技术栈及功能模块,涵盖管理后台的访问、登录、首页概览、API接口管理、接口权限设置、接口监控、计费管理、账号管理、应用管理、数据库配置、站点配置及管理员个人设置等内容,并提供了访问地址及操作指南。
|
SQL JavaScript 关系型数据库
node博客小项目:接口开发、连接mysql数据库
【10月更文挑战第14天】node博客小项目:接口开发、连接mysql数据库
|
SQL 关系型数据库 MySQL
PHP与MySQL协同工作的艺术:开发高效动态网站
在这个后端技术迅速迭代的时代,PHP和MySQL的组合仍然是创建动态网站和应用的主流选择之一。本文将带领读者深入理解PHP后端逻辑与MySQL数据库之间的协同工作方式,包括数据的检索、插入、更新和删除操作。文章将通过一系列实用的示例和最佳实践,揭示如何充分利用这两种技术的优势,构建高效、安全且易于维护的动态网站。
|
前端开发 Java 数据库连接
表白墙/留言墙 —— 中级SpringBoot项目,MyBatis技术栈MySQL数据库开发,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
本文是一份全面的表白墙/留言墙项目教程,使用SpringBoot + MyBatis技术栈和MySQL数据库开发,涵盖了项目前后端开发、数据库配置、代码实现和运行的详细步骤。
314 0
表白墙/留言墙 —— 中级SpringBoot项目,MyBatis技术栈MySQL数据库开发,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
|
Oracle 关系型数据库 MySQL
shell获取多个oracle库mysql库所有的表
请注意,此脚本假设你有足够的权限访问所有提到的数据库。在实际部署前,请确保对脚本中的数据库凭据、主机名和端口进行适当的修改和验证。此外,处理数据库操作时,务必谨慎操作,避免因错误的脚本执行造成数据损坏或服务中断。
192 0

推荐镜像

更多
下一篇
oss云网关配置