09—mybatis注解配置join查询
今天来聊mybatis的join查询,怎么说呢,有的时候,join查询确实能提升查询效率,今天举个left join的例子,来看看mybatis的join查询。
就不写的很细了,把主要代码贴出来了。
创建数据表:admin_user、admin_groups
CREATE TABLE `admin_user` (
`id` bigint() NOT NULL AUTO_INCREMENT COMMENT '用户编号',
`user_name` varchar() NOT NULL COMMENT '用户登录账号',
`pwd` varchar() DEFAULT NULL COMMENT '登录密码',
`create_date` datetime DEFAULT NULL COMMENT '创建时间',
`enable_flag` int() DEFAULT NULL COMMENT '用户状态 0:可用 1:不可用',
`group_id` int() DEFAULT NULL COMMENT '分组ID,0超级管理员,1一般管理员',
`last_login_ip` varchar() DEFAULT NULL COMMENT '最后一次登录IP地址',
`last_login_time` datetime DEFAULT NULL COMMENT '最后登录时间',
`login_count` int() DEFAULT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `user_name` (`user_name`) USING BTREE
) ---------------------------------------------------------------------------------
CREATE TABLE `admin_groups` (
`id` int() NOT NULL AUTO_INCREMENT,
`group_name` varchar() DEFAULT NULL,
`create_by_user_name` varchar() DEFAULT NULL,
`create_time` datetime DEFAULT NULL,
`update_time` datetime DEFAULT NULL,
`parent_id` int() DEFAULT NULL,
`remarks` varchar() NOT NULL DEFAULT '无' COMMENT '描述',
`enable_flag` int() NOT NULL DEFAULT '',
PRIMARY KEY (`id`)
)
创建实体类:AdminUserJoinGroups.java
package com.palmble.entity;
import lombok.Data;
import javax.persistence.Table; @Table(name = "admin_user")
@Data
public class AdminUserJoinGroups {
private Long id;
private String userName;
private String groupName;
private String createByUserName;
}
service层:AdminUserService.java
@Service
public class AdminUserService { @Autowired
private AdminUserMapper adminUserMapper;
public List<AdminUserJoinGroups> selectAllList()
{
return adminUserMapper.selectAllList();
}
}
mapper层:AdminUserMapper.java
@Mapper
public interface AdminUserMapper { @Select(" SELECT u.id,user_name,g.group_name,g.create_by_user_name FROM admin_user u left join admin_groups g on u.group_id=g.id;")
@Results(id = "userGroupMap", value = {
@Result(id = true, column = "id", property = "id"),
@Result(column = "user_name", property = "userName"),
@Result(column = "group_name", property = "groupName"),
@Result(column = "create_by_user_name", property = "createByUserName")
})
List<AdminUserJoinGroups> selectAllList();
}
测试:
@RestController
@RequestMapping("/admin")
public class AdminController {
@Autowired
private AdminUserService adminUserService; @RequestMapping("/getUserGroup")
public String getUserGroup() {
List<AdminUserJoinGroups> adminUserJoinGroups = adminUserService.selectAllList();
StringBuilder sb = new StringBuilder();
for (AdminUserJoinGroups item : adminUserJoinGroups) {
sb.append("id=" + item.getId() + ",username=" + item.getUserName() + ",groupname=" + item.getGroupName() + ",createByUserName=" + item.getCreateByUserName());
}
return sb.toString();
}

09—mybatis注解配置join查询的更多相关文章
- Mybatis注解开发模糊查询
Mybatis注解开发模糊查询 一般在使用mybatis时都是采用xml文件保存sql语句 这篇文章讲一下在使用mybatis的注解开发时,如何进行模糊查询 模糊查询语句写法(在@Select注解中) ...
- MyBatis 注解配置及动态SQL
一.注解配置 目前MyBatis支持注解配置,用注解方式来替代映射文件,但是注解配置还是有点不完善,在开发中使用比较少,大部分的企业还是在用映射文件来进行配置.不完善的地方体现在于当数据表中的字段 ...
- 阶段3 1.Mybatis_03.自定义Mybatis框架_7.自定义Mybatis的编码-实现基于注解配置的查询所有
注解的方式,这里进行修改.上面注释的是原来xml的方式. 在dao类里面加上注解 创建注解类 声明注解的生命周期为Runntime 改变注解出现的位置,在Mehtod方法上 写完之后这里就不报错了. ...
- 08—mybatis注解配置二
动态sql mybatis的注解也支持动态sql.mybatis提供了各种注解,如@InsertProvider.@UpdateProvider.@DeleteProvider和@SelectProv ...
- Spring Boot中使用MyBatis注解配置详解(1)
之前在Spring Boot中整合MyBatis时,采用了注解的配置方式,相信很多人还是比较喜欢这种优雅的方式的,也收到不少读者朋友的反馈和问题,主要集中于针对各种场景下注解如何使用,下面就对几种常见 ...
- Spring Boot中使用MyBatis注解配置详解
传参方式 下面通过几种不同传参方式来实现前文中实现的插入操作. 使用@Param 在之前的整合示例中我们已经使用了这种最简单的传参方式,如下: @Insert("INSERT INTO US ...
- 07—mybatis注解配置一
常用注解Select:映射查询的sql语句.SelectProvider:Select语句的动态sql映射.允许指定一个类名和一个方法在执行时返回运行的查询语句.有两个属性:type和mehtod,t ...
- Spring Boot教程(三十九)使用MyBatis注解配置详解(2)
增删改查 MyBatis针对不同的数据库操作分别提供了不同的注解来进行配置,在之前的示例中演示了@Insert,下面针对User表做一组最基本的增删改查作为示例: public interface U ...
- Spring Boot教程(三十八)使用MyBatis注解配置详解(1)
之前在Spring Boot中整合MyBatis时,采用了注解的配置方式,相信很多人还是比较喜欢这种优雅的方式的,也收到不少读者朋友的反馈和问题,主要集中于针对各种场景下注解如何使用,下面就对几种常见 ...
随机推荐
- eclipse修改java类时不自动重启
只有添加修改方法参数等重启 在方法里修改不重启 最后保存,Ctrl+S
- 用ExtentReports美化你的测试报告
前言 在实际的自动化测试工作中经常会用到一些报告生成工具大概分为两类,一类是测试框架自带的报告生成工具如:JUnit+Ant.TestNG:另一类就是专用报告工具如ReportNG等.这些报告要么在U ...
- ora00972标识符过长
oracle10G对于表名的长度限制是30个字节 表名超过30结果不能创建,提示ora00972-标识符过长. 需要将表名控制在30个字节以内
- Thinking In Java 4th Chap7 复用类
复用代码的两种方法:组合和继承 组合方法:(新类中产生现有类的对象) 没什么好说的,就是调用别类的对象而已 值得一提的是一个特殊方法:toString()当需要一个String却只有对象时能够自动调用 ...
- WUSTOJ 1285: Factors(Java)
1285: Factors 参考 hadis_fukan的博客--wustoj 1285 Factors 题目 输入一个数n,找出1~n之间(包括1,n)的质因子最多的数(x)的质因子个数(f ...
- 使用寄存器点亮LED(第1节)—GPIO功能框图讲解
GPIO简介 GPIO 是通用输入输出端口的简称,简单来说就是 STM32 可控制的引脚, STM32 芯片的 GPIO 引脚与外部设备连接起来,从而实现与外部通讯.控制以及数据采集的功能.STM32 ...
- Eureka常见问题
一 Eureka注册慢问题默认情况下,服务注册到Eureka Server过程较慢.在开发或测试时,常常希望加速这一过程,从而提高工作效率.服务注册涉及到周期性心跳,默认30秒一次.只有当实例.服务端 ...
- prometheus+grafana+Alertmanager邮箱告警
环境 系统:CentOS 7 软件:alertmanager-0.18.0.linux-amd64.tar.gz 安装 下载二进制包 地址:https://prometheus.io/download ...
- (二)如何利用C# Roslyn编译器写一个简单的代码提示/错误检查?
上一篇我们讲了如何建立一个简单的Roslyn分析项目如分析检查我们的代码. 今天我们主要介绍各个项目中具体的作用以及可视化分析工具. 还是这种截图,可以看到解决方案下一共有三个项目. Analyzer ...
- 使用jdk8 stream简化集合操作
使用stream的前提是对lambda表达式和函数式接口有一定的了解,同时对方法引用和普通传参的区别有一定的认识. stream的三大特性:1.不存储数据2.不改变源数据3.延时执行. stream优 ...