知识大全 Oracle与MySQL的几点区别

Posted

篇首语:不曾扬帆,何以至远方。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 Oracle与MySQL的几点区别相关的知识,希望对你有一定的参考价值。

Oracle与MySQL的几点区别  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!

Oracle数据库与MySQL数据库的区别是本文我们主要介绍的内容 希望能够对您有所帮助

   组函数用法规则

  mysql中组函数在select语句中可以随意使用 但在oracle中 如果查询语句中有组函数 那其他列名必须是组函数处理过的 或者是group by子句中的列 否则报错

  eg

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

   自动增长的数据类型处理

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

  CREATE SEQUENCE 序列号的名称 (最好是表名+序列号标记) INCREMENT BY START WITH MAXVALUE CYCLE NOCACHE;

  其中最大的值按字段的长度来定 如果定义的自动增长的序列号 NUMBER( ) 最大值为

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

   单引号的处理

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

   翻页的SQL语句的处理

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

  以下是经过分析后较好的两种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 条件 ORDER BY 条件 ) WHERE NUMROW > AND NUMROW < ) ORDER BY 条件 ;

  语句二

  SELECT * FROM (( SELECT ROWNUM AS NUMROW c * from (select [FIELD_NAME ] FROM TABLE_NAME WHERE 条件 ORDER BY 条件 ) c) WHERE NUMROW > AND NUMROW < ) ORDER BY 条件 ;

   长字符串的处理

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

   日期字段的处理

  MYSQL日期字段分DATE和TIME两种 ORACLE日期字段只有DATE 包含年月日时分秒信息 用当前数据库的系统时间为SYSDATE 精确到秒 或者用字符串转换成日期型函数TO_DATE( YYYY MM DD )年 月 日 小时:分钟:秒 的格式YYYY MM DD HH :MI:SS TO_DATE()还有很多种日期格式 可以参看ORACLE DOC 日期型字段转换成字符串函数TO_CHAR( YYYY MM DD HH :MI:SS )

  日期字段的数学运算公式有很大的不同 MYSQL找到离当前时间 天用 DATE_FIELD_NAME > SUBDATE(NOW() INTERVAL DAY)ORACLE找到离当前时间 天用 DATE_FIELD_NAME >SYSDATE ;

  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

   空字符的处理

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

   字符串的模糊比较

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

cha138/Article/program/MySQL/201404/30556

相关参考

知识大全 被Oracle9i应用服务器打动的几点理由

被Oracle9i应用服务器打动的几点理由  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  Ora

知识大全 求一位大神口述详解一下可好

begoingto与well+动原的区别!求一位大神口述详解一下可好!begoingto与will的几点区别begoingto与will的几点区别:1.begoingto表示近期、眼下就要发生的事情,

物流责任保险发展与完善的几点建议

物流责任保险发展与完善的几点建议1.物流企业方面物流企业必须端正思想、认清形势,认识到物流责任保险的重要性。物流责任保险不仅能够转移、分散物流企业的责任风险,减少亏损、增加盈利,还能够通过保险公司的介

知识大全 mysql中char和varchar有什么区别?

mysql中char和varchar有什么区别?mysql中char与varchar的区别分析1.都是用来存储字符串的,只是他们的保存方式不一样。2.char有固定的长度,而varchar属于可变长的

城市污水处理厂设计与运行的几点经验及建议

摘要:本文讨论了在城市污水处理厂提升泵房、沉砂池、二沉池和污泥消化池的设计与运行中的几点经验。同时对脱氮除磷工艺的选择以及污泥的处理与处置提出了几点建议。关键词:污水处理厂;设计与运行;脱氮除磷;污泥

城市污水处理厂设计与运行的几点经验及建议

摘要:本文讨论了在城市污水处理厂提升泵房、沉砂池、二沉池和污泥消化池的设计与运行中的几点经验。同时对脱氮除磷工艺的选择以及污泥的处理与处置提出了几点建议。关键词:污水处理厂;设计与运行;脱氮除磷;污泥

城市污水处理厂设计与运行的几点经验及建议

摘要:本文讨论了在城市污水处理厂提升泵房、沉砂池、二沉池和污泥消化池的设计与运行中的几点经验。同时对脱氮除磷工艺的选择以及污泥的处理与处置提出了几点建议。关键词:污水处理厂;设计与运行;脱氮除磷;污泥

知识大全 mysql和oracle常用内容比较

  注释  oracle使用的是–(两个)批量注释/**/  mysql使用的是#批量注释/**/  通配符的使用  mysql和oracle都支持通配符%用以模糊查询mysql还可以用instr(p

搞好池塘水质调节与养护的几点建议

要养好鱼,先得养好水,养鱼的好水要达到“肥、活、嫩、爽”。目前池塘养殖中已普遍采取高密度养殖方式,仅以盈江县的养殖现状来说,饲料年投入量较大的已达每亩5—6吨,残饵、粪便积累已严重超出了水体的自净能力

搞好池塘水质调节与养护的几点建议

要养好鱼,先得养好水,养鱼的好水要达到“肥、活、嫩、爽”。目前池塘养殖中已普遍采取高密度养殖方式,仅以盈江县的养殖现状来说,饲料年投入量较大的已达每亩5—6吨,残饵、粪便积累已严重超出了水体的自净能力