c# 定期重启程序操作

1 先说说重启//这部分是转载的

一、Restart方法

csharp 复制代码
System.Windows.Forms.Application.Restart();

经测试发现有时候只会关闭程序,并不会重新启动

二、Process.Start()和Exit()

csharp 复制代码
System.Diagnostics.Process.Start(System.Reflection.Assembly.GetExecutingAssembly().Location);
Application.Exit();

经测试发现有时候也只会关闭程序,并不会重新启动

三、进程的Start和Kill方法

csharp 复制代码
System.Diagnostics.Process.Start(System.Reflection.Assembly.GetExecutingAssembly().Location);
System.Diagnostics.Process.GetCurrentProcess().Kill();
 

经测试使用进程进行重启比较稳定。

csharp 复制代码
//开启新的实例  
System.Diagnostics.Process.Start(Application.ExecutablePath);
//关闭当前实例    
System.Diagnostics.Process.GetCurrentProcess().Kill();
Application.Exit();//退出当前项目,如果是子项目,则不会停止主项目
System.Environment.Exit(0);//停止所有项目

四:使用Process方式

csharp 复制代码
Process p = new Process();
p.StartInfo.FileName = System.AppDomain.CurrentDomain.BaseDirectory + "xxx.exe";
p.StartInfo.UseShellExecute = false;
p.Start(); 
Application.Current.Shutdown();

未测试。

带参数重启

csharp 复制代码
Process proc = new Process();
proc.StartInfo.FileName = @"MyExecutable.exe";
proc.StartInfo.Arguments = "\"C:\\My Docs\\SomeDirectory\\MyXMLPath.xml\"";
proc.Start();

原文链接:https://blog.csdn.net/yizhou2010/article/details/129583150

我的数据库结构:

csharp 复制代码
GO

/****** Object:  Table [dbo].[RestartLog]    Script Date: 09/04/2023 20:45:07 ******/
SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

CREATE TABLE [dbo].[RestartLog](
	[Id] [int] IDENTITY(1,1) NOT NULL,
	[RestartDate] [datetime] NULL,
	[ThisPCName] [nvarchar](80) NULL,
	[IPAdd] [nvarchar](80) NULL,
	[CreateDate] [datetime] NULL
) ON [PRIMARY]

GO

EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'重启时间' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'RestartLog', @level2type=N'COLUMN',@level2name=N'RestartDate'
GO

EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'计算机名' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'RestartLog', @level2type=N'COLUMN',@level2name=N'ThisPCName'
GO

ALTER TABLE [dbo].[RestartLog] ADD  CONSTRAINT [DF_RestartLog_CreateDate]  DEFAULT (getdate()) FOR [CreateDate]
GO

我的DAL处理操作方法:

csharp 复制代码
 /// <summary>
        /// 主要的数据操作
        /// </summary>
        /// <returns></returns>
        public ResultMsg InsertAndUpdate(int HourRestart)
        {
            ResultMsg msg = new ResultMsg();
            try
            {
                string SqlStr = $@" DECLARE   @IPadd nvarchar(80); ---Ip地址
                              DECLARE   @PCName nvarchar(100); --计算机名
                              DECLARE   @TempId  int ;--0无数据,1时间未到,2需要重启
                              DECLARE   @OutInt  int;---返回数据
                              DECLARE   @RestartHour  int;---重启时间
                              Select    @IPadd= CONVERT( nvarchar(80) ,CONNECTIONPROPERTY('CLIENT_NET_ADDRESS') ) ; 
                              Select    @PCName= HOST_NAME(); 
                              set @RestartHour={HourRestart};
                              if  exists(  SELECT  * FROM [RestartLog] WHERE [IPAdd] = @IPadd   ) 
                                  begin 
                                      if exists(  SELECT  * FROM [RestartLog] WHERE [IPAdd] = @IPadd  and datediff(hour,RestartDate,getdate())>@RestartHour)
                                      begin 
                                             update  [RestartLog] set  RestartDate = GETDATE() WHERE [IPAdd] = @IPadd  and datediff(hour,RestartDate,getdate())>@RestartHour;
                                             set @OutInt = 2;--需要重启
                                      end 
                                      else
                                      begin
                                           set @OutInt = 1;--时间未到不需要需要重启
                                      end  
                                  end 
                              else ----无数据,需要插入数据
                                 begin
                                     insert  [RestartLog] ( [RestartDate] ,[ThisPCName] ,[IPAdd],[CreateDate]) values (GETDATE(),@PCName,@IPadd,GETDATE());
                                     set @OutInt = 0; 
                                  end
                                select @OutInt; ";
                msg.ReturnInt = DapperDbHelper.ExecuteScalar<int>(SqlStr);
                msg.Success = true;
            }
            catch (Exception ex)
            {
                msg.Success = false;
                msg.ErrMsg = ex.Message; 
            }
            return msg;

        }
相关推荐
码云骑士2 分钟前
25-数据库连接池-Django连接复用与连接数上限控制
数据库·python·django
叫我:松哥3 分钟前
基于Flask的在线考试刷题系统设计与实现,集智能练习、过程追踪、深度分析与个性化引导
数据库·人工智能·后端·python·flask·boostrap
倒流时光三十年5 分钟前
PostgreSQL LEAST 表达式函数详解
数据库·postgresql
thinking_talk5 分钟前
2026中国MongoDB云服务厂商能力榜:选型对比与效能评估
数据库·mongodb·腾讯云
dishugj6 分钟前
从应用--DB发一条 SQL的数据流向
数据库·oracle
杨云龙UP8 分钟前
Oracle 19c 单机环境安装目录规划与磁盘永久挂载操作指南_2026-06-15
运维·服务器·数据库·oracle·部署·目录·规划
JOJO数据科学11 分钟前
DbGate Electron 鸿蒙 PC 适配全记录:从桌面数据库工具到 OpenHarmony HAP
数据库·electron·harmonyos
初圣魔门首席弟子13 分钟前
AI Agent 核心原理:工具调用(Function Calling)完整工作流程详解
前端·数据库·人工智能
半夜修仙13 分钟前
延迟队列的介绍及常见问题
java·数据库·中间件·rabbitmq
herinspace16 分钟前
管家婆云辉煌开单优化
服务器·数据库·电脑·管家婆软件·财务软件