1、假如你已经是个 PowerBuilder 高手,那么下面的东西对你来说毫无价值,你大可不必再看下去,假如你刚刚步入 PowerBuilder 的殿堂,那么下面的东西对你来说可能有点价值,你应该看一看。 作为一个优秀的客户端开发工具, PowerBuilder 必然需要与大型的数据库相连接,尽管许多资料上都介绍了如何通过 ODBC 或者 PowerBuilder 自带的 DB PRofile 或者专用接口连接上数据库,但仍然有许多使用者按此方法却无法连接上数据库,这方面的原因可能是 PowerBuilder 本身的原因,比如在安装 PowerBuilder 时的选项、ODBC 的版本之类;也可能
2、是在安装客户端的 Oracle、Sybase、Informix、SQL Server 等软件上的问题,下面就从最根本的 ODBC 配置开始,教你一步步如何连接上数据库。 ODBC 数据源的配置进入控制面板,打开 ODBC数据源(32 位) ,如图 1 所示,点击“ADD”按钮,进入 ODBC 数据源的配置面板,如图 2所示: 选择“Oracle ODBC Driver”一项,注重当前版本号为“8.00.0400”,假如你的操作系统中安装的是 Oracle7,则相应的版本号会不同。提醒一点:在 Windows98 操作系统上是无法安装 Oracle8.0.4 的(只能安装 Oracle7.2.3
3、) ,Oracle8.0.5 则没有试过。因而会有一些使用者在 Windows98 系统上无法正常配置 ODBC 数据源,因为 Windows98 本身自带的 ODBC 数据源已经比 Oracle7 数据源版本要高,无论你怎样配置 ODBC,系统总会提示你要安装一个更高版本的 Oracle,自然你就无法配置 ODBC 了,有一个解决方法就是用 PB7 第二张光盘上的 ODBC 安装程序覆盖系统中的 ODBC,或者把你的操作系统改为 Windows95/97 算了。 然后进入“Oracle8 ODBC Driver Setup”设置,在“Data Source Name”一项中随便输入一个名字,
4、在“Data Source Service Name”一栏中输入 Oracle 连接数据库的字符串名,这可以在你安装的 Oracle 目录中的 Tnsnames.ora 文件中查看到(Oracle7 安装路径为“ORAWIN95NETWORK ADMIN”;Oracle8 安装路径为“orawin95NET80ADMIN”) ,或者你通过 “SQL Net Easy Configuration”新添加一个数据库连接配置,将配置中的字符串填入即可,其他的就不必再填入,避免出现画蛇添足之错,反而连接不上数据库了。 DB Profile 数据源的配置进入 PB,打开 DB Profile,如图 4
5、所示,选择 ODBC 一项,点击“NEW”,进入 PB 数据源的配置,如图 5 所示。当然假如你之前没有进行 ODBC 的配置,你也可以在这里点击“Config ODBC”进入之前你看到的ODBC 配置界面。 在“Profile Name”中自定义一个名字,然后从“Data Source”的下拉菜单中选择你在 ODBC 中已经配置好的数据源,输入登录数据库所需要的用户名与密码,当然你认为没有这个必要性的话可以不在这里输入(主要是不要轻易让人知道你数据库的口令,不然问题就大了) ,到这一步为止,PB 已经做完了所有数据库连接的配置,剩下的就是连接上数据库了。 PB FOR Oracle 专用接口
6、的配置同样是进入 PB,点击 DB Profile 选项(这是对 Oracle7 版本而言,假如是 Oracle8,相应的选项就是 Oracle8.0.4) ,看到上面的“073 Oracle 7.3”选项没有,点击一下,再按“NEW”进入图 7 的界面, “Profile Name”一栏随意填, “Server”一栏填写时要注重,Oracle7 版本一定要在数据连接字符串前加上 ,否则不能连接上 PB 数据库,Oracle8 版本则不必加上,其他的设置就可以不用了。以上三种 PB 连接数据库的方法其实十分简单,但是初学者却又会经常出错,在这里只是想作为一种抛砖引玉之用,希望广大初学者通过本文
7、对 PB 数据源配置能够有一定的了解。下面再对 Oracle 连接数据库的配置文件 Tnsnames.ora 简单说明一下, “Tnsnames.ora”文件其实是通过“SQL Net Easy Configuration”初始化配置后的参数文件,假如你不想通过“SQL Net Easy Configuration”进行配置,你只需要把你先前已有的“Tnsnames.ora”文件放入Oracle 的 ADMIN 目录中,覆盖现有的文件就可以了,当然你也可以再自己添加数据库连接字符串。通常,一个“Tnsnames.ora”文件内容如下: ·····
8、;· kf.world = (DESCRipTION = (ADDRESS_LIST = (ADDRESS = (COMMUNITY = tcp.world) (PROTOCOL = TCP) (Host = 136.12.145.5) (Port = 1521) ) (ADDRESS = (COMMUNITY = tcp.world) (PROTOCOL = TCP) (Host = 136.12.145.5) (Port = 1526) ) ) (CONNECT_DATA = (SID = sid3) ) ) ······ 其中最要的是第一项和最后一项(这里是以 TCP/IP 网络连接,大多数用户都是以此连接) ,HOST 一栏是主机地址, “CONNECT_DATA = (SID = sid3)”中的 SID3 是连接主机数据库的字符串,你要修改这几项就可以了。另外谈谈如何让英文版的 Oracle7 显示中文,其实很简单,只要将注册表“HKEY_LOCAL_MACHINE SoftwareORACLENLS_LANG”中的值改为如下值就可以了“ SIMPLIFIED CHINESE_CHINA.ZHS16CGB231280”。