标题:[求助]新手请教mysql和oracle的区别
只看楼主
mujiang
Rank: 1
等 级:新手上路
帖 子:24
专家分:0
注 册:2006-5-30
 问题点数:0 回复次数:2 
[求助]新手请教mysql和oracle的区别

我想学学这些东西,自己电脑上装了mysql4.1,不知道mysql的命令语句是否都能在oracle这些大型数据库里面用,能否用一些例如delphi之类的软件编些程序和mysql连接上来,然后做一些基本的界面型的查询操作。非常感谢。因为如果用命令的话,不是界面型的,所以我有这个想法,不知能否实现。

[此贴子已经被作者于2006-9-21 10:04:22编辑过]

搜索更多相关主题的帖子: oracle mysql 数据库 
2006-09-20 20:35
可可℃乐
Rank: 2
等 级:新手上路
威 望:3
帖 子:1054
专家分:0
注 册:2006-5-9
得分:0 

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

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

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

3. 翻页的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;


[url=http://www.]网页设计教程[/url]
2006-09-21 15:05
mujiang
Rank: 1
等 级:新手上路
帖 子:24
专家分:0
注 册:2006-5-30
得分:0 
学习中,谢谢啦

QQ 5622519,菜鸟,大家一起进步!
2006-09-21 21:15



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-91600-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.420660 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved