`
小小兔
  • 浏览: 669 次
  • 性别: Icon_minigender_2
  • 来自: 太原
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

MySQL与oracle数据库的一些区别

阅读更多
  1、 组函数用法规则
   mysql中组函数在select语句中可以随意使用,但在oracle中 如果查询语句中有组函数,那其他列名必须是组函数处理过的,或者是group by子句中的列 否则报错。
eg:

select name,count(money) from user ;这个放在mysql中没有问题 在oracle中就有问题了.............

   2、自动增长的数据类型处理

  MYSQL有自动增长的数据类型,插入记录时不用操作此字段,会自动获得数据值。ORACLE没有自动增长的数据类型,需要建立一个自动增长的序列号,插入记录时要把序列号的下一个值赋于此字段。

CREATE SEQUENCE 序列号的名称 (最好是表名+序列号标记) INCREMENT BY 1 START WITH 1 MAXVALUE 99999 CYCLE NOCACHE;
  其中最大的值按字段的长度来定, 如果定义的自动增长的序列号 NUMBER(6) , 最大值为999999

  INSERT 语句插入这个字段值为: 序列号的名称.NEXTVAL。

    3、单引号的处理

  MYSQL里可以用双引号包起字符串,ORACLE里只可以用单引号包起字符串。在插入和修改字符串前必须做单引号的替换:把所有出现的一个单引号替换成两个单引号。

  4、翻页的SQL语句的处理

  MYSQL处理翻页的SQL语句比较简单,用LIMIT 开始位置, 记录个数;PHP里还可以用SEEK定位到结果集的位置。ORACLE处理翻页的SQL语句就比较繁琐了。每个结果集只有一个ROWNUM字段标明它的位置, 并且只能用ROWNUM<100, 不能用ROWNUM>80。

  以下是经过分析后较好的两种ORACLE翻页SQL语句( ID是唯一关键字的字段名 ):

  语句一:

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;
  语句二:

SELECT * FROM (( SELECT ROWNUM AS NUMROW, c.* from (select [FIELD_NAME,...] FROM TABLE_NAME WHERE 条件1 ORDER BY 条件2) c) WHERE NUMROW > 80 AND NUMROW < 100 ) ORDER BY 条件3;

  5、长字符串的处理

  长字符串的处理ORACLE也有它特殊的地方。INSERT和UPDATE时最大可操作的字符串长度小于等于4000个单字节, 如果要插入更长的字符串, 请考虑字段用CLOB类型,方法借用ORACLE里自带的DBMS_LOB程序包。插入修改记录前一定要做进行非空和长度判断,不能为空的字段值和超出长度字段值都应该提出警告,返回上次操作。

 6、日期字段的处理

  MYSQL日期字段分DATE和TIME两种,ORACLE日期字段只有DATE,包含年月日时分秒信息,用当前数据库的系统时间为SYSDATE, 精确到秒,或者用字符串转换成日期型函数:

TO_DATE(‘2001-08-01’,’YYYY-MM-DD’)年-月-日 24小时:分钟:秒 的格式YYYY-MM-DD HH24:MI:SS TO_DATE()
还有很多种日期格式, 可以参看ORACLE DOC.日期型字段转换成字符串函数:

TO_CHAR(‘2001-08-01’,’YYYY-MM-DD HH24:MI:SS’)
  日期字段的数学运算公式有很大的不同。MYSQL找到离当前时间7天用 DATE_FIELD_NAME > SUBDATE(NOW(),INTERVAL 7 DAY)ORACLE找到离当前时间7天用 DATE_FIELD_NAME >SYSDATE - 7;

  MYSQL中插入当前时间的几个函数是:

NOW()函数以`'YYYY-MM-DD HH:MM:SS'
返回当前的日期时间,可以直接存到DATETIME字段中。CURDATE()以’YYYY-MM-DD’的格式返回今天的日期,可以直接存到DATE字段中。CURTIME()以’HH:MM:SS’的格式返回当前的时间,可以直接存到TIME字段中。例:

insert into tablename (fieldname) values (now())
  而oracle中当前时间是sysdate。

  7、空字符的处理

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

  8、字符串的模糊比较

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

  9、程序和函数里,操作数据库的工作完成后请注意结果集和指针的释放。
分享到:
评论

相关推荐

    MySql 和Oracle 数据库结构导出Word

    1. 连接数据库:使用Java的JDBC(Java Database Connectivity)API,可以连接到MySQL或Oracle数据库,获取数据库的连接。 2. 执行SQL查询:通过执行`SHOW CREATE TABLE`(MySQL)或`DESCRIBE TABLE`(Oracle)等...

    mysql和 oracle数据库安装文档

    MySQL和Oracle数据库安装文档 MySQL和Oracle都是流行的关系数据库管理系统,它们广泛应用于企业级应用中。对于初学者来说,安装和配置数据库是一件比较困难的事情。因此,本文档旨在提供一个详细的安装指南,帮助...

    支持MYSQL和ORACLE数据库表

    DBExportDoc V1.0 For Oracle.doc 和 DBExportDoc V1.0 For MySQL.doc 这两个文档很可能包含了关于如何导出或备份MySQL和Oracle数据库表的详细步骤和最佳实践。在数据库管理中,数据备份和导出是至关重要的,它们...

    mysql ,oracle 数据库命名规范

    在数据库管理领域,命名规范是至关重要的,因为它不仅影响到代码的可读性和可维护性,还直接影响到团队协作的效率。"MySQL 和 Oracle 数据库...希望这些关于MySQL和Oracle数据库命名规范的知识能对你的工作带来帮助。

    数据库的连接篇(MySQL和Oracle)

    文档包含了Oracle数据库的连接,以及检测是否连接成功,还包含的MySQL数据库的连接及检测,这是基于初学者的学习使用

    mysql+oracle数据库驱动程序

    总的来说,`mysql-connector-java-3.1.14-bin.jar`和`ojdbc7.jar`是连接MySQL和Oracle数据库的关键组件,它们使得Java应用程序能够无缝地与这些数据库进行交互。在使用这些驱动时,开发人员需要注意版本兼容性、安全...

    MySql+Oracle数据库Java驱动jar包

    总的来说,MySQL和Oracle数据库的Java驱动jar包是Java应用与数据库交互的关键组件,它们为Java程序员提供了与数据库进行数据操作的桥梁。了解如何正确使用这些驱动,以及如何在项目中管理和配置它们,是每个Java开发...

    mysql、oracle 数据库生成文档源码

    【MySQL与Oracle数据库生成文档源码详解】 在数据库管理和开发过程中,记录和维护数据库结构的文档至关重要,这有助于团队协作,提升代码可读性,并在系统升级或迁移时提供参考。本文将详细介绍如何使用提供的...

    oracle数据库和mysql数据库的链接信息

    根据给定文件的信息,我们可以详细地探讨Oracle数据库与MySQL数据库的连接信息,包括它们的驱动程序、连接字符串等关键组成部分。 ### Oracle数据库连接信息 #### 驱动程序 Oracle数据库连接通常会用到`oracle....

    Oracle到Mysql数据库迁移总结

    Oracle到Mysql数据库迁移总结Oracle到Mysql数据库迁移总结Oracle到Mysql数据库迁移总结Oracle到Mysql数据库迁移总结

    如何连接MySQL-Oracle数据库

    ### 如何连接MySQL-Oracle数据库 在现代软件开发过程中,数据库连接是至关重要的一步。本文将详细介绍如何通过Java Database Connectivity (JDBC) 连接 MySQL 和 Oracle 数据库的方法。 #### JDBC 的基本概念 ...

    20190521-mysql与oracle数据库差异.pptx

    关系数据库选型、mysql与oracle数据库差异、oracle的优劣势、数据迁移

    把mysql数据库中的数据导入到oracle数据库中

    ### 把MySQL数据库中的数据导入到Oracle数据库中的详细步骤与注意事项 #### 一、环境配置与需求概述 本文档旨在详细介绍如何将MySQL数据库中的数据迁移到Oracle数据库中,包括具体的环境配置、迁移流程以及可能...

    mysql 数据库转 oracle

    8. **测试与验证**:迁移完成后,需要对Oracle数据库进行测试,确保所有功能都能正常工作,与原有的MySQL环境无明显差异。 在实际操作中,除了使用工具外,还需要考虑以下几个方面: 1. **计划与准备**:详细规划...

    TiDB&MySql&Oracle介绍及区别

    5. MySQL 与 ORACLE 区别 - 功能上:Oracle 提供更多高级特性,如更复杂的数据类型、分区表等。 - 性能上:Oracle 在大型企业级应用中通常表现出更高的性能。 - 价格上:Oracle 通常比 MySQL 成本更高,尤其在...

    MySQL、Oracle数据库连接的jar包

    本文将深入探讨如何使用Java编程语言与这两个数据库进行连接,重点介绍标题和描述中提及的jar包——ojdbc6.jar(Oracle数据库的驱动)和mysql-connector-java-5.1.7-bin.jar(MySQL数据库的驱动)。 首先,让我们...

    SqlServer、MySql、Oracle数据库直连和池连包及相应驱动

    在给定的标题"SqlServer、MySql、Oracle数据库直连和池连包及相应驱动"中,我们主要关注的是三种流行的数据库管理系统(DBMS):SQL Server、MySQL和Oracle,以及它们的连接方式——直连和池连,以及对应的驱动程序...

    Oracle数据库表转换为Mysql

    "Oracle数据库表转换为Mysql" Oracle数据库表转换为Mysql是指将Oracle数据库中的表结构转换为Mysql数据库中的表结构,以便在Mysql数据库中使用。这种转换可以使用PowerDesigner工具来实现。 一、Oracle数据库表...

Global site tag (gtag.js) - Google Analytics