当前位置: 首页 > news >正文

免安装Oracle客户端使用PL/SQL连接Linux Oracle 注意事项

免安装Oracle客户端使用PL/SQL连接Linux Oracle 注意事项

关于免安oracle 客户端使用pl/sql 连接oracle ,请查我的另一篇文章http://blog.csdn.net/zwxrain/archive/2008/07/16/2663464.aspx

连接Linux 下的oracle 有一个注意事项,就是ADMIN内建立tnsnames.ora文件,这个文件是连接数据库的配置文件,我们连接每个oracle 数据库的配置内容都在这里。但我却发现,连接windows oracle 与连接 Linux Oracle 有一点不同,具体如下:

配置内容1. tnsnames.ora

# TNSNAMES.ORA Network Configuration File: C:\oracle\ora90\NETWORK\ADMIN\tnsnames.ora

# Generated by Oracle configuration tools.

WINDB =

(DESCRIPTION =

(ADDRESS_LIST =

(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.4.31)(PORT = 1521))

)

(CONNECT_DATA =

(SERVICE_NAME = DEVDB)

)

)

LINUXDB =

(DESCRIPTION =

(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.4.41)(PORT = 1521))

(CONNECT_DATA =DEVDB)

)

)

EXTPROC_CONNECTION_DATA =

(DESCRIPTION =

(ADDRESS_LIST =

(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC0))

)

(CONNECT_DATA =

(SID = PLSExtProc)

(PRESENTATION = RO)

)

)

这里有WINDB LINUXDB 的配置内没有所不同,只是IP不同,一般这样配是不会有会题的,实验证明,WINDB在这种配置情况下,可以正常连上数据库

LINUXDB 却不能正确的连上数据库,报ORA-12154TNScould not resolve the connect identifier specified 的错误信息,如下图:

经过多次测试,得到一个可以正常连得上的LINUXDB的配置

# TNSNAMES.ORA Network Configuration File: C:\oracle\ora90\NETWORK\ADMIN\tnsnames.ora

# Generated by Oracle configuration tools.

WINDB =

(DESCRIPTION =

(ADDRESS_LIST =

(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.4.31)(PORT = 1521))

)

(CONNECT_DATA =

(SERVICE_NAME = DEVDB)

)

)

#Linux Lister 配置字符串不能分行,Sever_Name 也要用全局数据库名

LINUXDB =

(DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.4.41)(PORT = 1521)) (CONNECT_DATA =(SERVICE_NAME = DEVDB.SQL.DBA.COM)))

EXTPROC_CONNECTION_DATA =

(DESCRIPTION =

(ADDRESS_LIST =

(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC0))

)

(CONNECT_DATA =

(SID = PLSExtProc)

(PRESENTATION = RO)

)

)

测试结果如下:

1. Linux oracle 的配置字符串不能出行回车分行的情况,如果分行,会出现下图的错误

2. Server_Name 必须用全局数据库,如果没有用全局数据库,会出现如下的错误。

相关文章:

  • CLI PHP WebSocket服务器
  • Nginx 自带防盗链模块
  • 在MTK中添加TASK与常用函数分析
  • 大数据时代必不可少的大数据分析和制作工具大全
  • SubVersion服务器Windows安装指南
  • CentOS里ifcfg的device指的是什么?
  • SQLServer2005批量查询自定义对象脚本
  • 使用Let's encrypt保护你的网络通信
  • SQLServer中求两个字符串的交集
  • 139说客的优势和局限性
  • phpjm php加密的解密过程
  • 被遗忘的SQLServer比较运算符修饰词
  • PHP MySQL 数据字典生成器
  • 设计启动屏幕
  • CentOS 安装NodeJS
  • [微信小程序] 使用ES6特性Class后出现编译异常
  • css系列之关于字体的事
  • C学习-枚举(九)
  • iOS筛选菜单、分段选择器、导航栏、悬浮窗、转场动画、启动视频等源码
  • PAT A1120
  • Python socket服务器端、客户端传送信息
  • Redash本地开发环境搭建
  • use Google search engine
  • vue--为什么data属性必须是一个函数
  • 大型网站性能监测、分析与优化常见问题QA
  • 问:在指定的JSON数据中(最外层是数组)根据指定条件拿到匹配到的结果
  • 想晋级高级工程师只知道表面是不够的!Git内部原理介绍
  • 小而合理的前端理论:rscss和rsjs
  • 再次简单明了总结flex布局,一看就懂...
  • 找一份好的前端工作,起点很重要
  • ​LeetCode解法汇总2696. 删除子串后的字符串最小长度
  • #### go map 底层结构 ####
  • (11)MATLAB PCA+SVM 人脸识别
  • (C语言)球球大作战
  • (Redis使用系列) SpirngBoot中关于Redis的值的各种方式的存储与取出 三
  • (Redis使用系列) SpringBoot中Redis的RedisConfig 二
  • (附源码)ssm基于web技术的医务志愿者管理系统 毕业设计 100910
  • (附源码)计算机毕业设计SSM智慧停车系统
  • (六)Hibernate的二级缓存
  • (四)docker:为mysql和java jar运行环境创建同一网络,容器互联
  • (转)Linux NTP配置详解 (Network Time Protocol)
  • ... 是什么 ?... 有什么用处?
  • ./configure,make,make install的作用(转)
  • .h头文件 .lib动态链接库文件 .dll 动态链接库
  • .NET Remoting学习笔记(三)信道
  • .net 程序发生了一个不可捕获的异常
  • .netcore 如何获取系统中所有session_如何把百度推广中获取的线索(基木鱼,电话,百度商桥等)同步到企业微信或者企业CRM等企业营销系统中...
  • .NET程序员迈向卓越的必由之路
  • .NET开发不可不知、不可不用的辅助类(一)
  • .vue文件怎么使用_vue调试工具vue-devtools的安装
  • /dev/VolGroup00/LogVol00:unexpected inconsistency;run fsck manually
  • []指针
  • [Android 13]Input系列--获取触摸窗口
  • [C# WPF] 如何给控件添加边框(Border)?
  • [C# 开发技巧]如何使不符合要求的元素等于离它最近的一个元素