Mybatis Plus使用心得

代碼生成器的使用

1.引入Maven

生成器可以采用velocity模板或freemarker模板市俊,下面采用的是freemark模板

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>6.0.6</version>
        </dependency>

        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.0.6</version>
        </dependency>

        <!-- freemarker 模板引擎 -->
        <dependency>
            <groupId>org.freemarker</groupId>
            <artifactId>freemarker</artifactId>
            <version>2.3.28</version>
        </dependency>

2.編寫模板

在mybatis-plus-generator-3.0.6.jar包下可以找到默認(rèn)的模板配置殊橙。如果想采用修改生成的代碼踩验,只需將相應(yīng)的模板拷貝到自己工程下的templates目錄即可蛇摸。


默認(rèn)模板位置

3.數(shù)據(jù)庫的連接配置

按基本的jdbc連就行了隐轩,不過我在連接時(shí)踩了個(gè)坑垢粮,記錄一下个束。
在連接時(shí)沒有設(shè)置時(shí)區(qū)導(dǎo)致一直在報(bào)錯(cuò)蘸炸,所以設(shè)置URL時(shí)最好帶上

jdbc:mysql://localhost:3306/" + DB_NAME + "?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&useSSL=false&zeroDateTimeBehavior=convertToNull&serverTimezone=UTC

4.生成代碼

//包名
    public static final String PACKAGE_NAME = "com.yyq.demo";

    //模塊名
    public static final String MODULE_NAME = "code";

    //數(shù)據(jù)庫名
    public static final String DB_NAME = "test";

    //數(shù)據(jù)庫表
    public static final String TABLE_NAME = "t_user";

    //獲取當(dāng)前項(xiàng)目的路徑
    public static final String PROJECT_PATH = System.getProperty("user.dir");

    //代碼存儲(chǔ)路徑
    public static final String CODE_SAVE_PATH = PROJECT_PATH + "/src/main/java/" + StringUtils.join((PACKAGE_NAME + "." + MODULE_NAME).split("\\."), "/");


    public static void main(String[] args) {
        // 代碼生成器
        AutoGenerator mpg = new AutoGenerator();

        // 全局配置
        GlobalConfig gc = new GlobalConfig();

        gc.setOutputDir(PROJECT_PATH + "/src/main/java");
        gc.setAuthor("Richard");
        gc.setOpen(false);
        gc.setFileOverride(true);
        gc.setServiceName("%sService");
        gc.setBaseColumnList(true);
        gc.setBaseResultMap(true);
        gc.setDateType(DateType.ONLY_DATE);
        mpg.setGlobalConfig(gc);

        // 數(shù)據(jù)源配置
        DataSourceConfig dsc = new DataSourceConfig();
        dsc.setUrl("jdbc:mysql://localhost:3306/" + DB_NAME + "?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&useSSL=false&zeroDateTimeBehavior=convertToNull&serverTimezone=UTC");
        // dsc.setSchemaName("public");
        dsc.setDriverName("com.mysql.jdbc.Driver");
        dsc.setUsername("root");
        dsc.setPassword("123456");
        mpg.setDataSource(dsc);

        // 包配置
        PackageConfig pc = new PackageConfig();
        pc.setModuleName(MODULE_NAME);
        pc.setParent(PACKAGE_NAME);
        mpg.setPackageInfo(pc);

        // 自定義配置
        InjectionConfig cfg = new InjectionConfig() {
            @Override
            public void initMap() {
                // to do nothing
            }
        };
        List<FileOutConfig> focList = new ArrayList<>();
        focList.add(new FileOutConfig("/templates/mapper.xml.ftl") {
            @Override
            public String outputFile(TableInfo tableInfo) {
                // 自定義輸入文件名稱
                return PROJECT_PATH + "/src/main/resources/mapper/" + tableInfo.getEntityName() + "Mapper" + StringPool.DOT_XML;
            }
        });

        focList.add(new FileOutConfig("/templates/service.java.ftl") {
            @Override
            public String outputFile(TableInfo tableInfo) {
                // 自定義輸入文件名稱
                return CODE_SAVE_PATH + "/service/" + tableInfo.getEntityName() + "Service" + StringPool.DOT_JAVA;
            }
        });

        cfg.setFileOutConfigList(focList);
        mpg.setCfg(cfg);
        mpg.setTemplate(new TemplateConfig().setXml(null));

        // 策略配置
        StrategyConfig strategy = new StrategyConfig();
        strategy.setTablePrefix(new String[]{"t_"});
        strategy.setNaming(NamingStrategy.underline_to_camel);
        strategy.setColumnNaming(NamingStrategy.underline_to_camel);
        strategy.setSuperEntityClass("com.yyq.demo.bean.BaseEntity");
        strategy.setEntityLombokModel(true);
        strategy.setRestControllerStyle(true);
        strategy.setSuperControllerClass("com.yyq.demo.controller.BaseController");
        strategy.setInclude(TABLE_NAME);


        //自定義基礎(chǔ)的Entity類哑舒,公共字段 ,填入將在entity中不出現(xiàn)

        strategy.setSuperEntityColumns("id","version");
        strategy.setControllerMappingHyphenStyle(true);
        mpg.setStrategy(strategy);
        mpg.setTemplateEngine(new FreemarkerTemplateEngine());
        mpg.execute();
        //刪除自己不需要的目錄
        deleteDir(new File(CODE_SAVE_PATH+"/service/impl"));
    }




    private static void deleteDir(File dir) {
        if (dir.isDirectory()) {
            File[] files = dir.listFiles();
            for (int i = 0; i < files.length; i++) {
                deleteDir(files[i]);
            }
        }
        dir.delete();
    }

各種查詢套路

1.使用eq()時(shí)

字段名要是數(shù)據(jù)庫對應(yīng)的字段名幻馁,如wrapper.eq("login_name","test");
不能直接用于和null比較要用wrapper.isNull("param_name");

2.where()

可以寫任何的sql在里面洗鸵,可以把其他關(guān)聯(lián)表的結(jié)合起來做查詢,如

wrapper.where("id in (select o_id from t_a where name like concat('%',{0},'%'))",keyword);

Mybatis Plus官方文檔
Demo代碼

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末仗嗦,一起剝皮案震驚了整個(gè)濱河市膘滨,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌稀拐,老刑警劉巖火邓,帶你破解...
    沈念sama閱讀 218,858評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異德撬,居然都是意外死亡铲咨,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評論 3 395
  • 文/潘曉璐 我一進(jìn)店門蜓洪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來纤勒,“玉大人,你說我怎么就攤上這事隆檀∫√欤” “怎么了?”我有些...
    開封第一講書人閱讀 165,282評論 0 356
  • 文/不壞的土叔 我叫張陵恐仑,是天一觀的道長泉坐。 經(jīng)常有香客問我,道長裳仆,這世上最難降的妖魔是什么腕让? 我笑而不...
    開封第一講書人閱讀 58,842評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮歧斟,結(jié)果婚禮上纯丸,老公的妹妹穿的比我還像新娘司训。我一直安慰自己,他們只是感情好液南,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,857評論 6 392
  • 文/花漫 我一把揭開白布壳猜。 她就那樣靜靜地躺著,像睡著了一般滑凉。 火紅的嫁衣襯著肌膚如雪统扳。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,679評論 1 305
  • 那天畅姊,我揣著相機(jī)與錄音咒钟,去河邊找鬼。 笑死若未,一個(gè)胖子當(dāng)著我的面吹牛朱嘴,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播粗合,決...
    沈念sama閱讀 40,406評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼萍嬉,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了隙疚?” 一聲冷哼從身側(cè)響起壤追,我...
    開封第一講書人閱讀 39,311評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎供屉,沒想到半個(gè)月后行冰,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,767評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡伶丐,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年悼做,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片哗魂。...
    茶點(diǎn)故事閱讀 40,090評論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡肛走,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出啡彬,到底是詐尸還是另有隱情羹与,我是刑警寧澤,帶...
    沈念sama閱讀 35,785評論 5 346
  • 正文 年R本政府宣布庶灿,位于F島的核電站,受9級特大地震影響吃衅,放射性物質(zhì)發(fā)生泄漏往踢。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,420評論 3 331
  • 文/蒙蒙 一徘层、第九天 我趴在偏房一處隱蔽的房頂上張望峻呕。 院中可真熱鬧利职,春花似錦、人聲如沸瘦癌。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,988評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽讯私。三九已至热押,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間斤寇,已是汗流浹背桶癣。 一陣腳步聲響...
    開封第一講書人閱讀 33,101評論 1 271
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留娘锁,地道東北人牙寞。 一個(gè)月前我還...
    沈念sama閱讀 48,298評論 3 372
  • 正文 我出身青樓,卻偏偏與公主長得像莫秆,于是被迫代替她去往敵國和親间雀。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,033評論 2 355

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