• InstallShield高级应用检查是否安装ORACLE或SQL Server


    实现原理:判断是否存在,是通过查找注册表是否含有相应标识来判断的。

    注意:XP与WIN7系统注册表保存方式不一样,32位与64位操作系统注册表保存方式也不一样,需要分别判断。在此只判断32位操作系统的情况。

    源码:

    ////检查是否有安装Oracle
    function NUMBER CheckOracleISExist()
    STRING svOraclePath,nvValue;
    NUMBER nKeyType,nvType, nvSize;
    begin
    // defaut regedit root
    RegDBSetDefaultRoot(HKEY_LOCAL_MACHINE);
    //oralce regedit path
    if(RegDBGetKeyValueEx("SOFTWARE\\ORACLE\\ALL_HOMES","DEFAULT_HOME",nvType,nvValue,nvSize) = 0) then
    return 0;
    endif;
    return -1;
    end;

    // SQL Server 2000, SQL Server 2005, SQL Server 2008,
    // SQL Server 2005 Express,SQL Server 2008 Express
    //检查是否有安装SQL Server
    function NUMBER CheckSQLServer()
    STRING nvValue;
    NUMBER nvType, nvSize;
    begin
    //return -1;
    // defaut regedit root
    RegDBSetDefaultRoot(HKEY_LOCAL_MACHINE);
    // SQL Server 2000
    if(RegDBGetKeyValueEx("SOFTWARE\\Microsoft\\Microsoft SQL Server","InstalledInstances",nvType,nvValue,nvSize) = 0) then
    return 0;
    endif;
    //SQL Server 2005 Version
    if(RegDBGetKeyValueEx("SOFTWARE\\Microsoft\\Microsoft SQL Server 2005 Redist\\BOL\\2052\\CurrentVersion","Version",nvType,nvValue,nvSize) = 0) then
    return 0;
    endif;
    //SQL Server 2008 Express
    //if(RegDBGetKeyValueEx("SOFTWARE\\Microsoft\\Microsoft SQL Server 2008 Redist\\SQLNCLI10\\2052\\CurrentVersion","Version",nvType,nvValue,nvSize) = 0) then
    // return 0;
    //endif;
    // Express
    if(RegDBGetKeyValueEx("SOFTWARE\\Microsoft\\Microsoft SQL Server\SQLEXPRESS\setup","SQLPath",nvType,nvValue,nvSize) = 0) then
    return 0;
    endif;
    return -1;
    end;

    作者:chhuic

    出处:http://chhuic.cnblogs.com
    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

  • 相关阅读:
    函数节流和防抖
    记一次面试
    继承
    对象的几种创建方法
    对象的简单认识
    HTTP、HTTPS、SOCKS代理的概念(到底是什么意思?)
    Nginx 相关介绍(正向代理和反向代理区别)
    Markdown:怎么用?以及为什么要用Markdown?
    Google 凭什么要赔给 Oracle 88 亿?
    雷军:《我十年的程序员生涯》系列之三(失败的大学创业经历)
  • 原文地址:https://www.cnblogs.com/chhuic/p/2495631.html
Copyright © 2020-2023  润新知