mabitis中的一对一关系项目实战:

1.首先根据创建以mybatis为基础的web项目(1)中的流程将web项目部署好

  1. 打开IDE,建立web工程
  2. 在lib下面粘贴mybatis的jar,log4j的jar,mysql 连接的jar 最后最最重要的是要添加到构建路径中去,这样才能够被项目所使用
  3. 新建一个源文件夹config,用于存放xml文件
  4. 在src目录把下面新建四个包,分别是:
      • com.pojo:存放数据库表对应的实体类
      • com.imp:存放接口类
      • com.test:存放测试类
      • com.util:存放工具类(最好写成静态方法,可以用类点方法的方式调用方法)
      • 目录结构如下图所示:
        •   
  5. 在config下面新建一个com.imp包:存放接口类对应的xml文件(使用mapper代理接口方式: 使用接口和XML文件,在后台自动生成操作数据库的类)
  6. 在config下面新建一个main_config.xml文件用于配置数据库和一些相关的映射,环境,插件,别名,配置文件
    1.   main_config.xml
  7. 相应的再建立一个main_config.properties(这是一个键值对的文件,可用于存放jdbc的连接,便于修改)
    1.   main_config.properties
  8. 写一个工具类(MybatisConnection.java ),用于获取连接:
    1.   

       package com.util;
      
       import java.io.IOException;
      import java.io.InputStream; import org.apache.ibatis.io.Resources;
      import org.apache.ibatis.session.SqlSession;
      import org.apache.ibatis.session.SqlSessionFactory;
      import org.apache.ibatis.session.SqlSessionFactoryBuilder; public class MyBatisConnection { public static SqlSession getSqlSession() throws IOException{
      //获取主配置文件
      InputStream inputStream = Resources.getResourceAsStream("main_config.xml");
      //创建会话工厂
      SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
      SqlSession sqlSession = sqlSessionFactory.openSession();
      return sqlSession; } }

      MyBatisConnection.java

  9. 写一个测试类(TestConnection):测试是否可以获取连接
    1.   

       package com.test;
      
       import java.io.IOException;
      
       import org.apache.ibatis.session.SqlSession;
      
       import com.util.MyBatisConnection;
      
       public class TestConnection {
      
           public static void main(String[] args) throws IOException {
      SqlSession sqlSession = MyBatisConnection.getSqlSession();
      System.out.println(sqlSession); }

      TestConnection.java  

      

2.建立一个人的表(t_person),每个人对应一个身份证(一一对应关系)所以建立一个(t_card)表

表结构如下图所示

3.建立对应的实体类(pojo)

注意在person.java中cid对应写的是card的对象

 package com.pojo;

 public class Card {
private int id;
private int cardid;
public Card() {
super();
// TODO 自动生成的构造函数存根
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public int getCardid() {
return cardid;
}
public void setCardid(int cardid) {
this.cardid = cardid;
}
@Override
public String toString() {
return "Card [id=" + id + ", cardid=" + cardid + "]";
} }

Card.java

 package com.pojo;

 public class Person {

     private int id;
private String name;
private Card card;
public Person() {
super();
// TODO 自动生成的构造函数存根
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Card getCard() {
return card;
}
public void setCard(Card card) {
this.card = card;
}
@Override
public String toString() {
return "Person [id=" + id + ", name=" + name + ", card=" + card + "]";
} }

Person.java

4.写接口或者对应的xml文件(要注意三个规范:1.接口名和映射文件名相同,2.在同一目录下,3.使用mapper代理接口(接口和XML文件,在后台自动生成操作数据库的类))

建议先写接口,有了接口之后再考虑怎么实现

我先写了一个接口(IPerson.java)

 package com.imp;

 import java.util.List;

 import com.pojo.Person;

 public interface IPerson {
//查询所有
List<Person> sqlall(); }

IPerson.java

再写对应的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" >
<!-- namespace:命名空间, 用于隔离sql语句 -->
<mapper namespace="com.imp.IPerson">
<!-- id是sql语句的唯一标识符,名字要与 接口中的方法名相同 -->
<select id="sqlall" resultMap="test">
SELECT
t_person.id,
t_person.`name`,
t_person.cid,
t_card.id,
t_card.cardid
FROM
t_card
INNER JOIN t_person ON t_person.cid = t_card.id
</select>
<resultMap type="person" id="test">
<id column="id" property="id" />
<result column="name" property="name" />
<!-- association 是一对一映射关系使用的标签 -->
<association property=""></association>
<association property="card" javaType="card">
<id column="cid" property="id" />
<result column="cardid" property="cardid" />
</association>
</resultMap> </mapper>

IPerson.xml

在IPerson.xml中namepace的值为对应的接口的全限定名(com.imp.IPerson)

在IPerson.xml的查询中我们没有使用resultType而是使用了resultMap

这是因为数据库表中的字段和实体类的属性不一致,这时候我们使用resultMap

id表示主键, 

result 表示普通的字段

association:一对一关系

column表示:查询结果对应的字段

property:实体类对应的属性

查询语句可以直接通过工具直接生成(直接拖动到空白处即可生成查询语句)

5.接下来就应该是在主配置文件中写映射文件的路径了

大家发现没有,我在IPerson.xml文件中写的Type,javaType都是实体类名,没有加包名,(这里我们要注意,我在主配置

文件中写了别名,是通过包来加载的,所以只要写类名即可,首字母的大小写不作区分)

在主配置文件的mappers标签中我使用的也是package映射,这是为了使用更加方便,如果有很多的xml文件要映射,那不是要写很多,这里只写一句就够了。

         <!-- 取别名 -->
<typeAliases>
<package name="com.pojo"/>
</typeAliases>
<!-- 添加映射文件 -->
<mappers>
<package name="com.imp"/>
</mappers>

main_config.xml

注意标签的顺序,这个有严格的规定

Content Model : (properties?, settings?, typeAliases?, typeHandlers?, objectFactory?,
objectWrapperFactory?, reflectorFactory?, plugins?, environments?, databaseIdProvider?, mappers?)

6.接下来我们就要写一个测试文件,看看我们是否写成功了

 package com.test;

 import java.io.IOException;
import java.util.List; import org.apache.ibatis.session.SqlSession; import com.imp.IPerson;
import com.pojo.Person;
import com.util.MyBatisConnection; public class TestSqlAll { public static void main(String[] args) throws IOException {
SqlSession sqlSession = MyBatisConnection.getSqlSession();
IPerson person = sqlSession.getMapper(IPerson.class);
List<Person> list = person.sqlall();
for (Person person2 : list) {
System.out.println(person2);
}
}
}

TestSqlAll.java

可能测试的时候会发生错误,我们要仔细看看报的什么错误,找到错误所在,改正即可

7.测试结果如下(如果为空,那是因为你的数据库是空的啊)

创建以mybatis为基础的web项目(2)mabitis中的一对一关系项目实战的更多相关文章

  1. 创建以mybatis为基础的web项目(1)

    1. 新建项目,生成web.xml(生成的目录结构如下所示) 目录结构如下图 2. 导入mybatis包,数据库驱动包,log4j包(复制到webroot目录下的lib文件夹下面,并添加到构建路径) ...

  2. 201871010203-陈鹏昱 实验二 个人项目—《D{0-1}KP问题》项目报告

    项目 内容 课程班级博客链接 班级博客 这个作业要求链接 作业要求 我的课程学习目标 运用科学高效的方法学习软件工程的理论和知识 这个作业在哪些方面帮助我实现学习目标 掌握软件项目个人开发流程,掌握G ...

  3. MyBatis项目配置案例详解与Web下的增删改查实现[附项目源码]

    MyBatis项目案例 项目图示: 项目源码地址:https://github.com/JluTiger/mybatispro 1.项目功能 项目案例:后台管理系统用户数据维护平台 所有用户数据查询 ...

  4. IntelliJIDEA 14创建Maven管理的Java Web项目

    1.新建项目,选择Maven,点击Next继续. 接着输入项目名 接着直接点击Finish即可 下图就是创建完毕后的Maven项目,双击pom.xml查看POM文件内容,可以自行添加Maven的依赖. ...

  5. webstorm创建nodejs + express + jade 的web 项目

    webstorm创建nodejs + express + jade 的web 项目 前简单了解过nodejs,觉得用nodejs来做个网站也太麻烦了,要自己拼html的字符串返回,这能做网站嘛? 最近 ...

  6. 基于SpringBoot + Mybatis实现SpringMVC Web项目

    一.热身 一个现实的场景是:当我们开发一个Web工程时,架构师和开发工程师可能更关心项目技术结构上的设计.而几乎所有结构良好的软件(项目)都使用了分层设计.分层设计是将项目按技术职能分为几个内聚的部分 ...

  7. IntelliJ IDEA 12创建Maven管理的Java Web项目(图解)

    转:http://blog.csdn.net/zht666/article/details/8673609/ 本文主要使用图解介绍了使用IntelliJIDEA 12创建Maven管理的JavaWeb ...

  8. Spring+Maven+Dubbo+MyBatis+Linner+Handlebars—Web开发环境搭建

    本文主要分三部分,分别是:后台核心业务逻辑.桥梁辅助控制和前台显示页面. 本Web开发环境综合了多种工具,包括Maven包管理与编译工具.Dubbo分布式服务框架.MyBatis数据持久化工具.Lin ...

  9. Spring Boot 2.X(三):使用 Spring MVC + MyBatis + Thymeleaf 开发 web 应用

    前言 Spring MVC 是构建在 Servlet API 上的原生框架,并从一开始就包含在 Spring 框架中.本文主要通过简述 Spring MVC 的架构及分析,并用 Spring Boot ...

随机推荐

  1. JavaScript变量提升的本质

    变量提升 先说三句总结性的话: let 的「创建」过程被提升了,但是初始化没有提升. var 的「创建」和「初始化」都被提升了. function 的「创建」「初始化」和「赋值」都被提升了. 所以,我 ...

  2. Python基础-week01

    本节内容摘要:http://www.cnblogs.com/Jame-mei Python介绍 Python是怎么样的语言? Python 2 or 3? 安装 Hello World程序 变量 用户 ...

  3. python趣味——与MS系列编译器一样强大的Unicode变量名支持

    中文变量名,中文函数名,中文类名等,可惜Python2不支持,但在Python3时代,这些都可以完美支持了. def 中文函数(): return 1

  4. laravel 原生 sql

    1.插入数据 DB::insert('insert into users (id, name, email, password) values (?, ?, ? , ? )',[1, 'Laravel ...

  5. Java语法基础(1)

    Java语法基础(1) 1.      Java是一门跨平台(也就是跨操作系统)语言,其跨平台的本质是借助java虚拟机 (也就是JVM(java virtual mechinal))进行跨平台使用. ...

  6. 【网络】 应用&传输层笔记

    应用层 应用层常用的协议和各自对应的TCP/UDP端口: DNS TCP/UDP 53 HTTP TCP 80 SMTP TCP 25 POP UDP 110 Telnet TCP 23 DHCP U ...

  7. 使用ADO.NET查询和操作数据

    使用ADO.NET查询和操作数据 StringBuilder类: 用来定义可变字符串StringBuilder sb = new StringBuilder("");//追加字符串 ...

  8. 巨人大哥谈Web应用中的Session(session详解)

    巨人大哥谈Web应用中的Session(session详解) 虽然session机制在web应用程序中被采用已经很长时间了,但是仍然有很多人不清楚session机制的本质,以至不能正确的应用这一技术. ...

  9. springboot集成mybatisplus

    介绍: Mybatis-Plus(简称MP)是一个 Mybatis 的增强工具,在 Mybatis 的基础上只做增强不做改变,为简化开发.提高效率而生.(摘自mybatis-plus官网)Mybati ...

  10. 201621123040《Java程序设计》第八周学习总结

    1.本周学习总结 2.书面作业 2.1ArrayList代码分析 2.1.1解释ArrayList的contains源代码 ArrayList.contain()方法通过调用indexOf()来判断元 ...