员工管理功能

一、新增员工

1.代码实现 

在数据库employee表中,username(唯一约束)和status(默认为1)这两个字段比较特殊。

在EmployeeController类中写这段代码

2.完善代码

这段代码存在一个问题:当新增员工时输入的账号已经存在,但username设置了唯一约束,程序就会抛出异常。

java.sql.SQLIntegrityConstraintViolationException: Duplicate entry 'shimin' for key 'employee.idx_username'

我们可以对程序进行异常捕获,通常有两种处理方式:

①在Controller方法中加入try、catch进行异常捕获

但这样就要写很多try、catch了(如果有很多异常)

②使用异常处理器进行全局异常捕获(这里使用这个)

在common文件夹下创建了一个GlobalExceptionHandler类

 二、员工信息分页查询

1.配置分页插件

 在config文件夹下创建一个MybatisPlusConfig类

2.查询数据

(1)代码实现

 (2)报错解决

 这个StringUtils类很容易导入错误,它应该是

import org.apache.commons.lang.StringUtils;

如果没有这个包,检查是否导入了这个依赖 

        <dependency>
            <groupId>commons-lang</groupId>
            <artifactId>commons-lang</artifactId>
            <version>2.6</version>
        </dependency>

三、启用、禁用员工 

2.问题解决

(1)问题

虽然没有报错,但是点击了禁用后,并没有发生改变,还是正常的状态。检查发现是因为id不对,在数据库中查不到

因为js对long型数据进行处理时丢失了精度,它只能处理到16位,后面的3位四舍五入了。

所以我们可以在服务端给页面响应json数据时进行处理,将long型数据统一转为String字符串。

(2)解决 

我们可以使用springmvc提供的消息转换器,在WebMvcConfig配置类中扩展消息转换器。

当java对象转json时,由消息转换器统一进行处理,这时它会调用到对象转换器,这个对象转换器底层是使用Jackson来进行java对象到json数据的转换(我们在这个转换器中可以设置使得转变某些数据的类型)

消息转换器

package com.example.takeout.common;

import com.fasterxml.jackson.databind.DeserializationFeature;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.module.SimpleModule;
import com.fasterxml.jackson.databind.ser.std.ToStringSerializer;
import com.fasterxml.jackson.datatype.jsr310.deser.LocalDateDeserializer;
import com.fasterxml.jackson.datatype.jsr310.deser.LocalDateTimeDeserializer;
import com.fasterxml.jackson.datatype.jsr310.deser.LocalTimeDeserializer;
import com.fasterxml.jackson.datatype.jsr310.ser.LocalDateSerializer;
import com.fasterxml.jackson.datatype.jsr310.ser.LocalDateTimeSerializer;
import com.fasterxml.jackson.datatype.jsr310.ser.LocalTimeSerializer;
import java.math.BigInteger;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.LocalTime;
import java.time.format.DateTimeFormatter;
import static com.fasterxml.jackson.databind.DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES;

/**
 * 对象映射器:基于jackson将Java对象转为json,或者将json转为Java对象
 * 将JSON解析为Java对象的过程称为 [从JSON反序列化Java对象]
 * 从Java对象生成JSON的过程称为 [序列化Java对象到JSON]
 */
public class JacksonObjectMapper extends ObjectMapper {

    public static final String DEFAULT_DATE_FORMAT = "yyyy-MM-dd";
    public static final String DEFAULT_DATE_TIME_FORMAT = "yyyy-MM-dd HH:mm:ss";
    public static final String DEFAULT_TIME_FORMAT = "HH:mm:ss";

    public JacksonObjectMapper() {
        super();
        //收到未知属性时不报异常
        this.configure(FAIL_ON_UNKNOWN_PROPERTIES, false);

        //反序列化时,属性不存在的兼容处理
        this.getDeserializationConfig().withoutFeatures(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES);


        SimpleModule simpleModule = new SimpleModule()
                .addDeserializer(LocalDateTime.class, new LocalDateTimeDeserializer(DateTimeFormatter.ofPattern(DEFAULT_DATE_TIME_FORMAT)))
                .addDeserializer(LocalDate.class, new LocalDateDeserializer(DateTimeFormatter.ofPattern(DEFAULT_DATE_FORMAT)))
                .addDeserializer(LocalTime.class, new LocalTimeDeserializer(DateTimeFormatter.ofPattern(DEFAULT_TIME_FORMAT)))

//                addSerializer添加序列化器
                .addSerializer(BigInteger.class, ToStringSerializer.instance)
                .addSerializer(Long.class, ToStringSerializer.instance)
                .addSerializer(LocalDateTime.class, new LocalDateTimeSerializer(DateTimeFormatter.ofPattern(DEFAULT_DATE_TIME_FORMAT)))
                .addSerializer(LocalDate.class, new LocalDateSerializer(DateTimeFormatter.ofPattern(DEFAULT_DATE_FORMAT)))
                .addSerializer(LocalTime.class, new LocalTimeSerializer(DateTimeFormatter.ofPattern(DEFAULT_TIME_FORMAT)));

        //注册功能模块 例如,可以添加自定义序列化器和反序列化器
        this.registerModule(simpleModule);
    }
}

四、编辑员工信息

  • 10
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值