⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 oracle常见问题常用技巧-29.htm

📁 微软数据库开发梦工场多媒体教学-oracle篇.rar,是多媒体教学的
💻 HTM
字号:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>Untitled Document</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>

<body bgcolor="#000000" text="#FFFFFF">
<font color="#009900">如何实现SQL Sysbase Access向Oracle移植 </font> 
<p> </p>
<p>随着Oracle在中国的广泛应用,许多原来使用MS SQL7.0、Sysbase、Access等数 据库的用户都碰到了数据移植的问题。其实,存在着许多的方法,这里将介绍3 
  种方法。</p>
<p>1、使用MS SQL7.0自带的Import/Export工具 Import/Export工具可以方便的把数据移植到Oracle。你需要通过定义ODBC 
  For Oracle 作为目的源。这样的方法可以保证SQL7的绝大部分数据移植到Oracl e中去,但预先你必须在Oracle建立user 和 相应的tablespace。因为SQL7中有一些特殊的datatype,如text 
  、image等。当一个table中有多于一个text或image 的字段时,将出现错误,不能执行。这是你需要做出选择,或者把text 镜像为v archar2(4000),或者镜像为Long 
  datatype,但long datatype一个table里只能有一个。而且,还有可能遇到字符集的问题,最好用第三种方法或者第四种。所以你遇到这样的情况,可以结合使用第3种方法。</p>
<p>2、使用Oracle Migration Workbanch。 目前的版本是2.2,这个工具可以在http://technet.oracle.com免费下载。它是Oracle提供的一个代替SQl*Loader的工具,当然目前该工具仍然不能完全取 
  代SQL*Loader。使用OMWB,只要你定义了ODBC for MS SQL7 或Access或Sysbase ,就可以很方便的把tabels、views、triger、procedure、shortnaps、users等完全转到Oracle中去,对于text,可以镜像为CLOB类型,CLOB类型可以在一个Or 
  acle table里有多列。image可以镜像为BLOB。但是遗憾的是,OMWB2.2不支持 中 文CLOB,无论我如何调整,数据migrate到Oracle后,都变成了????,如果谁有解决的方法,别忘了email给我。我对OMWB对数据流(如image,video,sound)的控制非常的欣赏。</p>
<p>3、使用Oracle的 SQL*Loader 使用SQL*Loader,也许是最不方便的方法,但是是最有效的方法。可以使用各种方法把源数据导到一个外部分件中。我使用了MS 
  SQL7带的BCP工具,可以把 那些特殊多text字段的tables导出作为外部文件。然后使用SQL*Loader在把这些 数据导到Oracle的一个临时表里,在对第2中方法出现的????字段进行update。</p>
<p>4、使用程序进行移植 例子:从SQL7.0向基于Linux下的Oracle数据库倒入数据:程序语言:java 与数据库的连接 SQL7.0:jdbc-odbc桥,java自带。 
  Oracle:jdbc,Oracle提供。 代码如下: </p>
<p>import java.lang.*;<br>
    import java.sql.*;</p>
<p>import oracle.jdbc.driver.*; //倒入要用到的包</p>
<p>public class hhw extends Object<br>
    { public static void main(String args[]) throws SQLException, ClassNotFoundException 
  //抛出  SQLException异常 { Class.forName(&quot;sun.jdbc.odbc.JdbcOdbcDriver&quot;);</p>
<p>Class.forName (&quot;oracle.jdbc.driver.OracleDriver&quot;); // 登记驱动程序,准备联接数据库</p>
<p>Connection cn1 =DriverManager.getConnection&quot;jdbc:oracle:thin:@192.168.1.52:1521:SONIC&quot;, 
  &quot;sadly&quot;, &quot;sadly&quot;);</p>
<p>Connection cn2 =DriverManager.getConnection&quot;jdbc:odbc:sql&quot;, &quot;sa&quot;, 
  &quot;&quot; ); //联接到数据库,建立到两个数据库的连接</p>
<p>Statement s1=cn1.createStatement();<br>
    Statement s2=cn2.createStatement();</p>
<p>ResultSet rs1=s2.executeQuery(&quot;select * from users where id&gt;0 and id&lt;4 
  0000 &quot;); //从数据源中取得数据,定义一些中间变量</p>
<p>int id;</p>
<p>String name=new String(&quot;1&quot;);<br>
    String passwd=new String(&quot;1&quot;);<br>
    String email=new String(&quot;1&quot;); //执行另一个查询,向目的数据库插入数据</p>
<p>while(rs1.next())<br>
    {id=rs1.getInt(1);<br>
    name=rs1.getString(&quot;name&quot;);<br>
    passwd=rs1.getString(&quot;passwd&quot;);<br>
    email=rs1.getString(&quot;email&quot;); //System.out.print(id+name+passwd+email);<br>
    s1.executeQuery(&quot;insert into bbsuser values(\\&quot;+id+&quot;\,\\&quot;+name+&quot;\,\\&quot;+pas 
  swd+&quot;\,\\&quot;+email+&quot;\)&quot;); } }}</p>
<p>&nbsp; </p>
</body>
</html>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -