MySQL和Oracle的一些区别
- 自动增长的数据类型处理
MySQL有自动增长的数据类型,插入记录时不用操作此字段,会自动获得数据值。Oracle没有自动增长的数据类型,需要建立一个自动增长的序列号,插入记录时要把序列号的下一个值赋于此字段。
CREATE SEQUENCE 序列号的名称 (最好是表名+序列号标记)INCREMENT BY 1 START WITH 1 MAXVALUE 99999 CYCLE NOCACHE;//其中最大的值按字段的长度来定, 如果定义的自动增长的序列号 NUMBER(6) , 最大值为999999INSERT 语句插入这个字段值为: 序列号的名称.NEXTVAL
- 单引号的处理
MySQL里可以用双引号包起字符串,Oracle里只可以用单引号包起字符串。在插入和修改字符串前必须做单引号的替换:把所有出现的一个单引号替换成两个单引号。 - 分页的SQL语句的处理
MySQL处理翻页的SQL语句比较简单,用LIMIT
。Oracle分页的SQL语句就比较繁琐了。每个结果集只有一个ROWNUM字段标明它的位置, 并且只能用ROWNUM<100, 不能用ROWNUM>80。
SELECT ID, [FIELD_NAME,...]
FROM TABLE_NAME
WHERE ID IN ( SELECT ID FROM (SELECT ROWNUM AS NUMROW, ID FROM TABLE_NAME WHERE 条件1 ORDER BY 条件2) WHERE NUMROW > 80 AND NUMROW < 100 )
ORDER BY 条件3;
- 长字符串的处理
长字符串的处理Oracle也有它特殊的地方。INSERT和UPDATE时最大可操作的字符串长度小于等于4000个单字节, 如果要插入更长的字符串, 请考虑字段用CLOB类型,方法借用ORACLE里自带的DBMS_LOB程序包。插入修改记录前一定要做进行非空和长度判断,不能为空的字段值和超出长度字段值都应该提出警告,返回上次操作。 - 日期字段的处理
MySQL日期字段分DATE和TIME两种,Oracle日期字段只有DATE,包含年月日时分秒信息,用当前数据库的系统时间为SYSDATE, 精确到秒,或者用字符串转换成日期型函数
TO_DATE('2001-08-01','YYYY-MM-DD')
日期字段的数学运算公式有很大的不同。MySQL找到离当前时间7天用 DATE_FIELD_NAME > SUBDATE(NOW(),INTERVAL 7 DAY)ORACLE找到离当前时间7天用 DATE_FIELD_NAME >SYSDATE - 7;
空字符的处理
MySQL的非空字段也有空的内容,Oracle里定义了非空字段就不容许有空的内容。按MySQL的NOT NULL来定义Oracle表结构, 导数据的时候会产生错误。因此导数据时要对空字符进行判断,如果为NULL或空字符,需要把它改成一个空格的字符串。字符串的模糊比较
MySQL里用 字段名 like '%字符串%',Oracle里也可以用 字段名 like '%字符串%' 但这种方法不能使用索引, 速度不快,用字符串比较函数 instr(字段名,'字符串')>0 会得到更精确的查找结果。程序和函数里,操作数据库的工作完成后请注意结果集和指针的释放。
MySQL和Oracle的一些区别相关推荐
- mysql 、oracle存储过程语法区别
mysql .oracle存储过程语法区别 1. 条件语句:mysql使用elseif关键字,oracle是elsif关键字: oracle: if表达式 then 表达式: elsif 表达式: ...
- MySQL与Oracle的应用区别
关系型数据库(Oracle与MySQL优缺点.使用区别) MySQL的特点 1.性能卓越,服务稳定,很少出现异常宕机: 2.开放源代码无版本制约,自主性及使用成本低: 3.历史悠久,社区和用户非常活跃 ...
- mysql和oracle有什么区别
转自:微点阅读 www.weidianyuedu.com 1. mysql和oracle都是关系型数据库,可以应用于各种平台.我们用的oracle的版本是oracle11g ,用的mysql的版本是m ...
- MySQL与Oracle的语法区别详细对比 (转)
Oracle和mysql的一些简单命令对比 1) SQL> select to_char(sysdate,'yyyy-mm-dd') from dual; SQL> select to_c ...
- mysql和oracle的语法区别
最近需要迁移项目,将数据库由Oracle改为MySQL.由于两者的语法有部分不一样,所以需要把Oracle中能用但MySQL中不能用的函数/类型等改为MySQL中能用的,以下是总结出的部分语法区别: ...
- mysql 和 oracle 的一些区别
1.seq 在oracle中获取下一个ID可以用seq,在mysql中可以设置某列自增 但是在同时添加主从表是设置自增不好在同一个事物中处理. 结合网上提供的方法,这里写了个可以获得每个表的seq的 ...
- 总结MySQL和Oracle的语法区别
文章目录 1.时间函数 2.空值返0 3.长度函数 4.条件函数 5.trunc()函数 6.字符串整型转换函数 7.引号 8.字符串连接符 9.空数据排序 10.表(左/右)关联 11.merge ...
- MySQL与ORACLE 存储过程的区别
存储过程&Function 编号 类别 ORACLE MYSQL 注释 1 创建存储过程语句不同 create or replace procedure P_ADD_FAC( id_fa ...
- MySql和Oracle数据库的区别?
查询当前所有的表 SQL> select * from tab; SQL> select * from cat where table_type='TABLE';//可能会有view SQ ...
最新文章
- 更快更强,谷歌提出SWideRNet:全景分割新标杆来啦!
- 一个fork的面试题
- 图解SQL基础知识,小白也能看懂的SQL文章!
- mysql,gone away, hy000, reconnect,Mysql大sql文件导入
- python变量定义必须赋值_Python3单行定义多个变量或赋值方法
- Android经常使用的五种弹出对话框
- fanuc机器人编程手册_是谁需要G代码编程机器人?
- 消息中间件学习总结(9)——RocketMQ与kafka差异比较分析
- 结构体05:结构体做函数参数
- 13. Django基础:admin后台管理
- amd编码器 hevc_Bandicam支持Nvidia NVENC编码器(H264, HEVC) - Bandicam(班迪录屏)
- lisp 计算三点的夹角_平面三点计算夹角
- mysql sin度数正玄值_正弦值角度对照表
- 微商引流脚本,微商怎样选择正确的引流脚本?
- 【转自人人】本科生如何发表论文
- MCU实现低功耗注意事项
- A Deep Learning-Based Remaining Useful Life Prediction Approach for Bearings 基于深度学习的轴承剩余寿命预测
- 请问什么叫纹波?怎样测量纹波?
- 浙江经信公布人工智能5大榜单 网易易盾内容安全解决方案上榜
- matlab二阶节的系数,如何利用matlab求解矩阵系数的二阶微分方程
热门文章
- 指针应用时的注意事项
- 趣学 C 语言(五)—— 内存管理
- 深度学习基础(七)—— Gibbs 采样
- C 标准库——cmath/math.h
- select * 排除字段_interesting数据库查找语句Select还能这样用
- python的优点有哪些-python的优点和缺点是什么|python有哪些优缺点 - PS下
- 自学python要看哪些书-学习机器学习应该看哪些书籍?
- python读音有道-centos7安装有道词典(不能发音和取词)
- python一般的基础代码-Python中的变量,一切代码的基础,你掌握了吗
- python有什么用途-Python是什么 Python的用处