<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
注册表还不能解决问题,只能改程序了,上效果:
提示数据库连接失败,并通过倒计时的方法 启动自动连接数据库的方法,取消后不再连接数据库(即退出软件){灵感来自于连接宽带时候连不上自动重连}