myBatis 基础测试 表关联关系配置 集合 测试

时间:2023-01-13 07:33:54

myBatis 基础测试 表关联关系配置 集合 测试

测试myelipse项目源码 sql 下载 http://download.csdn.net/detail/liangrui1988/5993881

在上一篇做了简单 增删改查 的测试,基本代码+api 下载 可以看上一遍博文 myBatis 基础测试 增 删 改 查 用过hibrenate 之后,感觉很好理解

动行效果:

myBatis 基础测试 表关联关系配置 集合 测试

myBatis 基础测试 表关联关系配置 集合 测试

sql :

CREATE TABLE `student` (
`grade_id` int(11) DEFAULT NULL,
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(20) DEFAULT NULL,
`age` int(11) DEFAULT NULL,
`password` varchar(20) DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `fk_sutids` (`grade_id`),
CONSTRAINT `fk_sutids` FOREIGN KEY (`grade_id`) REFERENCES `grade` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;
/*!40101 SET character_set_client = @saved_cs_client */; INSERT INTO `student` VALUES (1,1,'admin',30,'123'),(1,2,'hello',100,'world'),(1,3,'林冲',45,'aaa'),(1,4,'宋江',55,'123456'),(2,5,'吴用',46,'123456'),(2,6,'武松',30,'3333');

sql:

-- MySQL dump 10.13  Distrib 5.5.20, for Win32 (x86)
--
-- Host: localhost Database: ruiabc
-- ------------------------------------------------------
-- Server version 5.5.20 CREATE TABLE `grade` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`grade_name` varchar(20) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8; INSERT INTO `grade` VALUES (1,'157'),(2,'158'); -- Dump completed on 2013-08-22 16:10:48

在里演示表关联的查询方试 注要代码

班级 xml:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.2//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="accp.dao">
<!-- 班集对象 类型 resultMap-->
<resultMap type="Grade" id="gradeRsultMap">
<id property="id" column="id"/>
<result property="grade_name" column="grade_name"/>
<!-- 学生集合 -->
<collection property="stu_list" column="id" javaType="ArrayList"
select="selectStudent" ofType="Student">
</collection>
</resultMap> <!-- 查询班级 并且和班级里的学生 条件-->
<select id="selectGradeAndStudentById" resultMap="gradeRsultMap" parameterType="int">
select * from grade where id=#{id}
</select> <!-- 查询班级下的学生 给集合引用 -->
<select id="selectStudent" resultType="Student" parameterType="int">
select * from student where grade_id=#{id}
</select> <!-- 方式二 -->
<select id="sqlSelectGradeAndStdeentById" resultMap="gradeMapbySql" parameterType="int">
select * from student s inner join grade g on s.grade_id= g.id where g.id=#{id}
</select>
<!-- select g.id,g.grade_name from student s inner join grade g on s.grade_id= g.id where g.id=#{id} -->
<resultMap type="Grade" id="gradeMapbySql">
<id property="id" column="id"/>
<result property="grade_name" column="grade_name"/>
<!-- 学生集合 类型的 引用 column="id" -->
<collection property="stu_list" ofType="Student" resultMap="StudentRsultMap" />
</resultMap> <!-- 学生集合 类型的 -->
<resultMap type="Student" id="StudentRsultMap">
<id property="id" column="id"/>
<result property="name" column="name"/>
<result property="age" column="age"/>
<result property="password" column="password"/> </resultMap> <!-- select grade by id select="selectGradeById" -->
<select id="selectGradeById" parameterType="int" resultType="Grade">
select * from grade where id=#{id}
</select>
<!-- select All grade -->
<select id="selectAllGradeAndStudents" resultType="Grade">
select * from grade
</select> </mapper>

sqlSession工具代码在上一篇里有,或都下载源码

测试代码:

package accp.test;

import java.util.List;
import java.util.Map;
import java.util.Map.Entry; import org.apache.ibatis.session.SqlSession; import accp.bean.Grade;
import accp.bean.Student;
import accp.dao.Dao;
import accp.dao.imp.DaoImp;
import accp.util.GetSession; public class TestRsultMap {
public static void main(String[] args) { SqlSession sqlSession=GetSession.getInstans().getSqlSession();
/*查询学生信息 包括所在班级*/
/*Student stu=sqlSession.selectOne("accp.dao.selectStuAndGrade",2);
System.out.println("学生id: "+stu.getId()+" "+stu.getName()+" "+stu.getPassword()+
" "+stu.getAge()+" 所在班级名称: "+stu.getGrade_id().getGrade_name()+
" 班级id: "+stu.getGrade_id().getId());*/ //查询班级信息 包括班级里的所有学生
Grade grade=sqlSession.selectOne("accp.dao.selectGradeAndStudentById",1);
System.out.println("班级ID:"+grade.getId()+" name: "+grade.getGrade_name());
System.out.println(" 班级里的学生: "+grade.getStu_list().size()+" 个 -------------");
System.out.println("id \t 姓名 \t 密码 \t 年龄");
for(Student tempStu:grade.getStu_list()){
System.out.println(tempStu.getId()+" \t "+tempStu.getName()+" \t "+tempStu.getPassword()+
" \t "+tempStu.getAge());
} //查询班级信息 包括班级里的所有学生 通过sql关联查询方式
/*直接取对应取不出来????没有第一种方式好用
* Map<String,Grade> map=sqlSession.selectMap("accp.dao.sqlSelectGradeAndStdeentById","id");
System.out.println(map.size());
for(Entry entry:map.entrySet()){
Grade gr=(Grade)entry.getValue();
System.out.println("MapKey "+entry.getKey() +
" mapValue Gr Name:"+ gr.getGrade_name()+
"gr Stu 共几个:"+gr.getStu_list().size());
}*/ //list-------- test
/* List<Grade> list=sqlSession.selectList("accp.dao.sqlSelectGradeAndStdeentById",1);
for(Grade grade2:list){
System.out.println("班级ID:"+grade2.getId()+" name: "+grade2.getGrade_name());
System.out.println(" 班级里的学生: "+grade2.getStu_list().size()+" 个 -------------");
System.out.println("id \t 姓名 \t 密码 \t 年龄");
for(Student tempStu:grade2.getStu_list()){
System.out.println(tempStu.getId()+" \t "+tempStu.getName()+" \t "+tempStu.getPassword()+
" \t "+tempStu.getAge());
}
}*/ }
}

myBatis 基础测试 表关联关系配置 集合 测试的更多相关文章

  1. Python 基础-python-列表-元组-字典-集合

    列表格式:name = []name = [name1, name2, name3, name4, name5] #针对列表的操作 name.index("name1")#查询指定 ...

  2. freeRadius 基础配置及测试

    国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html 内部邀请码:C8E245J (不写邀请码,没有现金送) 国 ...

  3. 构建基于表单配置的 Jenkins 测试项目(接口、UI、APP、Jmeter)

    1. 第一个 hello world 项目 2. 构建自动触发的项目(接口测试) 1)新建测试项目(执行测试脚本) 2)新建 Maven 打包项目 3)手动执行构建 4)修改 Web 工程代码并 pu ...

  4. IntelliJ IDEA安装、配置、测试

    IntelliJ IDEA安装.配置.测试(win7_64bit) 目录 1.概述 2.本文用到的工具 3.安装.激活与配置 4.开发测试 4.1 JavaSE开发测试(确保JDK已正确安装) 4.2 ...

  5. Myeclipse安装、配置、测试

    Myeclipse安装.配置.测试(win7_64bit) 目录 1.概述 2.本文用到的工具 3.安装与激活 4.JavaSE开发测试(确保JDK已正确安装) 5.JavaEE开发测试(确保服务器和 ...

  6. 【Oracle】曾经的Oracle学习笔记(1-3) 数据库常见用语,常见命令,创建测试表

    一.数据库的登录 二.数据库常用语 三.测试表的创建,测试数据初始化 四.常见命令介绍 五.测试 user:jeffreysn:jeffrey user:systemsn:jeffrey 浏览器中输入 ...

  7. Web API核查表:设计、测试、发布API时需思考的43件事&lbrack;转&rsqb;

    Web API核查表:设计.测试.发布API时需思考的43件事   当设计.测试或发布一个新的Web API时,你是在一个原有的复杂系统上构建新的系统.那么至少,你也要建立在HTTP上,而HTTP则是 ...

  8. LNMP环境搭建:Nginx安装、测试与域名配置

    Nginx作为一款优秀的Web Server软件同时也是一款优秀的负载均衡或前端反向代理.缓存服务软件 2.编译安装Nginx (1)安装Nginx依赖函数库pcre pcre为“perl兼容正则表达 ...

  9. Eclipse For JavaEE安装、配置、测试

    Eclipse For JavaEE安装.配置.测试(win7_64bit) 目录 1.概述 2.本文用到的工具 3.安装与配置 4.JavaSE开发测试(确保JDK已正确安装) 5.JavaEE开发 ...

随机推荐

  1. 设计模式--组合模式Composite(结构型)

    一.概念 组合模式允许你将对象组合成树形结构来表现"整体/部分"层次结构.组合能让客户以一致的方式处理个别对象以及对象组合. 二.UML图 1.Component(对象接口),定义 ...

  2. linux下zip文件解压后乱码解决方案

    解决办法一,利用pyton来处理 1.vi uzip文件2.复制一下内容(Python) #!/usr/bin/env python # -*- coding: utf-8 -*- # uzip.py ...

  3. CSS选择器的兼容性

    CSS 1 CSS2.1 CSS3 :hover 在IE6中只有a元素可用.E:empty 貌似在webkit核心浏览器中有些小bug.如果这个bug依然存在,不太确定如何测试.IE6不支持.clas ...

  4. csu 1305 Substring (后缀数组)

    http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1305 1305: Substring Time Limit: 2 Sec  Memory Limi ...

  5. shuffle ----- mr 董西城

    http://dongxicheng.org/framework-on-yarn/apache-spark-shuffle-details/

  6. C&num;自动实现Dll&lpar;OCX&rpar;控件注册的两种方法

    尽管MS为我们提供了丰富的.net framework库,我们的程序C#开发带来了极大的便利,但是有时候,一些特定功能的控件库还是需要由第三方提供或是自己编写.当需要用到Dll引用的时候,我们通常会通 ...

  7. 如何调用common&period;js

    第一步 页面需要引用此js 第二步 var loginJs = { //登录 goLogin: function () { var _userinfo = { name: "夏小沫&quot ...

  8. springcloud的finchley&period;RC2的bug

    https://blog.csdn.net/qq_14809913/article/details/80606772 https://www.cnblogs.com/Little-tree/p/916 ...

  9. denyhosts、中文文档乱码、端口占用查询

    1.安装 denyhosts, 设置 hosts.allow ,系统自动将攻击的ip 添加如 hosts.deny2.打开中文文档乱码, 将文档下载到windows, 通过富文本编辑器查看文档编码3. ...

  10. 缓存 Memached

    https://github.com/enyim/EnyimMemcached http://www.newasp.net/soft/63735.html#downloaded/ http://blo ...