Mybatis、使用注解的方式編寫用戶和角色一對多關系,并使用延遲加載

1、數據庫準備

CREATE TABLE `role` (

? `ID` INT(11) NOT NULL COMMENT '編號',
? `ROLE_NAME` VARCHAR(30) DEFAULT NULL COMMENT '角色名稱',
? `ROLE_DESC` VARCHAR(60) DEFAULT NULL COMMENT '角色描述',
? PRIMARY KEY? (`ID`)
) ENGINE=INNODB DEFAULT CHARSET=utf8;
INSERT? INTO `role`(`ID`,`ROLE_NAME`,`ROLE_DESC`) VALUES (1,'院長','管理整個學院'),(2,'總裁','管理整個公司'),(3,'校長','管理整個學校');
CREATE TABLE `user` (
? `id` INT(11) NOT NULL AUTO_INCREMENT,
? `username` VARCHAR(32) NOT NULL COMMENT '用戶名稱',
? `birthday` DATETIME DEFAULT NULL COMMENT '生日',
? `sex` CHAR(1) DEFAULT NULL COMMENT '性別',
? `address` VARCHAR(256) DEFAULT NULL COMMENT '地址',
? PRIMARY KEY? (`id`)
) ENGINE=INNODB DEFAULT CHARSET=utf8;

INSERT? INTO `user`(`id`,`username`,`birthday`,`sex`,`address`) VALUES (41,'老王','2018-02-27 17:47:08','男','北京'),(42,'小二王','2018-03-02 15:09:37','女','北京金燕龍'),(43,'小二王','2018-03-04 11:34:34','女','北京金燕龍'),(45,'傳智播客','2018-03-04 12:04:06','男','北京金燕龍'),(46,'老王','2018-03-07 17:37:26','男','北京'),(48,'小馬寶莉','2018-03-08 11:44:00','女','北京修正');

2、創建一個Maven項目

pom.xml引入約束:

<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>cn.wzq</groupId>
? <artifactId>MyBatis_day04_01_note_user_role_onetomany</artifactId>
? <version>0.0.1-SNAPSHOT</version>
??? <dependencies>
?? ??? ?<!-- log4j日志 -->
?? ??? ?<dependency>
?? ??? ??? ?<groupId>log4j</groupId>
?? ??? ??? ?<artifactId>log4j</artifactId>
?? ??? ??? ?<version>1.2.12</version>
?? ??? ?</dependency>
?? ??? ?<!-- mysql驅動 -->
?? ??? ?<dependency>
?? ??? ??? ?<groupId>mysql</groupId>
?? ??? ??? ?<artifactId>mysql-connector-java</artifactId>
?? ??? ??? ?<version>5.1.6</version>
?? ??? ?</dependency>
?? ??? ?<!-- mybatis的坐標 -->
?? ??? ?<dependency>
?? ??? ??? ?<groupId>org.mybatis</groupId>
?? ??? ??? ?<artifactId>mybatis</artifactId>
?? ??? ??? ?<version>3.4.5</version>
?? ??? ?</dependency>
?? ??? ?<dependency>
?? ??? ??? ?<groupId>junit</groupId>
?? ??? ??? ?<artifactId>junit</artifactId>
?? ??? ??? ?<version>4.12</version>
?? ??? ?</dependency>
?? ?</dependencies>
</project>

2、創建數據庫信息配置文件:jdbc.properties

jdbc.username=root
jdbc.password=root
jdbc.url=jdbc:mysql://localhost:3306/mybatisdb?characterEncoding=utf8

jdbc.driver=com.mysql.jdbc.Driver

3、配置核心配置文件

<?xml version="1.0" encoding="UTF-8" ?>
<!-- 核心配置文件的約束 -->
<!DOCTYPE configuration
? PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
? "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>? ?
?? ?<!-- 引入數據庫配置信息 -->
?? ?<properties resource="jdbc.properties"></properties>
?? ?<!-- 別名配置 -->
?? <typeAliases>
? ?? ???? <package name="cn.wzq.mybatis.domin"/>
?? </typeAliases>
?? <environments default="development">? ?
????? <environment id="development">? ?
??????? <transactionManager type="JDBC" />? ?
??????? <dataSource type="POOLED">? ?
????????? <property name="driver" value="${jdbc.driver}" ></property>? ?
????????? <property name="url" value="${jdbc.url}" ></property>? ?
????????? <property name="username" value="${jdbc.username}"></property>
????????? <property name="password" value="${jdbc.password}"></property>
??????? </dataSource>? ?
???? </environment>? ?
? </environments>
? <!-- sql映射配置 -->
? <mappers>
? ?? ?<package name="cn.wzq.mybatis.dao"/>
? </mappers>
</configuration>??

4、創建user和role對象

public class User {

?? ?private Integer id;
?? ?private String username;
?? ?private String sex;
?? ?private String address;
?? ?private Date birthday;

??? private List<Role> list;

?? //get/set/toString省略;

public class Role {
?? ?private Integer id;
?? ?private String ROLE_NAME;
?? ?private String ROLE_DESC;
??? //get/set/toString省略;

5、創建IRoleDao接口

public interface IRoleDao {

?? ?//根據用戶查詢角色
?? ?@Select(value="select * from role where id = #{id}")
?? ?public Role findRole(int uid);
?? ??? ?
}

6、創建IUserDao接口

public interface IUserDao {
?? ?
?? ?//查詢用戶下的所有角色
?? ?@Select(value="select * from user")
?? ?@Results(value= {
?? ??? ??? ?@Result(property="id",column="id",id=true),
?? ??? ??? ?@Result(property="username",column="username"),
?? ??? ??? ?@Result(property="sex",column="sex"),
?? ??? ??? ?@Result(property="address",column="address"),
?? ??? ??? ?@Result(property="birthday",column="birthday"),
?? ??? ??? ?@Result(property="list",javaType=List.class,column="id",
?? ??? ??? ??? ?many=@Many(select="cn.wzq.mybatis.dao.IRoleDao.findRole",fetchType=FetchType.LAZY)
?? ??? ??? ?)
?? ?})
?? ?public List<User> findAll();

}

7、測試

??? //查詢用戶下所有角色
?? ?@Test
?? ?public void findAllTest() {
?? ??? ?SqlSession openSession = sqlSessionFactory.openSession();
?? ??? ?IUserDao userDao = openSession.getMapper(IUserDao.class);
?? ??? ?List<User> list = userDao.findAll();
?? ??? ?for (User user : list) {
?? ??? ??? ?System.out.println(user.getId());
?? ??? ??? ?//System.out.println(user.getList()); //需要使用時釋放注解
?? ??? ?}

?? ?}

整體目錄結構


本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/273730.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/273730.shtml
英文地址,請注明出處:http://en.pswp.cn/news/273730.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

織夢標簽大全

關鍵描述調用標簽&#xff1a; <meta name"keywords" content"{dede:field namekeywords/}"> <meta name"description" content"{dede:field namedescription functionhtml2text(me)/}"> -------------------------------…

spring的注入

1、構造函數注入的是設計到的標簽&#xff1a;constructor-arg屬性&#xff1a;index:指定參數在構造函數參數列表的索引位置type:指定參數在構造函數中的數據類型name:指定參數在構造函數中的名稱上面三個都是找誰 &#xff0c;給誰賦值&#xff0c;下面兩個指的是賦什么值 va…

.Net中堆棧和堆的區別

首先堆棧和堆&#xff08;托管堆&#xff09;都在進程的虛擬內存中。&#xff08;在32位處理器上每個進程的虛擬內存為4GB&#xff09; 堆棧stack 1、堆棧中存儲值類型 2、堆棧實際上是向下填充&#xff0c;即由高內存地址指向低內存地址填充 3、堆棧的工作方式是先分配內存的變…

spring的IOC注解

1、創建對象的注解 含義&#xff1a;使用注解的形式創建對象&#xff0c;交給Spring容器管理(需要配置在類上) Component:組件 Controller:web層 Service:service層 Repository:Dao層默認&#xff1a;創建對象的唯一標識&#xff0c;當前類名首字母小寫value屬性&#xff1a;指…

PowerDesigner 逆向工程 從SQL文件轉換成PDM 從PDM轉成CDM

從SQL文件逆向工程到PDM&#xff1a; ①選擇file -> Reverse Engineer - > Database ②在General選項卡中選擇MySQL數據庫&#xff0c;點擊確定。 ③using script file 選擇你的sql文件&#xff0c;最后選擇確定。 從PDM轉成CDM&#xff1a; ①選擇工具 -> General CD…

SpringMvc的執行過程

Tomcat啟動 1、部署項目到Tomcat中 2、啟動Tomcat加載Web.xml 3、初始化DispatcherServlet(執行的是init方法) 4、加載配置文件&#xff0c;創建對象交給Spring容器管理 5、通過處理器映射器解析RequestMappin配置&#xff0c;配置‘請求地址’和‘控制器類’的映射關系 小結&a…

自然語言理解——introduction

1.基本概念&#xff1a; NLP&#xff1a;自然語言處理是研究如何利用計算機技術對語言文本&#xff08;句子、篇章或話語等&#xff09;進行處理和加工的一門學科&#xff0c;研究內容包括對詞法、句法、語義和語用等信息的識別、分類、提取、轉換和生成等各種處理方法和實現技…

Eclipse中彈出OLE Exception窗口

樓主事故原因&#xff1a;首先打開一個類&#xff0c;然后因為手速太快&#xff0c;在該類的編輯窗口中右鍵&#xff0c;單擊&#xff0c;不要問我點了啥&#xff0c;我也不知。后面發現該類的編輯器沒有顯示任何內容&#xff0c;但是可以發現代碼依然存在只是沒有顯示。 關閉…

HDOJ-3790-最短路徑問題 解題報告

一道最短路問題。普通最短路問題的邊只有一種權值&#xff0c;而此題的邊要考慮兩種權值。因為節點n<1000&#xff0c;所以不能夠使用Floyd算法&#xff0c;時間復雜度較高&#xff0c;這里使用Dijkstra算法解決。 中文描述&#xff0c;題意不再贅述。只是要注意每條邊都有距…

利用自定命令打開常用軟件,小白秒變大神。

不多說&#xff0c;先來個效果&#xff0c;WIINR打開運行&#xff0c;輸入qq(小編自定的命令)&#xff0c;就能打開。 實現步驟&#xff1a; 1、找到快捷方式(以騰訊QQ為例) 2、將騰訊QQ快捷方式復制粘貼到C:\Windows,并修改名稱 3、測試&#xff0c;winr代開運行&#xff0c;…

問題之JS中傳遞數值過大或前置有零時

1、JS中傳遞數值多大數值會變 var number 00161213313254545433 turnToDetail(number); function turnToDetail(queryNumber){ queryNumber ! 00161213313254545433(true) } 應將數值轉換為字符串 var number 00161213313254545433 turn…

rpm的用法 詳解

Linux rpm 命令參數使用詳解&#xff3b;介紹和應用&#xff3d; RPM是RedHat Package Manager&#xff08;RedHat軟件包管理工具&#xff09;類似Windows里面的“添加/刪除程序” rpm 執行安裝包二進制包&#xff08;Binary&#xff09;以及源代碼包&#xff08;Source&#x…

Android與Libgdx環境配置

此處所說的是基于windows和android版本的libgdx環境配置。 1. 下載所需軟件 JDK 1.7。 下載地址&#xff1a; window x86版本地址&#xff1a; http://www.oracle.com/technetwork/java/javase/downloads/jdk7-downloads-1880260.html Android SDK。 在android官網上下載最新版…

問題之sqlyou的使用

當數據過大時一定要注意sqlyou每頁只能顯示1000條數據

問題之mybatis-plus中的TableField、Tableld的區別

Tableld&#xff1a;屬性與主鍵的映射關系。 TableField:列與屬性的映射關系。

淺藍色設計類網站模板

淺藍色設計類網站模板是一款高端大氣的設計css3企業網站模板。 模板地址&#xff1a;http://www.huiyi8.com/sc/8673.html 轉載于:https://www.cnblogs.com/xkzy/p/3765371.html

html5中的一些標簽學習總結

html5 contenteditable"true" html5內容可編輯屬性 html5 hgroup hgroup字面意思是頭部的組&#xff0c;可以將其分拆為h和group來理解。在html5中的作用是用于對網頁和區塊的標題進行組合。&#xff08;網頁是一個最大的區塊&#xff0c;所以可以認為hgroup是區塊的…

總結1:Ajax上傳圖片至阿里云服務器

1.頁面效果以及JS <!-- HTML --> <div style"margin:30px;"><div class"form-horizontal rowt"><div class"control-label col-lg-1">標書分類</div><div class"col-lg-2"><select required&q…

Leetcode::Subsets

Given a set of distinct integers, S, return all possible subsets. 分析&#xff1a;題目就是給一個整數集合&#xff0c;給出所以的子集。 基本思想是遞歸或者說是迭代的方法。用前面得到的集合來構造 后面的。但是怎樣高效、方便的構造集合是關鍵點。比如&#xff0c;開始…

總結2:上傳圖片至指定服務器

1.前段頁面以及JS <!-- HTML --> <section class"content"><div class"row"><div class"col-xs-12"><div class"box box-success"><div class"row" style"margin-top: 1%;margin-bu…