column_timestamp plugin

  有些时候,我们可能需要记录某些列的更新时间,类似于rails的timestamps。手工一一处理稍显繁琐,于是将其抽取出来,写成了一个简单的plugin--column_timestamp,自动记录一些简单列的更新时间。

  •   使用方法

  1.将column_timestamp放到plugins目录。

  2.在表中针对要记录更新时间的列建立一个新列:[column_name]_updated_at。

  3.或者,在migration中使用:column_timestamp => true参数。例如:

 def self.up
    create_table :my_table do |t|
    t.string :name
      t.string :status,:column_timestamp => true
      t.timestamps
    end
  end
  

  这样,rails在执行migration的时候就会自动生成"status_updated_at"列。

  4.OK。开始工作了。每当status的值改变,status_updated_at就会自动记录更新的时间。

  5.如果要停止记录XXX_update_at,只需要在相应的model调用suppress_column_timestamps,例如:

class MyModel < ActiveRecord::Base
  suppress_column_timestamps
  ...
end
  • 版本问题 

  在2.0.2中通过。如果要在2.1+跑,可以将column_timestamp/vendor删除。并且注释column_timestamp/init.rb中的

require File.join(File.dirname(__FILE__),"/vendor/dirty_attr/init")

 

2008.10.15  23:59 星期三

我将开发一个大学生实习就业系统,工作任务如下: 系统开发使用Java语言,开发模式采用SpringBoot后台开发和Vue前端框架相结合。系统功能角色包括系统管理员(学校端管理)、学生(学生端模块)和企业(企业招聘管理模块)三个部分。企业招聘管理模块的内容包括系统首页、在线招聘、学生认证、创建简历、简历投递、在线招聘、就业指导、问卷调查等。学校端管理员教师审核企业的平台注册信息,并针对企业上传的招聘信息进行审核,审核通过的信息学生方可看见。负责班级学生实习情况统计,学院领导可查看学院全体学生的实习等。实习系统学生端模块学生通过系统浏览企业发布的招聘岗位,在线制作或上传简历并投递到心仪的企业,参加线上企业招聘会。在企业面试成功、签订协议后,由学校端管理模块对学生协议签订和实际求职情况进行审核,审核通过后,学生可上岗。 我打算使用若依前后端分离版本进行开发,现在我已经搭建好了若依脚手架。在角色管理中创建好了,students和Boss两个角色。 当前我已经建立了学生信息表、学院信息表、班级信息表。 表结构如下: -- ---------------------------- -- Table structure for class_info -- ---------------------------- DROP TABLE IF EXISTS `class_info`; CREATE TABLE `class_info` ( `class_id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '班级ID(主键)', `class_name` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL COMMENT '班级名称(格式如:计算机2021级1班)', `college_id` bigint(20) NOT NULL COMMENT '所属学院ID(外键)', `class_teacher` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NULL DEFAULT NULL COMMENT '班主任姓名', `student_count` int(11) NULL DEFAULT 0 COMMENT '班级学生人数(统计字段)', `create_time` datetime NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', `update_time` datetime NULL DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间', PRIMARY KEY (`class_id`) USING BTREE, INDEX `idx_college_id`(`college_id`) USING BTREE, CONSTRAINT `fk_class_college` FOREIGN KEY (`college_id`) REFERENCES `college_info` (`college_id`) ON DELETE CASCADE ON UPDATE CASCADE ) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci COMMENT = '班级信息表' ROW_FORMAT = Dynamic; SET FOREIGN_KEY_CHECKS = 1; -- ---------------------------- -- Table structure for college_info -- ---------------------------- DROP TABLE IF EXISTS `college_info`; CREATE TABLE `college_info` ( `college_id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '学院ID(主键)', `college_name` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL COMMENT '学院名称(唯一)', `college_leader` varchar(20) CHARACTER SET utf8mb4 COLLATE ut
最新发布
03-12
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值