91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mybatis plus中怎么自定義主鍵生成器IKeyGenerator

發布時間:2021-08-06 14:54:24 來源:億速云 閱讀:1724 作者:Leah 欄目:編程語言

本篇文章為大家展示了mybatis plus中怎么自定義主鍵生成器IKeyGenerator,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

1. 繼承IKeyGenerator

@Slf4j
@Component
public class MybatisKeyGenerator implements IKeyGenerator {
 
	@Value("${server.worker-id}")
	private Integer workerId;
 
	@Value("${server.data-center-id}")
	private Integer dataCenterId;
 
	@Override
	public String executeSql(String incrementerName) {
		log.info("mybatis plus keyGenerator: " + incrementerName + "(" + workerId + "," + dataCenterId + ")");
		long uid = new SnowflakeIdWorker(workerId, dataCenterId).nextId();
		return "select " + uid + " from dual";
	}
}

2. 定義entity, 需要有@KeySequence注解,和IdType.INPUT或者IdType.ID_WORKER

@Data
@TableName("test1")
@KeySequence("mybatisKeyGenerator")
public class Test {
	@TableId(type = IdType.INPUT)
	private Long id;
	private String name;
}

 3.測試:

@Autowired
private TestMapper testMapper;
@Override
public void run(String... args) throws Exception {
	Test test = new Test();
	test.setName("CCC"+ LocalDateTime.now());
	testMapper.insert(test);
	System.out.println(">>>> test:"+ test);
}

源碼查看:

1. com.baomidou.mybatisplus.autoconfigure.MybatisPlusAutoConfiguration

// 從spring容器中獲取IKeyGenerator
//注入主鍵生成器
if (this.applicationContext.getBeanNamesForType(IKeyGenerator.class, false,
	false).length > 0) {
	IKeyGenerator keyGenerator = this.applicationContext.getBean(IKeyGenerator.class);
	globalConfig.getDbConfig().setKeyGenerator(keyGenerator);
}

2. 在掃描實體時候,會掃描KeySequence注解

/* 開啟了自定義 KEY 生成器 */
if (null != dbConfig.getKeyGenerator()) {
   tableInfo.setKeySequence(clazz.getAnnotation(KeySequence.class));
}

3. 插入數據時:com.baomidou.mybatisplus.core.injector.methods.Insert

// 表包含主鍵處理邏輯,如果不包含主鍵當普通字段處理
if (StringUtils.isNotEmpty(tableInfo.getKeyProperty())) {
	if (tableInfo.getIdType() == IdType.AUTO) {
		/** 自增主鍵 */
		keyGenerator = new Jdbc3KeyGenerator();
		keyProperty = tableInfo.getKeyProperty();
		keyColumn = tableInfo.getKeyColumn();
	} else {
 
        // 如果有注解,則獲取自定義的主鍵生成器
		if (null != tableInfo.getKeySequence()) {
            // 這里獲取的就是注入的生成器,執行生成器接口executeSql,傳入值為注解里面的value
			keyGenerator = TableInfoHelper.genKeyGenerator(tableInfo, builderAssistant, sqlMethod.getMethod(), languageDriver);
			keyProperty = tableInfo.getKeyProperty();
			keyColumn = tableInfo.getKeyColumn();
		}
	}
}

4. 

    /**
     * <p>
     * 自定義 KEY 生成器
     * </p>
     */
    public static KeyGenerator genKeyGenerator(TableInfo tableInfo, MapperBuilderAssistant builderAssistant,
                                               String baseStatementId, LanguageDriver languageDriver) {
        IKeyGenerator keyGenerator = GlobalConfigUtils.getKeyGenerator(builderAssistant.getConfiguration());
        if (null == keyGenerator) {
            throw new IllegalArgumentException("not configure IKeyGenerator implementation class.");
        }
        String id = baseStatementId + SelectKeyGenerator.SELECT_KEY_SUFFIX;
        Class<?> resultTypeClass = tableInfo.getKeySequence().clazz();
        StatementType statementType = StatementType.PREPARED;
        String keyProperty = tableInfo.getKeyProperty();
        String keyColumn = tableInfo.getKeyColumn();
 
        // 執行語句keyGenerator.executeSql(tableInfo.getKeySequence().value())
        SqlSource sqlSource = languageDriver.createSqlSource(builderAssistant.getConfiguration(),
            keyGenerator.executeSql(tableInfo.getKeySequence().value()), null);
        builderAssistant.addMappedStatement(id, sqlSource, statementType, SqlCommandType.SELECT, null, null, null,
            null, null, resultTypeClass, null, false, false, false,
            new NoKeyGenerator(), keyProperty, keyColumn, null, languageDriver, null);
        id = builderAssistant.applyCurrentNamespace(id, false);
        MappedStatement keyStatement = builderAssistant.getConfiguration().getMappedStatement(id, false);
        SelectKeyGenerator selectKeyGenerator = new SelectKeyGenerator(keyStatement, true);
        builderAssistant.getConfiguration().addKeyGenerator(id, selectKeyGenerator);
        return selectKeyGenerator;
    }

上述內容就是mybatis plus中怎么自定義主鍵生成器IKeyGenerator,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

葫芦岛市| 尤溪县| 鄂伦春自治旗| 河北省| 五峰| 城口县| 东平县| 宣恩县| 砀山县| 承德县| 康定县| 通州市| 正安县| 扎兰屯市| 永德县| 莒南县| 天柱县| 杭州市| 彭山县| 临夏市| 平乡县| 沛县| 南召县| 随州市| 万年县| 金寨县| 彰武县| 营口市| 阿合奇县| 碌曲县| 什邡市| 衡南县| 锡林郭勒盟| 辽源市| 沙湾县| 吴堡县| 东阿县| 大洼县| 新丰县| 林甸县| 浦北县|