1. 自动增长的数据类型处理
    MySQL有自动增长的数据类型,插入记录时不用操作此字段,会自动获得数据值。Oracle没有自动增长的数据类型,需要建立一个自动增长的序列号,插入记录时要把序列号的下一个值赋于此字段。
 CREATE SEQUENCE 序列号的名称 (最好是表名+序列号标记)INCREMENT BY 1        START   WITH  1 MAXVALUE     99999        CYCLE        NOCACHE;//其中最大的值按字段的长度来定, 如果定义的自动增长的序列号 NUMBER(6) , 最大值为999999INSERT 语句插入这个字段值为: 序列号的名称.NEXTVAL
  1. 单引号的处理
    MySQL里可以用双引号包起字符串,Oracle里只可以用单引号包起字符串。在插入和修改字符串前必须做单引号的替换:把所有出现的一个单引号替换成两个单引号。
  2. 分页的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;
  1. 长字符串的处理
    长字符串的处理Oracle也有它特殊的地方。INSERT和UPDATE时最大可操作的字符串长度小于等于4000个单字节, 如果要插入更长的字符串, 请考虑字段用CLOB类型,方法借用ORACLE里自带的DBMS_LOB程序包。插入修改记录前一定要做进行非空和长度判断,不能为空的字段值和超出长度字段值都应该提出警告,返回上次操作。
  2. 日期字段的处理
    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;

  1. 空字符的处理
    MySQL的非空字段也有空的内容,Oracle里定义了非空字段就不容许有空的内容。按MySQL的NOT NULL来定义Oracle表结构, 导数据的时候会产生错误。因此导数据时要对空字符进行判断,如果为NULL或空字符,需要把它改成一个空格的字符串。

  2. 字符串的模糊比较
    MySQL里用 字段名 like '%字符串%',Oracle里也可以用 字段名 like '%字符串%' 但这种方法不能使用索引, 速度不快,用字符串比较函数 instr(字段名,'字符串')>0 会得到更精确的查找结果。

  3. 程序和函数里,操作数据库的工作完成后请注意结果集和指针的释放。

MySQL和Oracle的一些区别相关推荐

  1. mysql 、oracle存储过程语法区别

    mysql .oracle存储过程语法区别 1.  条件语句:mysql使用elseif关键字,oracle是elsif关键字: oracle: if表达式 then 表达式: elsif 表达式: ...

  2. MySQL与Oracle的应用区别

    关系型数据库(Oracle与MySQL优缺点.使用区别) MySQL的特点 1.性能卓越,服务稳定,很少出现异常宕机: 2.开放源代码无版本制约,自主性及使用成本低: 3.历史悠久,社区和用户非常活跃 ...

  3. mysql和oracle有什么区别

    转自:微点阅读 www.weidianyuedu.com 1. mysql和oracle都是关系型数据库,可以应用于各种平台.我们用的oracle的版本是oracle11g ,用的mysql的版本是m ...

  4. MySQL与Oracle的语法区别详细对比 (转)

    Oracle和mysql的一些简单命令对比 1) SQL> select to_char(sysdate,'yyyy-mm-dd') from dual; SQL> select to_c ...

  5. mysql和oracle的语法区别

    最近需要迁移项目,将数据库由Oracle改为MySQL.由于两者的语法有部分不一样,所以需要把Oracle中能用但MySQL中不能用的函数/类型等改为MySQL中能用的,以下是总结出的部分语法区别: ...

  6. mysql 和 oracle 的一些区别

    1.seq  在oracle中获取下一个ID可以用seq,在mysql中可以设置某列自增 但是在同时添加主从表是设置自增不好在同一个事物中处理. 结合网上提供的方法,这里写了个可以获得每个表的seq的 ...

  7. 总结MySQL和Oracle的语法区别

    文章目录 1.时间函数 2.空值返0 3.长度函数 4.条件函数 5.trunc()函数 6.字符串整型转换函数 7.引号 8.字符串连接符 9.空数据排序 10.表(左/右)关联 11.merge ...

  8. MySQL与ORACLE 存储过程的区别

    存储过程&Function 编号 类别 ORACLE MYSQL 注释 1 创建存储过程语句不同 create or replace procedure P_ADD_FAC(    id_fa ...

  9. MySql和Oracle数据库的区别?

    查询当前所有的表 SQL> select * from tab; SQL> select * from cat where table_type='TABLE';//可能会有view SQ ...

最新文章

  1. 更快更强,谷歌提出SWideRNet:全景分割新标杆来啦!
  2. 一个fork的面试题
  3. 图解SQL基础知识,小白也能看懂的SQL文章!
  4. mysql,gone away, hy000, reconnect,Mysql大sql文件导入
  5. python变量定义必须赋值_Python3单行定义多个变量或赋值方法
  6. Android经常使用的五种弹出对话框
  7. fanuc机器人编程手册_是谁需要G代码编程机器人?
  8. 消息中间件学习总结(9)——RocketMQ与kafka差异比较分析
  9. 结构体05:结构体做函数参数
  10. 13. Django基础:admin后台管理
  11. amd编码器 hevc_Bandicam支持Nvidia NVENC编码器(H264, HEVC) - Bandicam(班迪录屏)
  12. lisp 计算三点的夹角_平面三点计算夹角
  13. mysql sin度数正玄值_正弦值角度对照表
  14. 微商引流脚本,微商怎样选择正确的引流脚本?
  15. 【转自人人】本科生如何发表论文
  16. MCU实现低功耗注意事项
  17. A Deep Learning-Based Remaining Useful Life Prediction Approach for Bearings 基于深度学习的轴承剩余寿命预测
  18. 请问什么叫纹波?怎样测量纹波?
  19. 浙江经信公布人工智能5大榜单 网易易盾内容安全解决方案上榜
  20. matlab二阶节的系数,如何利用matlab求解矩阵系数的二阶微分方程

热门文章

  1. 指针应用时的注意事项
  2. 趣学 C 语言(五)—— 内存管理
  3. 深度学习基础(七)—— Gibbs 采样
  4. C 标准库——cmath/math.h
  5. select * 排除字段_interesting数据库查找语句Select还能这样用
  6. python的优点有哪些-python的优点和缺点是什么|python有哪些优缺点 - PS下
  7. 自学python要看哪些书-学习机器学习应该看哪些书籍?
  8. python读音有道-centos7安装有道词典(不能发音和取词)
  9. python一般的基础代码-Python中的变量,一切代码的基础,你掌握了吗
  10. python有什么用途-Python是什么 Python的用处