winform软件开机启动早于sqlserver服务,导致连接数据库失败

<add name="sqlserverpath" connectionString="D:\Program Files\Microsoft SQL Server\MSSQL.2\MSSQL\Binn\sqlservr.exe"/>
app.config中的数据库服务程序路径

//获取程序执行路径..
             string starupPath = Application.ExecutablePath;
             //class Micosoft.Win32.RegistryKey. 表示Window注册表中项级节点,此类是注册表装.
             RegistryKey loca = Registry.LocalMachine;
             RegistryKey run = loca.CreateSubKey(@"SOFTWARE\Microsoft\Windows\CurrentVersion\Run");
             try
             {
                 string sqlserverpath = System.Configuration.ConfigurationManager.ConnectionStrings["sqlserverpath"].ConnectionString.Trim();
                 //SetValue:存储值的名称
                 if (IsAutoRun == false)
                 {
                     run.DeleteValue("CMS", false);//取消开机运行
                     run.DeleteValue("2CMS", false);//取消开机运行
                     run.DeleteValue("1sqlserver", false);
                 }
                 else
                 {
                     if (sqlserverpath != "" && File.Exists(sqlserverpath))
                     {
                         run.SetValue("1sqlserver", "\"" + sqlserverpath + "\" -s -autorun");//1、2、3表示开机启动顺序,此处数据库服务先启动,然后启动软件程序 
                         run.SetValue("2CMS", starupPath);//设置开机运行
                     }
                     else
                     {
                         MessageBox.Show("数据库地址不存在,开机启动设置失败!");
                     }
                 }
                 loca.Close();
             }
             catch(Exception ex)
             {
                 string nihao = "";
                 nihao = "123";
             }

参考:http://wenwen.soso.com/z/q231044698.htm

注册表还不能解决问题,只能改程序了,上效果:


提示数据库连接失败,并通过倒计时的方法 启动自动连接数据库的方法,取消后不再连接数据库(即退出软件){灵感来自于连接宽带时候连不上自动重连}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值