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
<think>好的,我现在需要帮用户解决关于如何继续开发大学生实习就业系统的问题。用户已经基于若依框架搭建了前后端分离的系统,并创建了学生、学院、班级信息表,现在需要进一步的开发指导。首先,我得理清用户的需求和当前进展。 用户提到的系统是基于SpringBoot和Vue.js,使用若依框架。若依本身是一个权限管理系统,可能已经提供了用户管理、角色权限等基础功能。用户已经创建了三个表,接下来需要扩展功能模块,比如实习管理、就业管理、企业对接等。我应该从系统架构、功能扩展、数据关联、权限控制、性能优化等方面给出建议。 首先,模块设计方面,可能需要划分学生端、企业端和管理员端。学生端需要简历管理、岗位浏览、投递记录等;企业端需要发布岗位、查看投递、面试邀请;管理员则负责审核、数据统计等。用户已经有的表结构可能需要扩展,比如添加实习岗位表、投递记录表、简历表等。同时,要考虑如何关联学生与学院、班级,可能需要外键约束。 接下来是后端开发。需要确定实体类的关系,比如学生属于班级,班级属于学院。使用MyBatis-Plus可以简化CRUD操作,但复杂的查询可能需要自定义SQL或者使用QueryWrapper。接口设计要遵循RESTful风格,同时注意权限控制,比如企业只能修改自己的岗位信息。另外,业务逻辑如投递状态的变化、面试流程的管理需要详细设计。 前端开发部分,若依的Vue前端已经有一套组件,可以复用现有的布局和组件。学生主页可能需要分页展示岗位,使用Element UI的表格和分页组件。简历编辑可能需要表单验证,文件上传组件用于简历附件。路由权限需要根据角色配置,确保学生和企业只能访问对应的页面。 数据可视化是用户提到的引用中有涉及,可能需要使用ECharts或AntV来展示就业率、热门岗位等统计信息。大屏展示可能需要单独的路由和布局,后端提供聚合数据的接口。 系统集成方面,短信服务可以用阿里云,邮件通知用Spring的JavaMail。消息队列如RabbitMQ处理异步任务,比如发送通知。同时,需要考虑缓存机制,用Redis缓存热点数据,如频繁访问的岗位信息。 测试与部署方面,单元测试覆盖核心业务,集成测试检查模块交互。部署可以使用Nginx反向代理,后端打包成JAR使用Docker容器化,数据库主从复制提高可用性。 此外,用户提供的引用中提到了一些功能,比如讨论区管理、实习信息答复,这些可能需要额外的模块。引用[4]提到老师管理讨论区,所以需要考虑权限和模块设计。数据可视化大屏在引用[3]中也有涉及,可能需要参考相关实现。 需要提醒用户注意若依框架的权限机制,合理分配角色和菜单权限。比如学生、企业、管理员、教师可能有不同的权限层级。同时,现有表结构是否需要补充字段,比如学生表中的联系方式、状态等。 可能遇到的问题包括数据一致性,比如删除学院时如何处理关联的学生和班级。建议使用逻辑删除,或者在外键约束时处理级联操作。性能方面,分页查询需要优化,避免全表扫描。 最后,建议用户参考已有的若依文档和社区资源,遇到具体问题可以查阅相关模块的实现方式。同时,分阶段开发,先完成核心功能再逐步扩展,确保每个模块测试通过后再继续。</think>### 大学生实习就业系统开发指南(基于SpringBoot+Vue) #### 一、系统架构优化建议 1. **模块划分**: - 学生端:简历管理、岗位浏览、投递记录、面试管理 - 企业端:岗位发布、简历筛选、面试邀约 - 管理员端:学院/班级审核、企业资质审核、数据统计分析 - 教师端:实习过程监管、讨论区管理(引用[4]) 2. **表结构扩展建议**: ```sql -- 实习岗位表 CREATE TABLE internship_position ( position_id BIGINT PRIMARY KEY, company_id BIGINT REFERENCES company_info, title VARCHAR(100), requirement TEXT, start_date DATE, status TINYINT DEFAULT 1 ); -- 简历投递记录表 CREATE TABLE delivery_record ( record_id BIGINT PRIMARY KEY, student_id BIGINT REFERENCES student_info, position_id BIGINT REFERENCES internship_position, delivery_time DATETIME, status ENUM('pending','reviewing','rejected','accepted') ); ``` #### 二、核心功能开发步骤 **1. 后端开发(SpringBoot)** - **实体关系设计**: ```java // 学院-班级级联关系示例 public class College { private Long collegeId; private String collegeName; private List<Class> classes; } public class Student { private Long studentId; @ManyToOne @JoinColumn(name = "class_id") private Class studentClass; } ``` - **接口开发要点**: ```java // 分页查询岗位接口示例 @GetMapping("/positions") @PreAuthorize("@ss.hasPermi('internship:position:list')") public TableDataInfo list(InternshipPosition position) { startPage(); List<InternshipPosition> list = positionService.selectPositionList(position); return getDataTable(list); } // 投递状态机处理 @PostMapping("/delivery/{recordId}/status") public AjaxResult updateDeliveryStatus(@PathVariable Long recordId, @RequestParam String status) { DeliveryRecord record = deliveryService.getById(recordId); if (!StatusTransition.isValid(record.getStatus(), status)) { return error("状态转换非法"); } deliveryService.updateStatus(recordId, status); return success(); } ``` **2. 前端开发(Vue.js)** - **岗位列表组件**: ```vue <template> <el-table :data="positionList" @row-click="handleRowClick"> <el-table-column prop="title" label="职位名称"></el-table-column> <el-table-column prop="company.name" label="企业"></el-table-column> <el-table-column label="操作"> <template #default="scope"> <el-button @click="handleDelivery(scope.row)">立即投递</el-button> </template> </el-table-column> </el-table> <el-pagination @current-change="handlePageChange" :page-size="queryParams.pageSize" :total="total"> </el-pagination> </template> ``` - **权限控制**: ```javascript // 路由守卫配置 router.beforeEach((to, from, next) => { if (to.meta.roles && !hasAnyRole(to.meta.roles)) { next({ path: '/401' }); } else { next(); } }) ``` #### 三、关键技术实现 1. **文件上传管理**: ```java // SpringBoot文件上传接口 @PostMapping("/resume/upload") public AjaxResult uploadResume(@RequestParam("file") MultipartFile file) { String fileName = fileStorageService.store(file); return AjaxResult.success().put("url", fileName); } ``` 2. **数据可视化集成**: ```vue <template> <div ref="chart" style="width:600px;height:400px"></div> </template> <script> import * as echarts from 'echarts'; export default { mounted() { this.initChart(); }, methods: { async initChart() { const { data } = await getEmploymentStats(); const chart = echarts.init(this.$refs.chart); chart.setOption({ tooltip: { trigger: 'item' }, series: [{ type: 'pie', data: data.sectors }] }); } } } </script> ``` #### 四、系统集成建议 1. **第三方服务接入**: ```yaml # application.yml配置示例 aliyun: sms: access-key-id: ${ACCESS_KEY} access-secret: ${SECRET} sign-name: "实习系统" template-code: SMS_123456 ``` 2. **安全增强措施**: ```java // 敏感数据脱敏处理 @JsonSerialize(using = DataMaskingSerializer.class) private String idCard; // 自定义注解实现 @Target(ElementType.FIELD) @Retention(RetentionPolicy.RUNTIME) @JacksonAnnotationsInside @JsonSerialize(using = DataMaskingSerializer.class) public @interface DataMasking { MaskType type() default MaskType.NAME; } ``` #### 五、持续开发建议 1. **迭代计划示例**: ``` 第一阶段:基础功能(学生/企业信息管理+岗位发布) 第二阶段:交互功能(简历投递+消息通知) 第三阶段:高级功能(数据大屏+智能推荐) ``` 2. **代码质量保障**: ```xml <!-- 代码规范检查配置 --> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-checkstyle-plugin</artifactId> <configuration> <configLocation>google_checks.xml</configLocation> </configuration> </plugin> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值