一個問題:向comment表添加記錄時,報錯, 無法設置值。
reflection.ReflectionException: Could not set property 'id' of 'class com.awen.entity.Comment' with value '1246084348583632898' Cause: java.lang.IllegalArgumentException: argument type mismatch
我的comment表中設計的id為char(19),字符類型。而我對應的實體類ProductLike中id
設置的也是字符類型, 那是什么錯誤呢?
@ApiModelProperty(value = "評論id")
@TableId(value = "id", type = IdType.ID_WORKER)
private String id;
但我加了@TableId(value = "id", type = IdType.ID_WORKER),錯誤了。
ID_WORKER是全局唯一ID (UUID) ,而我的是字符串要字符串全局唯一ID ,那就是ID_WORKER_STR。 改為ID_WORKER_STR吧 ,可以跑了。
@ApiModelProperty(value = "評論id")
@TableId(value = "id", type = IdType.ID_WORKER_STR)
private String id;
還有其他就是 Long id , Integer id問題。
記錄:
@Getter
public enum IdType {
/** * 數據庫ID自增 */
AUTO(0),
/** * 該類型為未設置主鍵類型 */
NONE(1),
/** * 用戶輸入ID * 該類型可以通過自己注冊自動填充插件進行填充 */
INPUT(2),
/* 以下3種類型、只有當插入對象ID 為空,才自動填充。 */
/** * 全局唯一ID (idWorker) */
ID_WORKER(3),
/** * 全局唯一ID (UUID) */
UUID(4),
/** * 字符串全局唯一ID (idWorker 的字符串表示) */
ID_WORKER_STR(5);
private int key;
IdType(int key) {
this.key = key;
}
}
UUID 通用唯一識別碼
MyBatis-Plus
ID_WORKER
MyBatis-Plus默認的主鍵策略是:ID_WORKER *全局唯一ID *
自增策略
要想主鍵自增也可以
創建數據庫的時候可以設計主鍵自增 ,比如idint(11) NOT NULL AUTO_INCREMENT COMMENT '用戶id'
實體字段中配置@TableId(type = IdType.AUTO)
@TableId(type = IdType.AUTO)
private Long id;
Long
要想影響所有實體的配置,可以設置全局主鍵配置
#全局設置主鍵生成策略
mybatis-plus.global-config.db-config.id-type=auto
自動填充
一些數據相同的填充,如創建時間,更新時間
@Data
ublic class User implements Serializable {
//自動填充
@TableField(fill = FieldFill.INSERT)
@ApiModelProperty(value = "創建時間")
private Date createTime;
@TableField(fill = FieldFill.INSERT_UPDATE)
@ApiModelProperty(value = "更新時間")
private Date updateTime;
}
