基于siyucms的信息系统开发(一)历时天数的设置

2024-02-07 20:50

本文主要是介绍基于siyucms的信息系统开发(一)历时天数的设置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景:做一个项目管理模块,其中有“开始时间”、“结束时间”、“历时天数”三个字段,要使:

历时天数=结束时间-开始时间

假如项目正在进行中,结束时间未明确,则

历时天数=现在时间-开始时间

在数据库中,时间每过0:00,历时天数就应该往前进一天,那么还应在数据库中设施定时事件,定时更新该字段值。因为本系统主要在本地运行,可能会经常关机,那么还应该设置mysql数据库启动时,自动更新该字段值。

实现步骤如下:

一、首先对通用的添加、修改保存方法进行修改

原有的添加保存方法:

 public function addPost(){if (Request::isPost()) {$data   = MakeBuilder::changeFormData(Request::except(['file'], 'post'), $this->tableName);$result = $this->validate($data, $this->validate);if (true !== $result) {// 验证失败 输出错误信息$this->error($result);} else {$model  = '\app\common\model\\' . $this->modelName;$result = $model::addPost($data);if ($result['error']) {$this->error($result['msg']);} else {$this->success($result['msg'], 'index');}}}}

修改为:

  public function addPost(){if (Request::isPost()) {$data   = MakeBuilder::changeFormData(Request::except(['file'], 'post'), $this->tableName);$result = $this->validate($data, $this->validate);if (true !== $result) {// 验证失败 输出错误信息$this->error($result);} else {if($data['end_date']>0)//如果添加记录的时候设置了结束日期//直接存储历时天数{$timediff=$data['end_date']-$data['start_date'];$days=intval($timediff/86400);//转换成天数$data['took_days']=$days;}else{//否则以当前时间为截止计算日期$timediff=time()-$data['start_date'];$days=intval($timediff/86400);$data['took_days']=$days;}$model  = '\app\common\model\\' . $this->modelName;$result = $model::addPost($data);if ($result['error']) {$this->error($result['msg']);} else {$this->success($result['msg'], 'index');}}}}

原有的通用修改保存的方法:

 // 修改保存public function editPost(){if (Request::isPost()) {$data   = MakeBuilder::changeFormData(Request::except(['file'], 'post'), $this->tableName);$result = $this->validate($data, $this->validate);if (true !== $result) {// 验证失败 输出错误信息$this->error($result);} else {$model  = '\app\common\model\\' . $this->modelName;$result = $model::editPost($data);if ($result['error']) {$this->error($result['msg']);} else {$this->success($result['msg'], 'index');}}}}

修改为如下方法:

  public function editPost(){if (Request::isPost()) {$data   = MakeBuilder::changeFormData(Request::except(['file'], 'post'), $this->tableName);$result = $this->validate($data, $this->validate);if (true !== $result) {// 验证失败 输出错误信息$this->error($result);} else {//如果已填写实际完成时间if($data['end_date']>0)//如果添加记录的时候设置了结束日期//直接存储历时天数{$timediff=$data['end_date']-$data['start_date'];$days=intval($timediff/86400);//转换成天数$data['took_days']=$days;}else{//否则以当前时间为截止计算日期$timediff=time()-$data['start_date'];$days=intval($timediff/86400);$data['took_days']=$days;}$model  = '\app\common\model\\' . $this->modelName;$result = $model::editPost($data);if ($result['error']) {$this->error($result['msg']);} else {$this->success($result['msg'], 'index');}}}}

需要注意的是,“历时天数”这个字段是后台计算得出,不要显示在添加、修改页面,以避免人为输入。

 二、对数据库设置定时事件:

可以先查看定时任务的是否开启。通过以下命令:

show variables like '%sche%'

如果其设置值为为 OFF 或 0 ,通过执行下列语句,来开启event_scheduler

set global event_scheduler =1

把设置为设为ON 或 1。

在配置文件中添加event_scheduler=ON,保持事件开启。

 添加如下代码,即需定时执行的代码:

UPDATE tp_product SET took_days = DATEDIFF(NOW(),FROM_UNIXTIME(start_date)) WHERE project_status='2';

其中“project_satus”字段意为“项目状态”,2对应的是“正在推进”状态,也就是说对所有项目中状态为“正在推进”项目进行更新。已经完结的项目不更新。

设置运行方式为“从2011-11-05零点开始,每天运行一次”。

 三、对数据库设置启动时运行脚本文件:

找到数据库配置文件,我这里是Windows下的my.ini文件,添加代码设置自动运行的文件脚本目录:

在updatetime.sql中添加如下代码:

USE lmsite;
UPDATE tp_business SET elapsed_time = concat(DATEDIFF(NOW(),FROM_UNIXTIME(start_time)),'天') WHERE work_status='2';
UPDATE tp_project SET took_days = DATEDIFF(NOW(),FROM_UNIXTIME(start_date)) WHERE project_status='2';

 注意要保存为UTF-8编码格式。即可。

这篇关于基于siyucms的信息系统开发(一)历时天数的设置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/lumin509/article/details/121370675
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/688898

相关文章

PyQt5 GUI 开发的基础知识

《PyQt5GUI开发的基础知识》Qt是一个跨平台的C++图形用户界面开发框架,支持GUI和非GUI程序开发,本文介绍了使用PyQt5进行界面开发的基础知识,包括创建简单窗口、常用控件、窗口属性设... 目录简介第一个PyQt程序最常用的三个功能模块控件QPushButton(按钮)控件QLable(纯文本

Go语言编译环境设置教程

《Go语言编译环境设置教程》Go语言支持高并发(goroutine)、自动垃圾回收,编译为跨平台二进制文件,云原生兼容且社区活跃,开发便捷,内置测试与vet工具辅助检测错误,依赖模块化管理,提升开发效... 目录Go语言优势下载 Go  配置编译环境配置 GOPROXYIDE 设置(VS Code)一些基本

小白也能轻松上手! 路由器设置优化指南

《小白也能轻松上手!路由器设置优化指南》在日常生活中,我们常常会遇到WiFi网速慢的问题,这主要受到三个方面的影响,首要原因是WiFi产品的配置优化不合理,其次是硬件性能的不足,以及宽带线路本身的质... 在数字化时代,网络已成为生活必需品,追剧、游戏、办公、学习都离不开稳定高速的网络。但很多人面对新路由器

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

linux hostname设置全过程

《linuxhostname设置全过程》:本文主要介绍linuxhostname设置全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录查询hostname设置步骤其它相关点hostid/etc/hostsEDChina编程A工具license破解注意事项总结以RHE

Python设置Cookie永不超时的详细指南

《Python设置Cookie永不超时的详细指南》Cookie是一种存储在用户浏览器中的小型数据片段,用于记录用户的登录状态、偏好设置等信息,下面小编就来和大家详细讲讲Python如何设置Cookie... 目录一、Cookie的作用与重要性二、Cookie过期的原因三、实现Cookie永不超时的方法(一)

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

Qt 设置软件版本信息的实现

《Qt设置软件版本信息的实现》本文介绍了Qt项目中设置版本信息的三种常用方法,包括.pro文件和version.rc配置、CMakeLists.txt与version.h.in结合,具有一定的参考... 目录在运行程序期间设置版本信息可以参考VS在 QT 中设置软件版本信息的几种方法方法一:通过 .pro

Python中对FFmpeg封装开发库FFmpy详解

《Python中对FFmpeg封装开发库FFmpy详解》:本文主要介绍Python中对FFmpeg封装开发库FFmpy,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、FFmpy简介与安装1.1 FFmpy概述1.2 安装方法二、FFmpy核心类与方法2.1 FF

基于Python开发Windows屏幕控制工具

《基于Python开发Windows屏幕控制工具》在数字化办公时代,屏幕管理已成为提升工作效率和保护眼睛健康的重要环节,本文将分享一个基于Python和PySide6开发的Windows屏幕控制工具,... 目录概述功能亮点界面展示实现步骤详解1. 环境准备2. 亮度控制模块3. 息屏功能实现4. 息屏时间