编程论坛's Archiver

mujiang 发表于 2006-9-20 20:35

[求助]新手请教mysql和oracle的区别

<br>       我想学学这些东西,自己电脑上装了mysql4.1,不知道mysql的命令语句是否都能在oracle这些大型数据库里面用,能否用一些例如delphi之类的软件编些程序和mysql连接上来,然后做一些基本的界面型的查询操作。非常感谢。因为如果用命令的话,不是界面型的,所以我有这个想法,不知能否实现。
[align=right][color=#000066][此贴子已经被作者于2006-9-21 10:04:22编辑过][/color][/align]

可可℃乐 发表于 2006-9-21 15:05

<P>1. 自动增长的数据类型处理<BR>    MYSQL有自动增长的数据类型,插入记录时不用操作此字段,会自动获得数据值。ORACLE没有自动增长的数据类型,需要建立一个自动增长的序列号,插入记录时要把序列号的下一个值赋于此字段。</P>
<P>    CREATE SEQUENCE 序列号的名称 (最好是表名+序列号标记) INCREMENT BY 1  START  WITH  1 MAXVALUE  99999  CYCLE  NOCACHE;<BR>    其中最大的值按字段的长度来定, 如果定义的自动增长的序列号 NUMBER(6) , 最大值为999999<BR>    INSERT 语句插入这个字段值为: 序列号的名称.NEXTVAL</P>
<P>2. 单引号的处理<BR>    MYSQL里可以用双引号包起字符串,ORACLE里只可以用单引号包起字符串。在插入和修改字符串前必须做单引号的替换:把所有出现的一个单引号替换成两个单引号。</P>
<P>3.  翻页的SQL语句的处理<BR>    MYSQL处理翻页的SQL语句比较简单,用LIMIT 开始位置, 记录个数;PHP里还可以用SEEK定位到结果集的位置。ORACLE处理翻页的SQL语句就比较繁琐了。每个结果集只有一个ROWNUM字段标明它的位置, 并且只能用ROWNUM&lt;100, 不能用ROWNUM&gt;80。<BR>    以下是经过分析后较好的两种ORACLE翻页SQL语句( ID是唯一关键字的字段名 ):<BR>    语句一:<BR>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 &gt; 80 AND NUMROW &lt; 100 ) ORDER BY 条件3; <BR>  <BR>    语句二:<BR>SELECT * FROM (( SELECT ROWNUM AS NUMROW, c.* from (select [FIELD_NAME,...] FROM TABLE_NAME WHERE 条件1 ORDER BY 条件2) c) WHERE NUMROW &gt; 80 AND NUMROW &lt; 100 ) ORDER BY 条件3;<BR></P>

mujiang 发表于 2006-9-21 21:15

学习中,谢谢啦

页: [1]

Powered by Discuz! Archiver 6.1.0  © 2001-2007 Comsenz Inc.