基于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的信息系统开发(一)历时天数的设置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/688898

相关文章

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

PyCharm如何设置新建文件默认为LF换行符

《PyCharm如何设置新建文件默认为LF换行符》:本文主要介绍PyCharm如何设置新建文件默认为LF换行符问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录PyCharm设置新建文件默认为LF换行符设置换行符修改换行符总结PyCharm设置新建文件默认为LF

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

Linux上设置Ollama服务配置(常用环境变量)

《Linux上设置Ollama服务配置(常用环境变量)》本文主要介绍了Linux上设置Ollama服务配置(常用环境变量),Ollama提供了多种环境变量供配置,如调试模式、模型目录等,下面就来介绍一... 目录在 linux 上设置环境变量配置 OllamPOgxSRJfa手动安装安装特定版本查看日志在

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

基于Python开发批量提取Excel图片的小工具

《基于Python开发批量提取Excel图片的小工具》这篇文章主要为大家详细介绍了如何使用Python中的openpyxl库开发一个小工具,可以实现批量提取Excel图片,有需要的小伙伴可以参考一下... 目前有一个需求,就是批量读取当前目录下所有文件夹里的Excel文件,去获取出Excel文件中的图片,并

Ubuntu中Nginx虚拟主机设置的项目实践

《Ubuntu中Nginx虚拟主机设置的项目实践》通过配置虚拟主机,可以在同一台服务器上运行多个独立的网站,本文主要介绍了Ubuntu中Nginx虚拟主机设置的项目实践,具有一定的参考价值,感兴趣的可... 目录简介安装 Nginx创建虚拟主机1. 创建网站目录2. 创建默认索引文件3. 配置 Nginx4

基于Python开发PDF转PNG的可视化工具

《基于Python开发PDF转PNG的可视化工具》在数字文档处理领域,PDF到图像格式的转换是常见需求,本文介绍如何利用Python的PyMuPDF库和Tkinter框架开发一个带图形界面的PDF转P... 目录一、引言二、功能特性三、技术架构1. 技术栈组成2. 系统架构javascript设计3.效果图

如何关闭 Mac 触发角功能或设置修饰键? mac电脑防止误触设置技巧

《如何关闭Mac触发角功能或设置修饰键?mac电脑防止误触设置技巧》从Windows换到iOS大半年来,触发角是我觉得值得吹爆的MacBook效率神器,成为一大说服理由,下面我们就来看看mac电... MAC 的「触发角」功能虽然提高了效率,但过于灵敏也让不少用户感到头疼。特别是在关键时刻,一不小心就可能触