知识大全 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应用服务器打动的几点理由 以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! Ora
begoingto与well+动原的区别!求一位大神口述详解一下可好!begoingto与will的几点区别begoingto与will的几点区别:1.begoingto表示近期、眼下就要发生的事情,
物流责任保险发展与完善的几点建议1.物流企业方面物流企业必须端正思想、认清形势,认识到物流责任保险的重要性。物流责任保险不仅能够转移、分散物流企业的责任风险,减少亏损、增加盈利,还能够通过保险公司的介
mysql中char和varchar有什么区别?mysql中char与varchar的区别分析1.都是用来存储字符串的,只是他们的保存方式不一样。2.char有固定的长度,而varchar属于可变长的
摘要:本文讨论了在城市污水处理厂提升泵房、沉砂池、二沉池和污泥消化池的设计与运行中的几点经验。同时对脱氮除磷工艺的选择以及污泥的处理与处置提出了几点建议。关键词:污水处理厂;设计与运行;脱氮除磷;污泥
摘要:本文讨论了在城市污水处理厂提升泵房、沉砂池、二沉池和污泥消化池的设计与运行中的几点经验。同时对脱氮除磷工艺的选择以及污泥的处理与处置提出了几点建议。关键词:污水处理厂;设计与运行;脱氮除磷;污泥
摘要:本文讨论了在城市污水处理厂提升泵房、沉砂池、二沉池和污泥消化池的设计与运行中的几点经验。同时对脱氮除磷工艺的选择以及污泥的处理与处置提出了几点建议。关键词:污水处理厂;设计与运行;脱氮除磷;污泥
注释 oracle使用的是–(两个)批量注释/**/ mysql使用的是#批量注释/**/ 通配符的使用 mysql和oracle都支持通配符%用以模糊查询mysql还可以用instr(p
要养好鱼,先得养好水,养鱼的好水要达到“肥、活、嫩、爽”。目前池塘养殖中已普遍采取高密度养殖方式,仅以盈江县的养殖现状来说,饲料年投入量较大的已达每亩5—6吨,残饵、粪便积累已严重超出了水体的自净能力
要养好鱼,先得养好水,养鱼的好水要达到“肥、活、嫩、爽”。目前池塘养殖中已普遍采取高密度养殖方式,仅以盈江县的养殖现状来说,饲料年投入量较大的已达每亩5—6吨,残饵、粪便积累已严重超出了水体的自净能力