问题起因:在Swagger-ui掉用接口时候,参数传到后台控制器断点发现有值, ID>> controller 有值,之前有过类似的情况,比如查询时候只出现部分字段的值。
解决办法:经过了解,在使用 mybatis 时候需要将数据库的字段与程序内的实体名称进行一一对应。另外要注意的事情是,数据库中如果是小写下划线形式,则需要转换为驼峰式命名法。
例:
@TableId("u_id") //这里映射数据库字段、
public String uId; //这里是程序系统中命名方式
@TableField("u_name")
public String uName;
还有一种,通常会采用DTO(数据传输对象)与前台交互,在创建 DTO 类时候也需要注意,此时 DTO 类中的对象需要与实体类中的对象名称要保持一致,也就是说你在实体类中用什么对象名称,在 DTO 中的对象也就要用什么名字。
例:
//DTO
@ApiModelProperty(value = "ID", name = "ID")
public String uID;
@ApiModelProperty(value = "NAME", name = "uName")
public String uName;
//entity
@TableId("u_id")
public String uID;
@TableField("u_name")
public String uName;
命名可能不规范,只是做个例子。之前因为疏忽,将 DTO 中 的roleID 写成了大写,在 dto.setuID(val)时候值设置不进来,但是uName 可以用,然后尝试把 entity 修改一下,发现可以用了。其实应该是修改 DTO 里面的。
ps:如果数据库中字段是下划线类的,在程序中影射一样要采用下划线转驼峰式命名,否则可能会为 null !
自己遇到的错误,简单总结一下,如果有理解不对的地方,希望能有大佬们能指导指导。