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

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


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

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 &#39;EastRiver&#39; 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...