mybatis plus學(xué)習(xí)筆記(1)

1.介紹

可以從官網(wǎng)看到介紹

https://mybatis.plus/guide/#%E7%89%B9%E6%80%A7

下面我們先無腦使用其功能被芳,不考慮其是如何實(shí)現(xiàn)的,例子都是官方的

2.第一個(gè)例子

由于例子采用了spring boot start以及數(shù)據(jù)采用了h2,所以先略過此部分,直接使用,很無腦

代碼示例1

@Data
public class User {
    private Long id;
    private String name;
    private Integer age;
    private String email;
}

public interface UserMapper extends BaseMapper<User> {

}

@RunWith(SpringRunner.class)
@SpringBootTest
public class SampleTest {

    @Resource
    private UserMapper userMapper;

    @Test
    public void testSelect() {
        System.out.println(("----- selectAll method test ------"));
        List<User> userList = userMapper.selectList(null);
        Assert.assertEquals(5, userList.size());
        userList.forEach(System.out::println);
    }
}

1.定義了一個(gè)User實(shí)體類
2.定義一個(gè)繼承自BaseMapper 的UserMapper映射類
3.調(diào)用UserMapper相關(guān)查詢方法

就是這么簡(jiǎn)單,有點(diǎn)類似JPA的感覺

3.CRUD

只需要調(diào)用BaseMapper相關(guān)方法即可

public class SampleTest {

    @Resource
    private UserMapper mapper;

    @Test
    public void aInsert() {
        User user = new User();
        user.setName("小羊");
        user.setAge(3);
        user.setEmail("abc@mp.com");
        assertThat(mapper.insert(user)).isGreaterThan(0);
        // 成功直接拿會(huì)寫的 ID
        assertThat(user.getId()).isNotNull();
    }


    @Test
    public void bDelete() {
        assertThat(mapper.deleteById(3L)).isGreaterThan(0);
        assertThat(mapper.delete(new QueryWrapper<User>()
                .lambda().eq(User::getName, "Sandy"))).isGreaterThan(0);
    }


    @Test
    public void cUpdate() {
        assertThat(mapper.updateById(new User().setId(1L).setEmail("ab@c.c"))).isGreaterThan(0);
        assertThat(mapper.update(new User().setName("mp"),
                Wrappers.<User>lambdaUpdate()
                        .set(User::getAge, 3)
                        .eq(User::getId, 2))).isGreaterThan(0);
    }


    @Test
    public void dSelect() {
        assertThat(mapper.selectById(1L).getEmail()).isEqualTo("ab@c.c");
        User user = mapper.selectOne(new QueryWrapper<User>().lambda().eq(User::getId, 2));
        assertThat(user.getName()).isEqualTo("mp");
        assertThat(user.getAge()).isEqualTo(3);
    }
}

4.條件構(gòu)造器

即構(gòu)造一個(gè)QueryWrapper對(duì)象,直接一點(diǎn)可以理解為拼接sql語句

    @Test
    public void tests() {
        System.out.println("----- 普通查詢 ------");
        List<User> plainUsers = userMapper.selectList(new QueryWrapper<User>().eq("role_id", 2L));
        List<User> lambdaUsers = userMapper.selectList(new QueryWrapper<User>().lambda().eq(User::getRoleId, 2L));
        Assert.assertEquals(plainUsers.size(), lambdaUsers.size());
        print(plainUsers);

        System.out.println("----- 帶子查詢(sql注入) ------");
        List<User> plainUsers2 = userMapper.selectList(new QueryWrapper<User>()
                .inSql("role_id", "select id from role where id = 2"));
        List<User> lambdaUsers2 = userMapper.selectList(new QueryWrapper<User>().lambda()
                .inSql(User::getRoleId, "select id from role where id = 2"));
        Assert.assertEquals(plainUsers2.size(), lambdaUsers2.size());
        print(plainUsers2);

        System.out.println("----- 帶嵌套查詢 ------");
        List<User> plainUsers3 = userMapper.selectList(new QueryWrapper<User>()
                .nested(i -> i.eq("role_id", 2L).or().eq("role_id", 3L))
                .and(i -> i.ge("age", 20)));
        List<User> lambdaUsers3 = userMapper.selectList(new QueryWrapper<User>().lambda()
                .nested(i -> i.eq(User::getRoleId, 2L).or().eq(User::getRoleId, 3L))
                .and(i -> i.ge(User::getAge, 20)));
        Assert.assertEquals(plainUsers3.size(), lambdaUsers3.size());
        print(plainUsers3);

        System.out.println("----- 自定義(sql注入) ------");
        List<User> plainUsers4 = userMapper.selectList(new QueryWrapper<User>()
                .apply("role_id = 2"));
        print(plainUsers4);

        UpdateWrapper<User> uw = new UpdateWrapper<>();
        uw.set("email", null);
        uw.eq("id",4);
        userMapper.update(new User(), uw);
        User u4 = userMapper.selectById(4);
        Assert.assertNull(u4.getEmail());
    }

5.通用枚舉

兩種定義方法,接口繼承和注解

public enum AgeEnum implements IEnum<Integer> {
  ONE(1, "一歲"),
  TWO(2, "二歲"),
  THREE(3, "三歲");

  private int value;
  private String desc;

  AgeEnum(final int value, final String desc) {
    this.value = value;
    this.desc = desc;
  }

  @Override
  public Integer getValue() {
    return value;
  }
}

public enum GradeEnum {

    PRIMARY(1, "小學(xué)"),
    SECONDORY(2, "中學(xué)"),
    HIGH(3, "高中");

    GradeEnum(int code, String descp) {
        this.code = code;
        this.descp = descp;
    }

    @EnumValue
    private final int code;
    private final String descp;

    public int getCode() {
        return code;
    }

    public String getDescp() {
        return descp;
    }
}

測(cè)試

    @Test
    public void insert() {
        User user = new User();
        user.setName("K神");
        user.setAge(AgeEnum.ONE);
        user.setGrade(GradeEnum.HIGH);
        user.setGender(GenderEnum.MALE);
        user.setEmail("abc@mp.com");
        Assert.assertTrue(mapper.insert(user) > 0);
        // 成功直接拿會(huì)寫的 ID
        System.err.println("\n插入成功 ID 為:" + user.getId());

        List<User> list = mapper.selectList(null);
        for(User u:list){
            System.out.println(u);
            Assert.assertNotNull("age should not be null",u.getAge());
            if(u.getId().equals(user.getId())){
                Assert.assertNotNull("gender should not be null", u.getGender());
                Assert.assertNotNull("grade should not be null",u.getGrade());

            }
        }
    }

6.邏輯刪除

首先要配置一個(gè)sql注入器(sqlInjector),然后使用TableLogic注解標(biāo)記邏輯刪除字段,其他使用方式不變

@Configuration
public class PlusConfiguration {

    @Bean
    public ISqlInjector sqlInjector() {
        return new LogicSqlInjector();
    }
}

@Data
public class User {
    private Integer id;
    private String name;
    private Integer age;
    private String email;
    @TableLogic
    private Integer isDelete;
}

測(cè)試代碼

    @Test
    public void testLogicDeleteById() {
        userMapper.deleteById(1);
    }

輸出日志

c.b.m.s.logic.mapper.UserMapper.delete   : ==>  Preparing: UPDATE user SET is_delete=1 WHERE is_delete=0 AND age = ? 
c.b.m.s.logic.mapper.UserMapper.delete   : ==> Parameters: 2(Integer)
c.b.m.s.logic.mapper.UserMapper.delete   : <==    Updates: 0

7.自動(dòng)填充功能

在插入和更新表的時(shí)候自動(dòng)填充設(shè)定的值

public class User {
    
    private Long id;
    
    private String name;
    
    private Integer age;
    
    private String email;
    
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private String operator;
}

public class MyMetaObjectHandler implements MetaObjectHandler {

    private static final Logger LOGGER = LoggerFactory.getLogger(MyMetaObjectHandler.class);

    @Override
    public void insertFill(MetaObject metaObject) {
        LOGGER.info("start insert fill ....");
        //避免使用metaObject.setValue()
        this.setFieldValByName("operator", "Jerry", metaObject);
    }

    @Override
    public void updateFill(MetaObject metaObject) {
        LOGGER.info("start update fill ....");
        this.setFieldValByName("operator", "Tom", metaObject);
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子星虹,更是在濱河造成了極大的恐慌躬厌,老刑警劉巖浊洞,帶你破解...
    沈念sama閱讀 210,978評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異剪撬,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)郁岩,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門婿奔,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人问慎,你說我怎么就攤上這事萍摊。” “怎么了如叼?”我有些...
    開封第一講書人閱讀 156,623評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵冰木,是天一觀的道長。 經(jīng)常有香客問我笼恰,道長踊沸,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,324評(píng)論 1 282
  • 正文 為了忘掉前任社证,我火速辦了婚禮逼龟,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘追葡。我一直安慰自己腺律,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,390評(píng)論 5 384
  • 文/花漫 我一把揭開白布宜肉。 她就那樣靜靜地躺著匀钧,像睡著了一般。 火紅的嫁衣襯著肌膚如雪谬返。 梳的紋絲不亂的頭發(fā)上之斯,一...
    開封第一講書人閱讀 49,741評(píng)論 1 289
  • 那天,我揣著相機(jī)與錄音遣铝,去河邊找鬼佑刷。 笑死莉擒,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的瘫絮。 我是一名探鬼主播啰劲,決...
    沈念sama閱讀 38,892評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼檀何!你這毒婦竟也來了蝇裤?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,655評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤频鉴,失蹤者是張志新(化名)和其女友劉穎栓辜,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體垛孔,經(jīng)...
    沈念sama閱讀 44,104評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡藕甩,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了周荐。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片狭莱。...
    茶點(diǎn)故事閱讀 38,569評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖概作,靈堂內(nèi)的尸體忽然破棺而出腋妙,到底是詐尸還是另有隱情,我是刑警寧澤讯榕,帶...
    沈念sama閱讀 34,254評(píng)論 4 328
  • 正文 年R本政府宣布骤素,位于F島的核電站,受9級(jí)特大地震影響愚屁,放射性物質(zhì)發(fā)生泄漏济竹。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,834評(píng)論 3 312
  • 文/蒙蒙 一霎槐、第九天 我趴在偏房一處隱蔽的房頂上張望送浊。 院中可真熱鬧,春花似錦丘跌、人聲如沸袭景。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽浴讯。三九已至朵夏,卻和暖如春蔼啦,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背仰猖。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評(píng)論 1 264
  • 我被黑心中介騙來泰國打工捏肢, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留奈籽,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,260評(píng)論 2 360
  • 正文 我出身青樓鸵赫,卻偏偏與公主長得像衣屏,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子辩棒,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,446評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容