返回顶部
首页 > 资讯 > 精选 >MyBatis和jeesite多表查询的方法
  • 385
分享到

MyBatis和jeesite多表查询的方法

2023-06-30 03:06:46 385人浏览 八月长安
摘要

这篇文章主要介绍了mybatis和jeesite多表查询的方法的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇MyBatis和jeesite多表查询的方法文章都会有所收获,下面我们一起来看看吧。有时候经常碰到多级

这篇文章主要介绍了mybatis和jeesite多表查询的方法的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇MyBatis和jeesite多表查询的方法文章都会有所收获,下面我们一起来看看吧。

有时候经常碰到多级联查,比如通过某个功能A表查角色信息,但是A表和角色表没有直接的关联关系,需要通过用户表进行关联,所以就需要多级关联查询出来了(下面的只是举例,实际应用用户和角色不会这样设计字段)

一、MyBatis xml文件手写resultMap和查询语句

MyBatis配置文件:因为是通过column(数据库字段名称)和property(实体类对象名称)进行数据绑定的,如果存在相同字段的名字可以用as修改字段名称也能进行特殊绑定

<resultMap type="User" id="UserResult">        <!--  表字段  -->        <result property="xxxxxxxxxId" column="xxxxxxxxx_id"/>        <!--  通用字段和关联字段  -->        <result property="userId" column="user_id"/>        <result property="status" column="status"/>        <result property="createBy" column="create_by"/>        <result property="createTime" column="create_time"/>        <result property="updateBy" column="update_by"/>        <result property="updateTime" column="update_time"/>        <result property="remark" column="remark"/>        <result property="scriptJSON" column="script_json"/>        <!--  关联查询  -->        <association property="user" column="user_id" javaType="User" resultMap="UserResult"/></resultMap><resultMap type="User" id="UserResult">        <id property="userId" column="user_id"/>        <result property="userName" column="user_name"/>        <id property="roleId" column="role_id"/>        <!--  二级关联查询  -->        <association property="role" column="role_id" javaType="Role" resultMap="RoleResult"/></resultMap><resultMap type="Role" id="RoleResult">        <id property="roleId" column="role_id"/>        <result property="roleName" column="role_name"/></resultMap>
<select id="" parameterType="" resultMap="">    select a.*,u.role_id,r.role_name from xxxx a    left join user u on a.user_id = u.user_id    left join role r on r.role_id = u.role_id </select>

二、使用jeesite中的@Table注解

@Table(name="Test", alias="a", label="测试表", columns={        @Column(name="testid", attrName="testid", label="测试ID", isPK=true),        @Column(name="userid", attrName="userid", label="用户id"),        @Column(includeEntity=DataEntity.class),}, joinTable = {        @JoinTable(type= JoinTable.Type.LEFT_JOIN,entity = User.class, alias = "c",                on = "c.user_id = a.user_id", attrName="user",columns = {                @Column(name = "user_name",attrName="username", label="用户名"),                @Column(name = "role_id",attrName="roleId", label="角色id"),        }),        @JoinTable(type= JoinTable.Type.LEFT_JOIN,entity = Role.class, alias = "d",                on = "d.role_id = c.role_id", attrName="role",columns = {                @Column(name = "role_name",attrName="rolename", label="角色名称"),        }),},        orderBy="a.update_date DESC")public class Utest extends DataEntity<Utest> {    private static final long serialVersionUID = 1L;    private User user;    private Role role;    private String testid;        // 构件ID}

省略get、set方法,在使用的时候直接调用jeesite的finList、findPage等查询方法进行使用了数据结构就自己debug一下吧

补充:下面介绍下jeesite复杂查询语句实现

在一开始用jeesite进行开发的时候,偶尔会碰到许多问题,解决方式一般也有很多方法

一、多表查询的时候,怎么添加子表的条件进行查询?

举例:有一个文件信息表file,关联了用户表user,存储了一个user_id,需要根据用户姓名进行模糊查询

方法1:前端用beetl进行控件值绑定的时候path按 对象名.变量名 进行绑定,值得注意的是记得在User类的userName字段的注解上加上查询条件为like:queryType=QueryType.LIKE

<#fORM:input path="user.userName"class="form-control width-120" />

方法2:在后台代码中进行手动赋值,file实体类中增加userName变量,在后台接收到userName参数以后调用方法

file.getsqlMap().getWhere().and("c.user_name", QueryType.LIKE,"张");

关于“MyBatis和jeesite多表查询的方法”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“MyBatis和jeesite多表查询的方法”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网精选频道。

--结束END--

本文标题: MyBatis和jeesite多表查询的方法

本文链接: https://lsjlt.com/news/327226.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MyBatis和jeesite多表查询的方法
    这篇文章主要介绍了MyBatis和jeesite多表查询的方法的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇MyBatis和jeesite多表查询的方法文章都会有所收获,下面我们一起来看看吧。有时候经常碰到多级...
    99+
    2023-06-30
  • MyBatis 和 jeesite多表查询示例详解
    有时候经常碰到多级联查,比如通过某个功能A表查角色信息,但是A表和角色表没有直接的关联关系,需要通过用户表进行关联,所以就需要多级关联查询出来了(下面的只是举例,实际应用用户和角色不...
    99+
    2024-04-02
  • MyBatis-Plus多表联查的实现方法(动态查询和静态查询)
    目录建库建表依赖配置代码测试1.静态查询2.动态查询 1.不传条件2.传条件建库建表 DROP DATABASE IF EXISTS mp; CREATE DATA...
    99+
    2024-04-02
  • Mybatis-plus多表查询
    如题有一个用户表,有一个订单表,此时你想查询用户的时候把他附属的订单也查到 一对多 user pojo package com.suse.entity;import com.baomidou.myba...
    99+
    2023-09-09
    mybatis java mysql
  • MyBatis 多表联合查询及优化方法
    目录背景正文关于优化这篇文章我打算来简单的谈谈 mybatis 的多表联合查询。起初是觉得挺简单的,没必要拿出来写,毕竟 mybatis 这东西现在是个开发的都会用,而且网上的文章也...
    99+
    2022-11-13
    MyBatis 多表联合查询 MyBatis 多表查询
  • mybatis多表查询的实现(xml方式)
    目录前言数据库表及关系一对多查询多对一及一对一查询总结前言 表之间的关系有几种:一对多、多对一、 一对一、多对多在多对一关系中,把多的部分拆成一个一个对象其实就是一对一关系,如账户和...
    99+
    2024-04-02
  • MyBatis多表查询和注解开发
    文章目录 Mybatis多表查询一对一查询一对一查询的模型一对一查询的语句创建Order和User实体创建OrderMapper接口配置OrderMapper.xml测试结果 一对多查询一对多查询的模型一对多查询的语句修改Us...
    99+
    2023-08-19
    mybatis java mysql 原力计划
  • MyBatis 多表关联查询
    ✅作者简介:2022年博客新星 第八。热爱国学的Java后端开发者,修心和技术同步精进。 🍎个人主页:Java Fans的博客 🍊个人信条:不迁怒,不贰过。小知识...
    99+
    2023-09-01
    mybatis java mysql
  • MyBatis Plus多表联查方法
    MyBatis Plus是一款针对MyBatis框架的增强工具, 它提供了很多方便的方法来实现多表联查. 你可以使用MyBatis Plus的selectPage方法来实现多表联查, 该方法接收一个QueryWrapper参数, 你可...
    99+
    2023-09-02
    mybatis java mysql maven spring
  • Java MyBatis 多表查询详解
    目录多表查询:一对一:一对多:多对多: 总结多表查询: 学生表、班级表、课程表、班级课程表     一对一:  一个学...
    99+
    2024-04-02
  • MySQL的连接方式和多表查询方法
    本篇内容主要讲解“MySQL的连接方式和多表查询方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL的连接方式和多表查询方法”吧!目录MySQL 内连接、左连接、右连接、外连接、多表查询...
    99+
    2023-06-20
  • Mybatis多对一查询的实现方法
    目录架构环境搭建数据库实体类接口Mapper配置文件子查询方法按结果集查询架构 这里从学生的角度来说就是多对一的场景 那么在Java中是怎么样的呢? 环境搭建 数据库 CREATE...
    99+
    2024-04-02
  • MyBatis多表操作查询功能
    一对一查询 用户表和订单表的关系为,一个用户多个订单,一个订单只从属一个用户 一对一查询的需求:查询一个订单,与此同时查询出该订单所属的用户 在只查询order表的时候,也要查询u...
    99+
    2024-04-02
  • mybatis collection 多条件查询的实现方法
    mybatis collection 多条件查询的实现方法 前言: 业务需要通过mybatis 查询返回嵌套集合,嫌多次查询太麻烦,用自带的高级查询解决问题,下边是代码,已测试通过。 说下自己的理解,就是一...
    99+
    2024-04-02
  • mysql的多表查询实现方法
    本篇文章给大家分享的是有关mysql的多表查询实现方法,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。多表查询有3种方式,分别是:1、传统方式,...
    99+
    2024-04-02
  • mysql多表联合的查询方法
    本文主要给大家介绍mysql多表联合的查询方法,文章内容都是笔者用心摘选和编辑的,具有一定的针对性,对大家的参考意义还是比较大的,下面跟笔者一起了解下mysql多表联合的查询方法吧。   ...
    99+
    2024-04-02
  • MySQL进行多表查询的方法
    这篇文章主要介绍了MySQL进行多表查询的方法,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。一、使用SELECT子句进行多表查询SELE...
    99+
    2024-04-02
  • navicat进行多表查询的方法
    小编给大家分享一下navicat进行多表查询的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!笛卡尔积多表查询,表名之间用逗号...
    99+
    2024-04-02
  • mybatis多个参数查询的方法是什么
    在MyBatis中,可以使用@Param注解或者Map对象来传递多个参数进行查询。下面分别介绍这两种方法: 使用@Param注解:...
    99+
    2024-03-12
    mybatis
  • MyBatis-Plus实现连表查询的方法实例
    目录使用方法安装使用核心类MPJLambdaWrapper和MPJQueryWrapperMPJLambdaWrapper用法MPJQueryWrapper总结mybatis-plu...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作