mybatis连接数据库实现双表查询

 更新时间:2024年09月19日 09:36:59   作者:『 初橙ζ 』  
本文主要介绍了mybatis连接数据库实现双表查询,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

创建maven工程包

 再点击下一步

 自己定义项目名称,在下一步

设置自己本地仓库位置

最后点击完成。

建好后在pom.xml文件中添加mybatis以及相关架包

  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.11</version>
      <scope>test</scope>
    </dependency>
    <dependency>
      <groupId>org.mybatis </groupId>
      <artifactId> mybatis</artifactId>
      <version>3.4.6</version>
    </dependency>
    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>5.1.38</version>
    </dependency>
    <dependency>
      <groupId>org.projectlombok</groupId>
      <artifactId>lombok</artifactId>
      <version>1.18.24</version>
    </dependency>
  </dependencies>

这些架包可以从Maven Repository: Search/Browse/Explore (mvnrepository.com)获取.

接着连接数据库表的接口

import java.util.List;

public interface OrdersDAO {
    public List<Orders> findOrderByUserid(long userid);

    public  void batchInsertOrder(List<Orders> ord);
}
public interface UserinfosDAO {

public List<Userinfos>findTop10();
public List<Userinfos>findUser(Userinfos user);

}

以及实用类

import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.util.Date;
import java.util.List;

@Data
@NoArgsConstructor
@AllArgsConstructor
@Builder
public class Userinfos {
    private  long userid;
    private  String username;
    private Date birthday;
    private  String pwd;
    private List<Orders> ords;
}
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.util.Date;
import java.util.List;

@Data
@NoArgsConstructor
@AllArgsConstructor
@Builder
public class Userinfos {
    private  long userid;
    private  String username;
    private Date birthday;
    private  String pwd;
    private List<Orders> ords;
}

以及配置文件order.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.kgc.mymb.dao.OrdersDAO">

    <!--   resulMap-->
    <!--   动态sql-->
    <select id="findOrderByUserid" parameterType="long" resultType="order">
        select * from orders where userid=#{userid}

    </select>
    <insert id="batchInsertOrder">
        insert  into orders values
    <foreach collection="list" item="order" separator=",">
    (#{order.ordid},#{order.userid},#{order.shopid},#{order.buynum})
    </foreach>
    </insert>
</mapper>

和userinfos.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.kgc.mymb.dao.UserinfosDAO">
    <!--    动态sql-->
    <select id="findUser" parameterType="user" resultType="user">
        select* from userinfos
      <where>
          <if test="username != null">
               username=#{username}
          </if>
          <if test="birthday != null">
               and date_format(birthday,'%Y-%m-%d')=date_format(#{birthday},'%Y-%m-%d')

          </if>
      </where>
    </select>

    <!--   resulMap  关联性查询-->
    <resultMap id="user_order" type="user">
        <!--      collection  一对多
          property 查询出订单的结果放在哪个属性中
          column 用什么列传递给订单做参数
          select 订单查询方法
          -->
        <result column="userid" property="userid"></result>
        <collection property="ords"
                    column="userid"
                    select="com.kgc.mymb.dao.OrdersDAO.findOrderByUserid">

        </collection>


    </resultMap>
    <select id="findTop10" resultMap="user_order">
        select * from userinfos limit 10
    </select>
</mapper>

数据库链接文件mybatis.cfg.xml

<?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>
<!--     给自己的实体类起别名-->
    <typeAliases>
        <typeAlias type="com.kgc.mymb.domain.Userinfos" alias="user"></typeAlias>
    <typeAlias type="com.kgc.mymb.domain.Orders" alias="order"></typeAlias>
    </typeAliases>
<!--    连接数据库配置-->
    <environments default="cm">
        <environment id="cm">
            <transactionManager type="JDBC"></transactionManager>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://192.168.47.3:3306/mydemo"/>
                <property name="username" value="root"/>
                <property name="password" value="ok"/>
            </dataSource>
        </environment>
    </environments>
<!--    加载用户的sql xml 文件-->
    <mappers>
        <mapper resource="mapper/userinfos.xml"></mapper>
        <mapper resource="mapper/orders.xml"></mapper>
    </mappers>
</configuration>

最后测试类

public class Demo {
    public static void main(String[] args) throws IOException {
        //读取配置文件
        Reader reader = Resources.getResourceAsReader("mybatis.cfg.xml");
        // 开启SqlSessionFactory工厂
        SqlSessionFactory factory=new SqlSessionFactoryBuilder().build(reader);
        //将你的dao接口注入到会话工厂配置对象中
        // factory.getConfiguration().addMapper(UserinfosDAO.class);
        //开启SqlSession
        SqlSession session =factory.openSession();
        //获取接口对象


        // UserinfosDAO udao= session.getMapper(UserinfosDAO.class);
        // Calendar cal=Calendar.getInstance();
        // cal.set(1995,3,22,0,0,0);
        // Userinfos us =  Userinfos.builder().username("dpjbms").birthday(cal.getTime()).build();
        // System.out.println(udao.findUser(us));

        UserinfosDAO udao= session.getMapper(UserinfosDAO.class);
        System.out.println( udao.findTop10());
        // OrdersDAO ordersDAO = session.getMapper(OrdersDAO.class);
        // Orders ord1=Orders.builder().ordid(10).userid(1).shopid(100).buynum(5).build();
        // Orders ord2=Orders.builder().ordid(11).userid(2).shopid(1).buynum(1).build();
        // List<Orders> ords=new ArrayList<>();
        // ords.add(ord1);
        // ords.add(ord2);
        // ordersDAO.batchInsertOrder(ords);
        // session.commit();


        // OrdersDAO ordersDAO= session.getMapper(OrdersDAO.class);
        // System.out.println(ordersDAO.findOrderByUserid(1));

        //关闭会话
        session.close();
    }
}

结果如图所示

到此这篇关于mybatis连接数据库实现双表查询的文章就介绍到这了,更多相关mybatis 双表查询内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • java实现双色球彩票游戏

    java实现双色球彩票游戏

    这篇文章主要为大家详细介绍了java实现双色球彩票游戏,超级简单的逻辑,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-06-06
  • SpringBoot整合screw实现自动生成数据库设计文档

    SpringBoot整合screw实现自动生成数据库设计文档

    使用navicat工作的话,导出的格式是excel不符合格式,还得自己整理。所以本文将用screw工具包,整合到springboot的项目中便可以自动生成数据库设计文档,非常方便,下面就分享一下教程
    2022-11-11
  • 图解程序员必须掌握的Java常用8大排序算法

    图解程序员必须掌握的Java常用8大排序算法

    本文以图片与文字结合的方式讲解了程序员必须掌握的Java常用8大排序算法:插入排序、冒泡排序、选择排序、希尔排序 、快速排序、归并排序、堆排序和LST基数排序,需要的朋友可以参考下
    2015-07-07
  • Java Exception异常全方面分析

    Java Exception异常全方面分析

    异常就是不正常,比如当我们身体出现了异常我们会根据身体情况选择喝开水、吃药、看病、等 异常处理方法。 java异常处理机制是我们java语言使用异常处理机制为程序提供了错误处理的能力,程序出现的错误,程序可以安全的退出,以保证程序正常的运行等
    2022-03-03
  • Java字符串替换方法详细讲解

    Java字符串替换方法详细讲解

    在Java编程中,处理字符串公式运算是一项常见的任务,特别是在需要动态计算或自定义逻辑的场景,这篇文章主要介绍了Java字符串替换方法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-09-09
  • java中处理socket通信过程中粘包的情况

    java中处理socket通信过程中粘包的情况

    本篇文章主要介绍了java中处理socket通信过程中粘包的情况,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-05-05
  • IntelliJ IDEA Tomcat控制台中文乱码问题的四种解决方案

    IntelliJ IDEA Tomcat控制台中文乱码问题的四种解决方案

    这篇文章主要给大家分享了4种方法完美解决IntelliJ IDEA Tomcat控制台中文乱码问题,文中有详细的图文介绍,对我们的学习或工作有一定的帮助,需要的朋友可以参考下
    2023-08-08
  • idea切换git地址并刷新右下角git分支

    idea切换git地址并刷新右下角git分支

    这篇文章主要介绍了idea切换git地址并刷新右下角git分支,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • Java经典算法汇总之冒泡排序

    Java经典算法汇总之冒泡排序

    冒泡排序基本思想:在要排序的一组数中,对当前还未排好序的范围内的全部数,自上而下对相邻的两个数依次进行比较和调整,让较大的数往下沉,较小的往上冒。即:每当两相邻的数比较后发现它们的排序与排序要求相反时,就将它们互换。
    2016-04-04
  • mybatis多层嵌套resultMap及返回自定义参数详解

    mybatis多层嵌套resultMap及返回自定义参数详解

    这篇文章主要介绍了mybatis多层嵌套resultMap及返回自定义参数详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12

最新评论