【Problems】Could not set property 'id' of 'xxx' with value '' Cause argument type mismatch


一個問題:向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;
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM