如何在程序中获取Oracle服务名

 

 1。查询注册表,获取oracle安装根目录
           HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\ORACLE_HOME   REG_SZ  E:\ORACLE\ORA92
            得知oracle服务名文件所在地:根目录\network\ADMIN\tnsnames.ora
            
 

2。解析该文件,该文件结构如
            # ------------------------------------------------
            PORTAL =
            (DESCRIPTION =
                (ADDRESS_LIST =
                (ADDRESS = (PROTOCOL = TCP)(HOST = 134.104.52.6)(PORT = 1521))
                )
                (CONNECT_DATA =
                (SERVICE_NAME = portal)
                )
            )

3 。解析要点:
            一行一行获取再解析
            跳过以 # 打头的注释行
            过滤掉空格后,首字符在 A~z 之间的行就包含了 Oracle 服务名
            截取该行第一个 “ = ” 号左边的字符串, trim 处理后就是 Oracle 服务名了   

None.gif private   string []  TnsNameRead()
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif {
InBlock.gif            ArrayList arr 
= new ArrayList();
InBlock.gif            
string path = (string)Registry.LocalMachine.OpenSubKey("SOFTWARE\\ORACLE").GetValue("ORACLE_HOME");
InBlock.gif            path 
+= @"\network\admin\tnsnames.ora";
InBlock.gif            
try 
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                
using (StreamReader sr = new StreamReader(path)) 
ExpandedSubBlockStart.gifContractedSubBlock.gif                
dot.gif{
InBlock.gif                    String line;
InBlock.gif                    
while ((line = sr.ReadLine()) != null
ExpandedSubBlockStart.gifContractedSubBlock.gif                    
dot.gif{
InBlock.gif                        line 
= line.Trim();
InBlock.gif                        
if (line != "")
ExpandedSubBlockStart.gifContractedSubBlock.gif                        
dot.gif{
InBlock.gif                            
char c = line[0];
InBlock.gif                            
if ( c>= 'A' && c<='z')
ExpandedSubBlockStart.gifContractedSubBlock.gif                            
dot.gif{
InBlock.gif                                arr.Add(line.Substring(
0, line.IndexOf('=')).Trim());
InBlock.gif                                MessageBox.Show(line.Substring(
0, line.IndexOf('=')).Trim());
ExpandedSubBlockEnd.gif                            }

ExpandedSubBlockEnd.gif                        }

ExpandedSubBlockEnd.gif                    }

ExpandedSubBlockEnd.gif                }

ExpandedSubBlockEnd.gif            }

InBlock.gif            
catch (Exception e) 
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                MessageBox.Show(
"无法打开tnsnames.ora文件\n"+ e.Message , "警告", MessageBoxButtons.OK, MessageBoxIcon.Stop);
ExpandedSubBlockEnd.gif            }

InBlock.gif            
return (string[])arr.ToArray(typeof(string));
ExpandedBlockEnd.gif        }

None.gif
    
posted on 2007-01-16 11:06 米天峰 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/mtf/archive/2007/01/16/621465.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值