mall整合SpringBoot+MyBatis搭建基本骨架

本文主要講解mall整合SpringBoot+MyBatis搭建基本骨架,以商品品牌為例實(shí)現(xiàn)基本的CRUD操作及通過(guò)PageHelper實(shí)現(xiàn)分頁(yè)查詢薇正。

mysql數(shù)據(jù)庫(kù)環(huán)境搭建

下載并安裝mysql5.7版本巩剖,下載地址:https://dev.mysql.com/downloads/installer/

設(shè)置數(shù)據(jù)庫(kù)帳號(hào)密碼:root root

下載并安裝客戶端連接工具Navicat,下載地址:http://www.formysql.com/xiazai.html

創(chuàng)建數(shù)據(jù)庫(kù)mall

導(dǎo)入mall的數(shù)據(jù)庫(kù)腳本,腳本地址:https://github.com/macrozheng/mall-learning/blob/master/document/sql/mall.sql

項(xiàng)目使用框架介紹

SpringBoot

SpringBoot可以讓你快速構(gòu)建基于Spring的Web應(yīng)用程序佳魔,內(nèi)置多種Web容器(如Tomcat),通過(guò)啟動(dòng)入口程序的main函數(shù)即可運(yùn)行鞠鲜。

PagerHelper

MyBatis分頁(yè)插件宁脊,簡(jiǎn)單的幾行代碼就能實(shí)現(xiàn)分頁(yè),在與SpringBoot整合時(shí)贤姆,只要整合了PagerHelper就自動(dòng)整合了MyBatis榆苞。

PageHelper.startPage(pageNum,pageSize);//之后進(jìn)行查詢操作將自動(dòng)進(jìn)行分頁(yè)List<PmsBrand>brandList=brandMapper.selectByExample(newPmsBrandExample());//通過(guò)構(gòu)造PageInfo對(duì)象獲取分頁(yè)信息,如當(dāng)前頁(yè)碼霞捡,總頁(yè)數(shù)坐漏,總條數(shù)PageInfo<PmsBrand>pageInfo=newPageInfo<PmsBrand>(list);Copy to clipboardErrorCopied

Druid

alibaba開(kāi)源的數(shù)據(jù)庫(kù)連接池,號(hào)稱Java語(yǔ)言中最好的數(shù)據(jù)庫(kù)連接池碧信。

Mybatis generator

MyBatis的代碼生成器赊琳,可以根據(jù)數(shù)據(jù)庫(kù)生成model、mapper.xml砰碴、mapper接口和Example躏筏,通常情況下的單表查詢不用再手寫mapper。

項(xiàng)目搭建

使用IDEA初始化一個(gè)SpringBoot項(xiàng)目

添加項(xiàng)目依賴

在pom.xml中添加相關(guān)依賴呈枉。

<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.1.3.RELEASE</version><relativePath/><!-- lookup parent from repository --></parent><dependencies><!--SpringBoot通用依賴模塊--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-aop</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><!--MyBatis分頁(yè)插件--><dependency><groupId>com.github.pagehelper</groupId><artifactId>pagehelper-spring-boot-starter</artifactId><version>1.2.10</version></dependency><!--集成druid連接池--><dependency><groupId>com.alibaba</groupId><artifactId>druid-spring-boot-starter</artifactId><version>1.1.10</version></dependency><!-- MyBatis 生成器 --><dependency><groupId>org.mybatis.generator</groupId><artifactId>mybatis-generator-core</artifactId><version>1.3.3</version></dependency><!--Mysql數(shù)據(jù)庫(kù)驅(qū)動(dòng)--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.15</version></dependency></dependencies>Copy to clipboardErrorCopied

修改SpringBoot配置文件

在application.yml中添加數(shù)據(jù)源配置和MyBatis的mapper.xml的路徑配置趁尼。

server:

? port: 8080

spring:

? datasource:

? ? url: jdbc:mysql://localhost:3306/mall?useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai

? ? username: root

? ? password: root

mybatis:

? mapper-locations:

? ? - classpath:mapper/*.xml

? ? - classpath*:com/**/mapper/*.xmlCopy to clipboardErrorCopied

項(xiàng)目結(jié)構(gòu)說(shuō)明

Mybatis generator 配置文件

配置數(shù)據(jù)庫(kù)連接埃碱,Mybatis generator生成model、mapper接口及mapper.xml的路徑酥泞。

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE generatorConfiguration

? ? ? ? PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"

? ? ? ? "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd"><generatorConfiguration><propertiesresource="generator.properties"/><contextid="MySqlContext"targetRuntime="MyBatis3"defaultModelType="flat"><propertyname="beginningDelimiter"value="`"/><propertyname="endingDelimiter"value="`"/><propertyname="javaFileEncoding"value="UTF-8"/><!-- 為模型生成序列化方法--><plugintype="org.mybatis.generator.plugins.SerializablePlugin"/><!-- 為生成的Java模型創(chuàng)建一個(gè)toString方法 --><plugintype="org.mybatis.generator.plugins.ToStringPlugin"/><!--可以自定義生成model的代碼注釋--><commentGeneratortype="com.macro.mall.tiny.mbg.CommentGenerator"><!-- 是否去除自動(dòng)生成的注釋 true:是 : false:否 --><propertyname="suppressAllComments"value="true"/><propertyname="suppressDate"value="true"/><propertyname="addRemarkComments"value="true"/></commentGenerator><!--配置數(shù)據(jù)庫(kù)連接--><jdbcConnectiondriverClass="${jdbc.driverClass}"connectionURL="${jdbc.connectionURL}"userId="${jdbc.userId}"password="${jdbc.password}"><!--解決mysql驅(qū)動(dòng)升級(jí)到8.0后不生成指定數(shù)據(jù)庫(kù)代碼的問(wèn)題--><propertyname="nullCatalogMeansCurrent"value="true"/></jdbcConnection><!--指定生成model的路徑--><javaModelGeneratortargetPackage="com.macro.mall.tiny.mbg.model"targetProject="mall-tiny-01\src\main\java"/><!--指定生成mapper.xml的路徑--><sqlMapGeneratortargetPackage="com.macro.mall.tiny.mbg.mapper"targetProject="mall-tiny-01\src\main\resources"/><!--指定生成mapper接口的的路徑--><javaClientGeneratortype="XMLMAPPER"targetPackage="com.macro.mall.tiny.mbg.mapper"targetProject="mall-tiny-01\src\main\java"/><!--生成全部表tableName設(shè)為%--><tabletableName="pms_brand"><generatedKeycolumn="id"sqlStatement="MySql"identity="true"/></table></context></generatorConfiguration>Copy to clipboardErrorCopied

運(yùn)行Generator的main函數(shù)生成代碼

packagecom.macro.mall.tiny.mbg;importorg.mybatis.generator.api.MyBatisGenerator;importorg.mybatis.generator.config.Configuration;importorg.mybatis.generator.config.xml.ConfigurationParser;importorg.mybatis.generator.internal.DefaultShellCallback;importjava.io.InputStream;importjava.util.ArrayList;importjava.util.List;/**

* 用于生產(chǎn)MBG的代碼

* Created by macro on 2018/4/26.

*/publicclassGenerator{publicstaticvoidmain(String[]args)throwsException{//MBG 執(zhí)行過(guò)程中的警告信息List<String>warnings=newArrayList<String>();//當(dāng)生成的代碼重復(fù)時(shí)砚殿,覆蓋原代碼booleanoverwrite=true;//讀取我們的 MBG 配置文件InputStreamis=Generator.class.getResourceAsStream("/generatorConfig.xml");ConfigurationParsercp=newConfigurationParser(warnings);Configurationconfig=cp.parseConfiguration(is);is.close();DefaultShellCallbackcallback=newDefaultShellCallback(overwrite);//創(chuàng)建 MBGMyBatisGeneratormyBatisGenerator=newMyBatisGenerator(config,callback,warnings);//執(zhí)行生成代碼myBatisGenerator.generate(null);//輸出警告信息for(Stringwarning:warnings){System.out.println(warning);}}}Copy to clipboardErrorCopied

添加MyBatis的Java配置

用于配置需要?jiǎng)討B(tài)生成的mapper接口的路徑

packagecom.macro.mall.tiny.config;importorg.mybatis.spring.annotation.MapperScan;importorg.springframework.context.annotation.Configuration;/**

* MyBatis配置類

* Created by macro on 2019/4/8.

*/@Configuration@MapperScan("com.macro.mall.tiny.mbg.mapper")publicclassMyBatisConfig{}Copy to clipboardErrorCopied

實(shí)現(xiàn)Controller中的接口

實(shí)現(xiàn)PmsBrand表中的添加、修改婶博、刪除及分頁(yè)查詢接口瓮具。

packagecom.macro.mall.tiny.controller;importcom.macro.mall.tiny.common.api.CommonPage;importcom.macro.mall.tiny.common.api.CommonResult;importcom.macro.mall.tiny.mbg.model.PmsBrand;importcom.macro.mall.tiny.service.PmsBrandService;importorg.slf4j.Logger;importorg.slf4j.LoggerFactory;importorg.springframework.beans.factory.annotation.Autowired;importorg.springframework.stereotype.Controller;importorg.springframework.validation.BindingResult;importorg.springframework.web.bind.annotation.*;importjava.util.List;/**

* 品牌管理Controller

* Created by macro on 2019/4/19.

*/@Controller@RequestMapping("/brand")publicclassPmsBrandController{@AutowiredprivatePmsBrandServicedemoService;privatestaticfinalLoggerLOGGER=LoggerFactory.getLogger(PmsBrandController.class);@RequestMapping(value="listAll",method=RequestMethod.GET)@ResponseBodypublicCommonResult<List<PmsBrand>>getBrandList(){returnCommonResult.success(demoService.listAllBrand());}@RequestMapping(value="/create",method=RequestMethod.POST)@ResponseBodypublicCommonResultcreateBrand(@RequestBodyPmsBrandpmsBrand){CommonResultcommonResult;intcount=demoService.createBrand(pmsBrand);if(count==1){commonResult=CommonResult.success(pmsBrand);LOGGER.debug("createBrand success:{}",pmsBrand);}else{commonResult=CommonResult.failed("操作失敗");LOGGER.debug("createBrand failed:{}",pmsBrand);}returncommonResult;}@RequestMapping(value="/update/{id}",method=RequestMethod.POST)@ResponseBodypublicCommonResultupdateBrand(@PathVariable("id")Longid,@RequestBodyPmsBrandpmsBrandDto,BindingResultresult){CommonResultcommonResult;intcount=demoService.updateBrand(id,pmsBrandDto);if(count==1){commonResult=CommonResult.success(pmsBrandDto);LOGGER.debug("updateBrand success:{}",pmsBrandDto);}else{commonResult=CommonResult.failed("操作失敗");LOGGER.debug("updateBrand failed:{}",pmsBrandDto);}returncommonResult;}@RequestMapping(value="/delete/{id}",method=RequestMethod.GET)@ResponseBodypublicCommonResultdeleteBrand(@PathVariable("id")Longid){intcount=demoService.deleteBrand(id);if(count==1){LOGGER.debug("deleteBrand success :id={}",id);returnCommonResult.success(null);}else{LOGGER.debug("deleteBrand failed :id={}",id);returnCommonResult.failed("操作失敗");}}@RequestMapping(value="/list",method=RequestMethod.GET)@ResponseBodypublicCommonResult<CommonPage<PmsBrand>>listBrand(@RequestParam(value="pageNum",defaultValue="1")IntegerpageNum,@RequestParam(value="pageSize",defaultValue="3")IntegerpageSize){List<PmsBrand>brandList=demoService.listBrand(pageNum,pageSize);returnCommonResult.success(CommonPage.restPage(brandList));}@RequestMapping(value="/{id}",method=RequestMethod.GET)@ResponseBodypublicCommonResult<PmsBrand>brand(@PathVariable("id")Longid){returnCommonResult.success(demoService.getBrand(id));}}Copy to clipboardErrorCopied

添加Service接口

packagecom.macro.mall.tiny.service;importcom.macro.mall.tiny.mbg.model.PmsBrand;importjava.util.List;/**

* PmsBrandService

* Created by macro on 2019/4/19.

*/publicinterfacePmsBrandService{List<PmsBrand>listAllBrand();intcreateBrand(PmsBrandbrand);intupdateBrand(Longid,PmsBrandbrand);intdeleteBrand(Longid);List<PmsBrand>listBrand(intpageNum,intpageSize);PmsBrandgetBrand(Longid);}Copy to clipboardErrorCopied

實(shí)現(xiàn)Service接口

packagecom.macro.mall.tiny.service.impl;importcom.github.pagehelper.PageHelper;importcom.macro.mall.tiny.mbg.mapper.PmsBrandMapper;importcom.macro.mall.tiny.mbg.model.PmsBrand;importcom.macro.mall.tiny.mbg.model.PmsBrandExample;importcom.macro.mall.tiny.service.PmsBrandService;importorg.springframework.beans.factory.annotation.Autowired;importorg.springframework.stereotype.Service;importjava.util.List;/**

* PmsBrandService實(shí)現(xiàn)類

* Created by macro on 2019/4/19.

*/@ServicepublicclassPmsBrandServiceImplimplementsPmsBrandService{@AutowiredprivatePmsBrandMapperbrandMapper;@OverridepublicList<PmsBrand>listAllBrand(){returnbrandMapper.selectByExample(newPmsBrandExample());}@OverridepublicintcreateBrand(PmsBrandbrand){returnbrandMapper.insertSelective(brand);}@OverridepublicintupdateBrand(Longid,PmsBrandbrand){brand.setId(id);returnbrandMapper.updateByPrimaryKeySelective(brand);}@OverridepublicintdeleteBrand(Longid){returnbrandMapper.deleteByPrimaryKey(id);}@OverridepublicList<PmsBrand>listBrand(intpageNum,intpageSize){PageHelper.startPage(pageNum,pageSize);returnbrandMapper.selectByExample(newPmsBrandExample());}@OverridepublicPmsBrandgetBrand(Longid){returnbrandMapper.selectByPrimaryKey(id);}}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末荧飞,一起剝皮案震驚了整個(gè)濱河市凡人,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌叹阔,老刑警劉巖挠轴,帶你破解...
    沈念sama閱讀 218,941評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異睛藻,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)冈在,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門包券,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)溅固,“玉大人兰珍,你說(shuō)我怎么就攤上這事×猎” “怎么了苹粟?”我有些...
    開(kāi)封第一講書人閱讀 165,345評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵嵌削,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我苛秕,道長(zhǎng),這世上最難降的妖魔是什么吼驶? 我笑而不...
    開(kāi)封第一講書人閱讀 58,851評(píng)論 1 295
  • 正文 為了忘掉前任蟹演,我火速辦了婚禮酒请,結(jié)果婚禮上鸣个,老公的妹妹穿的比我還像新娘。我一直安慰自己昼窗,他們只是感情好澄惊,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,868評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布缤削。 她就那樣靜靜地躺著吹榴,像睡著了一般。 火紅的嫁衣襯著肌膚如雪帅刀。 梳的紋絲不亂的頭發(fā)上远剩,一...
    開(kāi)封第一講書人閱讀 51,688評(píng)論 1 305
  • 那天瓜晤,我揣著相機(jī)與錄音痢掠,去河邊找鬼嘲恍。 笑死佃牛,一個(gè)胖子當(dāng)著我的面吹牛医舆,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播爷速,決...
    沈念sama閱讀 40,414評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼等曼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼禁谦!你這毒婦竟也來(lái)了州泊?” 一聲冷哼從身側(cè)響起遥皂,我...
    開(kāi)封第一講書人閱讀 39,319評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎样悟,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,775評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡录肯,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年于样,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了潘靖。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,096評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡糊余,死狀恐怖贬芥,靈堂內(nèi)的尸體忽然破棺而出宣决,到底是詐尸還是另有隱情,我是刑警寧澤威沫,帶...
    沈念sama閱讀 35,789評(píng)論 5 346
  • 正文 年R本政府宣布棒掠,位于F島的核電站屁商,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏雾袱。R本人自食惡果不足惜官还,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,437評(píng)論 3 331
  • 文/蒙蒙 一妻枕、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧述么,春花似錦愕掏、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,993評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至酪刀,卻和暖如春钮孵,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背历涝。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,107評(píng)論 1 271
  • 我被黑心中介騙來(lái)泰國(guó)打工荧库, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留毡证,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,308評(píng)論 3 372
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像恤煞,于是被迫代替她去往敵國(guó)和親施籍。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,037評(píng)論 2 355

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