今天就跟大家聊聊有關(guān)在SpringBoot中使用MyBatis如何實(shí)現(xiàn)一個(gè)應(yīng)用訪問(wèn)功能,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
10年積累的成都網(wǎng)站制作、做網(wǎng)站、外貿(mào)營(yíng)銷(xiāo)網(wǎng)站建設(shè)經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶(hù)對(duì)網(wǎng)站的新想法和需求。提供各種問(wèn)題對(duì)應(yīng)的解決方案。讓選擇我們的客戶(hù)得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站設(shè)計(jì)后付款的網(wǎng)站建設(shè)流程,更有萬(wàn)秀免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
一,Pom文件
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.example</groupId> <artifactId>example</artifactId> <version>1.0-SNAPSHOT</version> <packaging>jar</packaging> //這里設(shè)置為jar,因?yàn)槲覀儠?huì)使用jar包部署運(yùn)行 <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.4.2.RELEASE</version> </parent> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- https://mvnrepository.com/artifact/org.mybatis/mybatis --> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> //Mybatis的jar包 <version>1.1.1</version> </dependency> <dependency> <groupId>org.codehaus.jackson</groupId> <artifactId>jackson-mapper-asl</artifactId> //json數(shù)據(jù)格式和對(duì)象的轉(zhuǎn)換jar包 <version>1.9.8</version> <type>jar</type> <scope>compile</scope> </dependency> <dependency> <groupId>com.h3database</groupId> //內(nèi)嵌數(shù)據(jù)庫(kù) <artifactId>h3</artifactId> <version>1.3.156</version> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> //lombok插件,方便model對(duì)象的處理 <version>1.16.2</version> </dependency> <!-- https://mvnrepository.com/artifact/MySQL/mysql-connector-java --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> //mysql驅(qū)動(dòng) <version>5.1.18</version> </dependency> </dependencies> <build> <finalName>example</finalName> //打包后的jar包名稱(chēng) <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> //必須要的SpringBoot繼承的maven插件,缺少了無(wú)法打包jar。 <executions> <execution> <goals> <goal>repackage</goal> </goals> </execution> </executions> </plugin> <plugin> <artifactId>maven-resources-plugin</artifactId> //因?yàn)閖ar包中可能存在很多其他的配置資源,例如mapper文件所以打包為jar包需要將其加入,所以需要此資源打包插件 <version>2.5</version> <executions> <execution> <id>copy-xmls</id> <phase>process-sources</phase> <goals> <goal>copy-resources</goal> </goals> <configuration> <outputDirectory>${basedir}/target/classes</outputDirectory> <resources> <resource> <directory>${basedir}/src/main/java</directory> <includes> <include>**/*.xml</include> </includes> </resource> </resources> </configuration> </execution> </executions> </plugin> </plugins> <resources> //打包包含相應(yīng)的資源文件 <resource> <directory>src/main/resources</directory> <includes> <include>**/*.properties</include> <include>**/*.xml</include> <include>**/*.tld</include> </includes> <filtering>false</filtering> </resource> <resource> <directory>src/main/java</directory> <includes> <include>**/*.properties</include> <include>**/*.xml</include> <include>**/*.tld</include> </includes> <filtering>false</filtering> </resource> </resources> </build> <repositories>//設(shè)置倉(cāng)庫(kù) <repository> <id>spring-milestone</id> <url>http://repo.spring.io/libs-release</url> </repository> </repositories> </project>
好了簡(jiǎn)單的SpringBoot整合Mybatis框架的基礎(chǔ)環(huán)境已經(jīng)搭建完成了,一個(gè)Pom文件搞定,接下來(lái)我們配置我們的配置文件。
二,配置文件
我們寫(xiě)在resources目錄下的application.properties文件中。
spring.datasource.url=jdbc:mysql://localhost:3306/數(shù)據(jù)庫(kù)名稱(chēng)?useUnicode=true&characterEncoding=UTF8 spring.datasource.username=用戶(hù)名 spring.datasource.password=用戶(hù)密碼 spring.datasource.driver-class-name=com.mysql.jdbc.Driver mybatis.mapper-locations=classpath*:/mapper/*Mapper.xml //mapper文件的路徑 mybatis.type-aliases-package=map.model //mapper文件中的前綴 server.port=監(jiān)聽(tīng)端口號(hào),不設(shè)置默認(rèn)8080
ok,現(xiàn)在環(huán)境已經(jīng)徹底搭建完成我們可以編寫(xiě)自己的代碼了。
三,編寫(xiě)代碼
Model對(duì)象
@Data//@Data lombok插件的注解自動(dòng)添加get set方法 public class ExampleModel { private Long id; private String name; } //一個(gè)簡(jiǎn)單的model對(duì)象
Dao層
這里需要注意的是,推薦公司使用的一種做法,因?yàn)楹芏嗟腄ao對(duì)象都是簡(jiǎn)單的增刪改查功能,所以我們抽象出一個(gè)最基本的父類(lèi),這個(gè)父類(lèi)實(shí)現(xiàn)最基本的增刪改查功能,每個(gè)新的Dao對(duì)象可以繼承這個(gè)類(lèi),然后自定義實(shí)現(xiàn)特殊的數(shù)據(jù)庫(kù)訪問(wèn)功能,我們可以把這個(gè)基本的父類(lèi)成為MyBatisHelper并用上泛型,具體實(shí)現(xiàn)如下:
@Data public class MybatisHelper<T> { @Autowired private SqlSession sqlSession; //這里自動(dòng)注入mybatis的SqlSession private String nameSpace; public MybatisHelper(String nameSpace) { this.nameSpace = nameSpace; } public String getSqlName(String sqlName) { return nameSpace +"."+ sqlName; } public Integer create(String name, T obj) { return sqlSession.insert(getSqlName(name), obj); } public Boolean update(String name, T obj) { return Boolean.valueOf(sqlSession.update(getSqlName(name), obj) > 0); } public T findById(String name, Long id) { return sqlSession.selectOne(getSqlName(name), id); } public Boolean delete(String name, Long id) { return Boolean.valueOf(sqlSession.delete(getSqlName(name), id) > 0); } public List<T> findAll(String name){return sqlSession.selectList(getSqlName(name));} }
需要說(shuō)明的是因?yàn)閟qlSession的執(zhí)行回去尋找相應(yīng)的mapper文件,所以namespace+方法名稱(chēng)很重要,這個(gè)一定要注意不要弄錯(cuò)了,弄錯(cuò)了就會(huì)無(wú)法正確調(diào)用。
然后我們的Dao層實(shí)現(xiàn)繼承此類(lèi)
@Component public class ExampleModelDao extends MybatisHelper<ExampleModel>{ public ExampleModelDao() { super("example.dao."); } //todo 自定義操作 public Integer findDataCounts(){ return getSqlSession().selectOne(getSqlName("findDataCounts"));//他會(huì)尋找example.dao.findDataCounts對(duì)應(yīng)的方法執(zhí)行 } }
這樣是不是很簡(jiǎn)單,也能大量復(fù)用很省事,關(guān)于service層我就不寫(xiě)了很簡(jiǎn)單。
四,mapper文件
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" > <mapper namespace="example.dao">//這里很重要就是前綴 <resultMap id="ExampleModelMap" type="ExampleMode"> <id column="id" property="id"/> <result column="name" property="name"/> </resultMap> //自定義resultMap對(duì)象,利于對(duì)象的操作 <sql id="tb"> //數(shù)據(jù)表標(biāo)簽 example_data </sql> <sql id="value_exclude_id"> //除了主鍵以為的字段集合標(biāo)簽 name </sql> <sql id="vls"> //插入屬性的字段集合標(biāo)簽 id,name </sql> <sql id="insert_value">//插入輸入進(jìn)來(lái)的字段值標(biāo)簽 #{name} </sql> <insert id="create" parameterType="ExampleModel"> INSERT INTO <include refid="tb"/> (<include refid="value_exclude_id"/>) VALUES (<include refid="insert_value"/>) </insert>//一看就明白了創(chuàng)建一個(gè)對(duì)象 <select id="findById" parameterType="long" resultMap="ExampleModelMap">//返回我們定義的resultMap SELECT <include refid="vls"/> FROM <include refid="tb"/> WHERE id = #{id} </select> <select id="findAll" resultMap="ExampleModelMap"> SELECT <include refid="vls"/> FROM <include refid="tb"/> </select> <select id="findDataCounts" resultType="int"> SELECT count(1) FROM <include refid="tb"/> </select>//自定義的操作 </mapper>
ok,對(duì)應(yīng)的mapper文件已經(jīng)有了,我們就可以調(diào)用了,調(diào)用很簡(jiǎn)單一般寫(xiě)在service層中調(diào)用,下面我們?nèi)ゾ帉?xiě)對(duì)應(yīng)的controller。
五,控制器編寫(xiě)
推薦使用restful風(fēng)格,因此我們控制器編寫(xiě)代碼如下:
@RestController @CrossOrigin //這個(gè)是ajax跨域請(qǐng)求允許的注解,不用可以去掉 public class DigMapDataController { @Autowired private ExampleService exampleService;//service對(duì)象 @RequestMapping(value = "/create", method = RequestMethod.POST) public String create(@requestBody ExampleModel exampleModel) { return String.valueOf(exampleService.create(exampleModel)); } //@requestBody注解會(huì)接受前端的JSON數(shù)據(jù)并配合jackson自動(dòng)轉(zhuǎn)換為相應(yīng)的對(duì)象 @RequestMapping(value = "/find/count",method = RequestMethod.GET) public Integer findCounts() { return exampleService.findDataCounts(); } }
一個(gè)簡(jiǎn)單的控制器就編寫(xiě)完成了,這個(gè)時(shí)候我們可以啟動(dòng)應(yīng)用進(jìn)行數(shù)據(jù)訪問(wèn)了,是不是很簡(jiǎn)單。
六,應(yīng)用的部署
直接在終端中使用命令,將應(yīng)用打包為jar文件
1.maven [clean] package ;打包后的文件在target目錄下
2.java -jar example.jar ; 運(yùn)行我們的jar包程序
看完上述內(nèi)容,你們對(duì)在SpringBoot中使用MyBatis如何實(shí)現(xiàn)一個(gè)應(yīng)用訪問(wèn)功能有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。
分享名稱(chēng):在SpringBoot中使用MyBatis如何實(shí)現(xiàn)一個(gè)應(yīng)用訪問(wèn)功能
當(dāng)前鏈接:http://chinadenli.net/article48/giceep.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、網(wǎng)站設(shè)計(jì)、定制開(kāi)發(fā)、小程序開(kāi)發(fā)、外貿(mào)建站、網(wǎng)站導(dǎo)航
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)