按代码获取文件tnsnames.ora的位置

RRU*_*RUZ 7 c# c++ delphi oracle oracle11g

如何tnsnames.ora在安装了Oracle客户端的计算机中按代码获取文件的位置?

是否有一个Windows注册表项指示此文件的位置?

Tho*_*ing 10

几年前我遇到了同样的问题.
那时我不得不支持Oracle 9和10,所以代码只处理那些版本,但也许它可以让你免于一些研究.这个想法是:

  • 搜索注册表以确定oracle客户端版本
  • 试着找到ORACLE_HOME
  • 终于从HOME获得了tnsnames

public enum OracleVersion
{
    Oracle9,
    Oracle10,
    Oracle0
};

private OracleVersion GetOracleVersion()
{
    RegistryKey rgkLM = Registry.LocalMachine;
    RegistryKey rgkAllHome = rgkLM.OpenSubKey(@"SOFTWARE\ORACLE\ALL_HOMES");

    /* 
     * 10g Installationen don't have an ALL_HOMES key
     * Try to find HOME at SOFTWARE\ORACLE\
     * 10g homes start with KEY_
     */
    string[] okeys = rgkLM.OpenSubKey(@"SOFTWARE\ORACLE").GetSubKeyNames();
    foreach (string okey in okeys)
    {
        if (okey.StartsWith("KEY_"))
            return OracleVersion.Oracle10;
    }

    if (rgkAllHome != null)
    {
        string strLastHome = "";
        object objLastHome = rgkAllHome.GetValue("LAST_HOME");
        strLastHome = objLastHome.ToString();
        RegistryKey rgkActualHome = Registry.LocalMachine.OpenSubKey(@"SOFTWARE\ORACLE\HOME" + strLastHome);
        string strOraHome = "";
        object objOraHome = rgkActualHome.GetValue("ORACLE_HOME");
        string strOracleHome = strOraHome = objOraHome.ToString();
        return OracleVersion.Oracle9;
    }
    return OracleVersion.Oracle0;
}

private string GetOracleHome()
{
    RegistryKey rgkLM = Registry.LocalMachine;
    RegistryKey rgkAllHome = rgkLM.OpenSubKey(@"SOFTWARE\ORACLE\ALL_HOMES");
    OracleVersion ov = this.GetOracleVersion();

    switch(ov)
    {
        case OracleVersion.Oracle10:
            {
                string[] okeys = rgkLM.OpenSubKey(@"SOFTWARE\ORACLE").GetSubKeyNames();
                foreach (string okey in okeys)
                {
                    if (okey.StartsWith("KEY_"))
                    {
                        return rgkLM.OpenSubKey(@"SOFTWARE\ORACLE\" + okey).GetValue("ORACLE_HOME") as string;
                    }
                }
                throw new Exception("No Oracle Home found");
            }
        case OracleVersion.Oracle9:
            {
                string strLastHome = "";
                object objLastHome = rgkAllHome.GetValue("LAST_HOME");
                strLastHome = objLastHome.ToString();
                RegistryKey rgkActualHome = Registry.LocalMachine.OpenSubKey(@"SOFTWARE\ORACLE\HOME" + strLastHome);
                string strOraHome = "";
                object objOraHome = rgkActualHome.GetValue("ORACLE_HOME");
                string strOracleHome = strOraHome = objOraHome.ToString();
                return strOraHome;
            }
        default:
            {
                throw new Exception("No supported Oracle Installation found");
            }
    }
}

public string GetTNSNAMESORAFilePath()
{
    string strOracleHome = GetOracleHome();
    if (strOracleHome != "")
    {
        string strTNSNAMESORAFilePath = strOracleHome + @"\NETWORK\ADMIN\TNSNAMES.ORA";
        if (File.Exists(strTNSNAMESORAFilePath))
        {
            return strTNSNAMESORAFilePath;
        }
        else
        {
            strTNSNAMESORAFilePath = strOracleHome + @"\NET80\ADMIN\TNSNAMES.ORA";
            if (File.Exists(strTNSNAMESORAFilePath))
            {
                return strTNSNAMESORAFilePath;
            }
            else
            {
                throw new SystemException("Could not find tnsnames.ora");
            }
        }
    }
    else
    {
        throw new SystemException("Could not determine ORAHOME");
    }
}
Run Code Online (Sandbox Code Playgroud)


Col*_*ard 7

在Windows上,最可能的位置是%ORACLE_HOME%/network/admin%TNS_ADMIN%(或TNS_ADMIN注册表设置).这两个几乎涵盖了所有安装.

当然,有一个没有这个文件的工作Oracle客户端是可能的.Oracle有一系列令人眼花缭乱的网络选项,并且有很多方法可以使用TNSNAMES实现工作设置.根据您在此处尝试实现的目标,您的第一个呼叫端口可能是sqlnet.ora文件,也可以在该文件中找到%ORACLE_HOME%/network/admin.这应该包含一行如下所示:

NAMES.DIRECTORY_PATH= (LDAP, TNSNAMES, HOSTNAME)
Run Code Online (Sandbox Code Playgroud)

TNSNAMES表示它将使用该TNSNAMES.ora文件(在本例中为第二个). LDAP并且HOSTNAME是解决数据库的替代方法.如果没有TNSNAMESTNSNAMES.ora文件,如果它存在于正确的位置,将被忽略.

在C#/ .NET中,这应该为您提供环境变量:

Environment.GetEnvironmentVariable("ORACLE_HOME");

Environment.GetEnvironmentVariable("TNS_ADMIN");