tkMapper的使用

Maven引入

? ? ? ? <dependency>

? ? ? ? ? ? <groupId>tk.mybatis</groupId>

? ? ? ? ? ? <artifactId>mapper-spring-boot-starter</artifactId>

? ? ? ? ? ? <version>2.1.5</version>

? ? ? ? </dependency>

? ? ? ? <dependency>

? ? ? ? ? ? <groupId>org.springframework.boot</groupId>

? ? ? ? ? ? <artifactId>spring-boot-starter-web</artifactId>

? ? ? ? </dependency>

? ? ? ? <dependency>

? ? ? ? ? ? <groupId>org.mybatis.spring.boot</groupId>

? ? ? ? ? ? <artifactId>mybatis-spring-boot-starter</artifactId>

? ? ? ? ? ? <version>2.2.0</version>

? ? ? ? </dependency>

? ? ? ? <dependency>

? ? ? ? ? ? <groupId>org.projectlombok</groupId>

? ? ? ? ? ? <artifactId>lombok</artifactId>

? ? ? ? ? ? <optional>true</optional>

? ? ? ? </dependency>

? ? ? ? <dependency>

? ? ? ? ? ? <groupId>mysql</groupId>

? ? ? ? ? ? <artifactId>mysql-connector-java</artifactId>

? ? ? ? ? ? <scope>runtime</scope>

? ? ? ? </dependency>

? ? ? ? <dependency>

? ? ? ? ? ? <groupId>org.springframework.boot</groupId>

? ? ? ? ? ? <artifactId>spring-boot-starter-test</artifactId>

? ? ? ? ? ? <scope>test</scope>

? ? ? ? </dependency>

? ? ? ? <dependency>

? ? ? ? ? ? <groupId>junit</groupId>

? ? ? ? ? ? <artifactId>junit</artifactId>

? ? ? ? ? ? <version>4.12</version>

? ? ? ? ? ? <scope>test</scope>

? ? ? ? </dependency>

? ? ? ? <dependency>

? ? ? ? ? ? <groupId>junit</groupId>

? ? ? ? ? ? <artifactId>junit</artifactId>

? ? ? ? ? ? <scope>test</scope>

? ? ? ? </dependency>


創(chuàng)建實(shí)體類(字段類型一定要是對(duì)象類型坑匠,不能是基礎(chǔ)類型:要寫Integer不能寫int椿疗,要寫Long不能寫long)

User.java類

package com.bruce.entity;

import lombok.AllArgsConstructor;

import lombok.Data;

import lombok.NoArgsConstructor;

import lombok.ToString;

import javax.persistence.Column;

import javax.persistence.Id;

import java.util.Date;

import java.util.List;

@Data

@AllArgsConstructor

@NoArgsConstructor

@ToString

public class Users {

? ? @Id

? ? private Integer userId;

? ? @Column(name = "username")

? ? private String userName;

? ? @Column(name = "password")

? ? private String userPassword;

? ? @Column(name = "nickname")

? ? private String nickName;

? ? @Column(name = "realname")

? ? private String userRealName;

? ? private String userImg;

? ? private Integer userAge;

? ? private String userMobile;

? ? private String userEmail;

? ? private Boolean userSex;

? ? private Date userBirth;

? ? private Date userRegtime;

? ? private Date userModtime;

? ? private List<Orders> ordersList;

}

Orders.java 類

package com.bruce.entity;

import lombok.AllArgsConstructor;

import lombok.Data;

import lombok.NoArgsConstructor;

import lombok.ToString;

import javax.persistence.Id;

@Data

@AllArgsConstructor

@NoArgsConstructor

@ToString

public class Orders {

@Id

private String orderId;

private Long userId;

private String receiverName;

private String receiverMobile;

private String receiverAddress;

}

創(chuàng)建DAO接口

tkMapper已經(jīng)完成了對(duì)單表的通用操作的封裝腻扇,封裝在Mapper接口和MySqlMapper接口膜楷;因此如果我們要完成對(duì)單表的操作,只需自定義DAO接口繼承Mapper接口和MySqlMapper接口

@Repository

public interface UserDAO extends Mapper<User>, MySqlMapper<Users> {

????? public Users selectByUsername(String username);?? //tkMapper中默認(rèn)的方法不能滿足當(dāng)前要求可以自定義方法

}

UserMapper.xml

如果tkMybatis默認(rèn)的方法不能滿足當(dāng)下的要求可以杉编,將自定義的方法寫入Mapper.xml的配置文件中

<?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="com.bruce.mapper.UsersDao" >

? ? <!--namespace根據(jù)自己需要?jiǎng)?chuàng)建的的mapper的路徑和名稱填寫-->

? ? <resultMap id="userMap" type="com.bruce.entity.Users">

? ? ? ? <id column="user_id" property="userId"></id>

? ? ? ? <result column="username" property="userName"></result>

? ? ? ? <result column="password" property="userPassword"></result>

? ? ? ? <result column="nickname" property="nickName"></result>

? ? ? ? <result column="realname" property="userRealName"></result>

? ? ? ? <result column="user_img" property="userImg"></result>

? ? ? ? <result column="user_mobile" property="userMobile"></result>

? ? ? ? <result column="user_email" property="userEmail"></result>

? ? ? ? <result column="user_sex" property="userSex"></result>

? ? ? ? <result column="user_birth" property="userBirth"></result>

? ? ? ? <result column="user_regtime" property="userRegtime"></result>

? ? ? ? <result column="user_modtime" property="userModtime"></result>

? ? ? ? <result column="user_age" property="userAge"></result>

? ? ? ? <collection property="ordersList" ofType="com.bruce.entity.Orders">

? ? ? ? ? ? <id column="order_id" property="orderId"></id>

? ? ? ? ? ? <result column="receiver_name" property="receiverName"></result>

? ? ? ? ? ? <result column="receiver_mobile" property="receiverMobile"></result>

? ? ? ? ? ? <result column="receiver_address" property="receiverAddress"></result>

? ? ? ? </collection>

? ? </resultMap>

? ? <select id="selectByUsername" resultMap="userMap">

? ? ? ? select

? ? ? ? u.user_id,

? ? ? ? u.username,

? ? ? ? u.password,

? ? ? ? u.nickname,

? ? ? ? u.realname,

? ? ? ? u.user_img,

? ? ? ? u.user_mobile,

? ? ? ? u.user_email,

? ? ? ? u.user_sex,

? ? ? ? u.user_birth,

? ? ? ? u.user_regtime,

? ? ? ? u.user_modtime,

? ? ? ? u.user_age,

? ? ? ? o.order_id,

? ? ? ? o.receiver_name,

? ? ? ? o.receiver_mobile,

? ? ? ? o.receiver_address

? ? ? ? from users u inner join orders o

? ? ? ? on u.user_id = o.user_id

? ? </select>

</mapper>


修改啟動(dòng)類的`@MapperScan`注解的包

配置的MapperScan不是mybatis的而是`tk.mybatis.spring.annotation.MapperScan`

import tk.mybatis.spring.annotation.MapperScan;

@SpringBootApplication

@MapperScan("com.bruce.mapper")

public class TkmapperDemoApplication {

? ? public static void main(String[] args) {

? ? ? ? SpringApplication.run(TkmapperDemoApplication.class, args);

? ? }

}


Junit4 測(cè)試定義的方法

package com.bruce.mapper;

import com.bruce.TkmybatisApplication;

import com.bruce.entity.Orders;

import com.bruce.entity.Users;

import org.junit.Test;

import org.junit.runner.RunWith;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.boot.test.context.SpringBootTest;

import org.springframework.test.context.junit4.SpringRunner;

import tk.mybatis.mapper.entity.Example;

import java.util.List;

import static org.junit.Assert.*;

@RunWith(SpringRunner.class)

@SpringBootTest(classes = TkmybatisApplication.class)

public class UserDaoTest {

? ? @Autowired

? ? private UsersDao usersDao;

? ? @Autowired

? ? private OrdersDao ordersDao;

? ? @Test

? ? public void testSelect() {

? ? ? ? Example example = new Example(Users.class);

? ? ? ? Example.Criteria criteria = example.createCriteria();

? ? ? ? criteria.andEqualTo("userName", "bruce");

? ? ? ? List<Users> users = usersDao.selectByExample(example);

? ? ? ? Users user1 = users.get(0);

? ? ? ? System.out.println(user1);

? ? ? ? Example example1 = new Example(Orders.class);

? ? ? ? Example.Criteria criteria1 = example1.createCriteria();

? ? ? ? criteria1.andEqualTo("userId", user1.getUserId());

? ? ? ? List<Orders> ordersList = ordersDao.selectByExample(example1);

? ? ? ? user1.setOrdersList(ordersList);

? ? ? ? System.out.println(user1);

? ? ? ? System.out.println(user1.getOrdersList());

? ? }

? ? @Test

? ? public void testSelect2(){

? ? ? ? Users bruce = usersDao.selectByUsername("bruce");

? ? ? ? System.out.println(bruce);

? ? }

}


逆向工程操作(用于生成代碼)

maven引入

在dependencies中引入

<dependency>

? ? ? <groupId>tk.mybatis</groupId>

? ? ? <artifactId>mapper</artifactId>

? ? ? <version>4.1.5</version>

</dependency>

在build標(biāo)簽下面的plugins標(biāo)簽下加入

<plugin>

? ? ? ? ? ? ? ? <groupId>org.mybatis.generator</groupId>

? ? ? ? ? ? ? ? <artifactId>mybatis-generator-maven-plugin</artifactId>

? ? ? ? ? ? ? ? <version>1.3.5</version>

? ? ? ? ? ? ? ? <configuration>

??????????????????? <!-- 這里指定配置文件 -->

? ? ? ? ? ? ? ? ? ? <configurationFile>${basedir}/src/main/resources/generator/generatorConfig.xml</configurationFile>

? ? ? ? ? ? ? ? </configuration>

? ? ? ? ? ? ? ? <dependencies>

? ? ? ? ? ? ? ? ? ? <dependency>

? ? ? ? ? ? ? ? ? ? ? ? <groupId>mysql</groupId>

? ? ? ? ? ? ? ? ? ? ? ? <artifactId>mysql-connector-java</artifactId>

? ? ? ? ? ? ? ? ? ? ? ? <version>5.1.47</version>

? ? ? ? ? ? ? ? ? ? </dependency>

? ? ? ? ? ? ? ? ? ? <dependency>

? ? ? ? ? ? ? ? ? ? ? ? <groupId>tk.mybatis</groupId>

? ? ? ? ? ? ? ? ? ? ? ? <artifactId>mapper</artifactId>

? ? ? ? ? ? ? ? ? ? ? ? <version>4.1.5</version>

? ? ? ? ? ? ? ? ? ? </dependency>

? ? ? ? ? ? ? ? </dependencies>

? ? ? ? ? ? </plugin>


把配置文件放到resources下的generator目錄下(這里目錄可以隨意超全,但要跟上面pow.xml文件中的 configurationFile 中指定目錄一致)

內(nèi)置文件內(nèi)容如下

<?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>

? ? <!-- 引入數(shù)據(jù)庫(kù)連接配置 -->

<!--? ? <properties resource="jdbc.properties"/>-->

? ? <context id="Mysql" targetRuntime="MyBatis3Simple" defaultModelType="flat">

? ? ? ? <property name="beginningDelimiter" value="`"/>

? ? ? ? <property name="endingDelimiter" value="`"/>

? ? ? ? <!-- 配置 GeneralDAO -->

? ? ? ? <plugin type="tk.mybatis.mapper.generator.MapperPlugin">

? ? ? ? ? ? <property name="mappers" value="com.bruce.general.GeneralDao"/>

? ? ? ? </plugin>

? ? ? ? <!-- 配置數(shù)據(jù)庫(kù)連接 -->

? ? ? ? <jdbcConnection driverClass="com.mysql.jdbc.Driver"

? ? ? ? ? ? ? ? connectionURL="jdbc:mysql://localhost:3306/fmmall"

? ? ? ? ? ? ? ? userId="root" password="root">

? ? ? ? </jdbcConnection>

? ? ? ? <!-- 配置實(shí)體類存放路徑 -->

? ? ? ? <javaModelGenerator targetPackage="com.bruce.entity" targetProject="src/main/java"/>

? ? ? ? <!-- 配置 XML 存放路徑 -->

? ? ? ? <sqlMapGenerator targetPackage="/" targetProject="src/main/resources/mappers"/>

? ? ? ? <!-- 配置 DAO 存放路徑 -->

? ? ? ? <javaClientGenerator targetPackage="com.bruce.mapper" targetProject="src/main/java" type="XMLMAPPER"/>

? ? ? ? <!-- 配置需要指定生成的數(shù)據(jù)庫(kù)和表,% 代表所有表 -->

? ? ? ? <table tableName="%">

? ? ? ? ? ? <!-- mysql 配置 -->

<!--? ? ? ? ? ? <generatedKey column="id" sqlStatement="Mysql" identity="true"/>-->

? ? ? ? </table>

<!--? ? ? ? <table tableName="tb_roles">-->

<!--? ? ? ? ? ? &lt;!&ndash; mysql 配置 &ndash;&gt;-->

<!--? ? ? ? ? ? <generatedKey column="roleid" sqlStatement="Mysql" identity="true"/>-->

<!--? ? ? ? </table>-->

<!--? ? ? ? <table tableName="tb_permissions">-->

<!--? ? ? ? ? ? &lt;!&ndash; mysql 配置 &ndash;&gt;-->

<!--? ? ? ? ? ? <generatedKey column="perid" sqlStatement="Mysql" identity="true"/>-->

<!--? ? ? ? </table>-->

? ? </context>

</generatorConfiguration>


執(zhí)行生成

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末邓馒,一起剝皮案震驚了整個(gè)濱河市嘶朱,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌光酣,老刑警劉巖疏遏,帶你破解...
    沈念sama閱讀 206,723評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異救军,居然都是意外死亡财异,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門唱遭,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)戳寸,“玉大人,你說(shuō)我怎么就攤上這事拷泽∫呷担” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,998評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵跌穗,是天一觀的道長(zhǎng)订晌。 經(jīng)常有香客問(wèn)我虏辫,道長(zhǎng)蚌吸,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,323評(píng)論 1 279
  • 正文 為了忘掉前任砌庄,我火速辦了婚禮羹唠,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘娄昆。我一直安慰自己佩微,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,355評(píng)論 5 374
  • 文/花漫 我一把揭開(kāi)白布萌焰。 她就那樣靜靜地躺著哺眯,像睡著了一般。 火紅的嫁衣襯著肌膚如雪扒俯。 梳的紋絲不亂的頭發(fā)上奶卓,一...
    開(kāi)封第一講書(shū)人閱讀 49,079評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼漏益。 笑死穆桂,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的盏浙。 我是一名探鬼主播眉睹,決...
    沈念sama閱讀 38,389評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼废膘!你這毒婦竟也來(lái)了竹海?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,019評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤丐黄,失蹤者是張志新(化名)和其女友劉穎站削,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體孵稽,經(jīng)...
    沈念sama閱讀 43,519評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡许起,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,971評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了菩鲜。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片园细。...
    茶點(diǎn)故事閱讀 38,100評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖接校,靈堂內(nèi)的尸體忽然破棺而出猛频,到底是詐尸還是另有隱情,我是刑警寧澤蛛勉,帶...
    沈念sama閱讀 33,738評(píng)論 4 324
  • 正文 年R本政府宣布鹿寻,位于F島的核電站,受9級(jí)特大地震影響诽凌,放射性物質(zhì)發(fā)生泄漏毡熏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,293評(píng)論 3 307
  • 文/蒙蒙 一侣诵、第九天 我趴在偏房一處隱蔽的房頂上張望痢法。 院中可真熱鬧,春花似錦杜顺、人聲如沸财搁。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,289評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)尖奔。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間提茁,已是汗流浹背仗嗦。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,517評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留甘凭,地道東北人稀拐。 一個(gè)月前我還...
    沈念sama閱讀 45,547評(píng)論 2 354
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像丹弱,于是被迫代替她去往敵國(guó)和親德撬。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,834評(píng)論 2 345

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

  • 1躲胳、MyBatis簡(jiǎn)介 MyBatis 是一款優(yōu)秀的持久層框架 中文官網(wǎng):https://mybatis.org/...
    CHeng_c0e9閱讀 393評(píng)論 0 0
  • 1蜓洪、簡(jiǎn)介 1.1、什么是Mybatis MyBatis 是一款優(yōu)秀的持久層框架 它支持自定義 SQL坯苹、存儲(chǔ)過(guò)程以及...
    箋札code閱讀 1,272評(píng)論 0 0
  • MyBatis 新建工程隆檀,選好資源 實(shí)體類 不需要添加各種注解,直接把對(duì)應(yīng)字段生成get與set方法即可 pack...
    天馬行空_9f6e閱讀 3,091評(píng)論 0 0
  • ### 入門案例 第一個(gè):創(chuàng)建maven工程并導(dǎo)入坐標(biāo) 第二個(gè):創(chuàng)建實(shí)體類和dao接口 第三步:創(chuàng)建Mybatis...
    Sylvester_f7ee閱讀 198評(píng)論 0 0
  • Spring 技術(shù)筆記Day 1 預(yù)熱知識(shí)一粹湃、 基本術(shù)語(yǔ)Blob類型恐仑,二進(jìn)制對(duì)象Object Graph:對(duì)象圖...
    OchardBird閱讀 961評(píng)論 0 2