<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ThinkChat2.0新版上線,更智能更精彩,支持會話、畫圖、視頻、閱讀、搜索等,送10W Token,即刻開啟你的AI之旅 廣告
                Mybatis Plus 為我們提供了三種設置 主鍵生成策略的方式。它們的優先級順序是:局部注解 > 全局 > 默認(雪花算法)。下面我們來一一介紹 ## 一、默認主鍵生成策略:雪花算法 Mybatis Plus如果不做任何主鍵策略配置,默認使用的是雪花算法。該策略會根據雪花算法生成主鍵ID,主鍵類型為Long或String(具體到MySQL數據庫就是BIGINT和VARCHAR),該策略使用接口IdentifierGenerator的方法nextId(默認實現類為DefaultIdentifierGenerator雪花算法) > snowflake算法是Twitter開源的分布式ID生成算法,結果是一個long類型的ID 。其核心思想:使用41bit作為毫秒數,10bit作為機器的ID(5bit數據中心,5bit的機器ID),12bit作為毫秒內的流水號(意味著每個節點在每個毫秒可以產生4096個ID),最后還有一個符號位,永遠是0。 ## 二、自定義主鍵策略 mybatis-plus3.3.0以后,主要有五種主鍵生成策略。 ~~~ public enum IdType { /** * 數據庫ID自增,數據庫需要支持主鍵自增(如MySQL),并設置主鍵自增 */ AUTO(0), /** * 該類型為未設置主鍵類型,默認使用雪花算法生成 */ NONE(1), /** * 用戶輸入ID,數據類型和數據庫保持一致就行 * <p>該類型可以通過自己注冊自動填充插件進行填充</p> */ INPUT(2), /* 以下3種類型、只有當插入對象ID 為空,才自動填充。 */ /** * 全局唯一ID (idWorker),數值類型 數據庫中也必須是數值類型 否則會報錯 */ ID_WORKER(3), /** * 全局唯一ID (UUID,不含中劃線) */ UUID(4), /** * 字符串全局唯一ID (idWorker 的字符串表示),數據庫也要保證一樣字符類型 */ ID_WORKER_STR(5); } ~~~ ## 三、局部注解配置策略 我們針對主鍵設置主鍵策略使用注解方式為 ~~~ @TableId(type = IdType.AUTO) private long userId; ~~~ ## 四、全局配置策略 ~~~ mybatis-plus: global-config: db-config: id-type: auto ~~~ ## 五、擴展使用 ### 5.1.INPUT用戶輸入ID策略的用法 其中需要和大家特殊介紹的是:Input(用戶輸入ID),這個ID來源可以有兩種 * 用戶自己設置ID,并在insert之前SET主鍵的值 * 一些有序列的數據庫,比如Oracle,SQLServer等,針對這些數據庫我們可以通過序列填充ID字段 Mybatis-Plus 內置了如下數據庫主鍵序列(如果內置支持不滿足你的需求,可實現 IKeyGenerator 接口來進行擴展): * DB2KeyGenerator * H2KeyGenerator * KingbaseKeyGenerator * OracleKeyGenerator * PostgreKeyGenerator 以Oracle 的Sequence使用方法為例,使用方法如下: 首先添加@Bean ~~~ @Bean public OracleKeyGenerator oracleKeyGenerator(){ return new OracleKeyGenerator(); } ~~~ 然后實體類配置主鍵 Sequence,指定主鍵策略為 IdType.INPUT 即可, ~~~ @Data @KeySequence(value = "SEQ_USER" , clazz = Long.class) public class User { @TableId(value = "ID",type = IdType.INPUT) private Integer id; ~~~
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看