mysql多对多查询 原生写法
准备工作,1.创建表
CREATE TABLE IF NOT EXISTS `users` (
`id` INTEGER NOT NULL AUTO_INCREMENT,
`name` VARCHAR() NOT NULL,
PRIMARY KEY (`id`)
) ENGINE = InnoDB CHARSET = utf8mb4; CREATE TABLE IF NOT EXISTS `applications` (
`id` INTEGER NOT NULL AUTO_INCREMENT,
`systemName` VARCHAR() NOT NULL,
PRIMARY KEY (`id`)
) ENGINE = InnoDB CHARSET = utf8mb4; CREATE TABLE IF NOT EXISTS `user_application` (
`id` INTEGER NOT NULL AUTO_INCREMENT,
`applicationId` INTEGER NOT NULL,
`userId` INTEGER NOT NULL,
`type` TINYINT,
UNIQUE `user_application_applicationId_userId_unique` (`applicationId`, `userId`),
PRIMARY KEY (`id`)
) ENGINE = InnoDB CHARSET = utf8mb4;
2.创建数据
INSERT INTO `users` (`name`) VALUES ('张三'),('李四'),('老王'),('小明'),('涛哥');
INSERT INTO `applications` (`systemName`) VALUES ('mac'),('windows'),('linux'),('android'),('qilin');
INSERT INTO `user_application` (`applicationId`,`userId`,`type`) VALUES (,,),(,,),(,,),(,,),(,,);
3.使用多对多 关联查询... 一个用户可以有多个应用,一个应用对应多个用户
查询“张三”下应用:
SELECT users.id, users.name, user_application.type, applications.systemName
FROM users
LEFT JOIN (user_application `user_application`
INNER JOIN applications `applications` ON user_application.applicationId = applications.id) ON users.id = user_application.userId
WHERE users.name = '张三'
查询“windows”下用户:
SELECT applications.systemName, users.name, user_application.type
FROM applications
LEFT JOIN (user_application `user_application`
INNER JOIN users `users` ON user_application.userId = users.id) ON applications.id = user_application.applicationId
WHERE applications.systemName = 'windows'
mysql多对多查询 原生写法的更多相关文章
- Entity Framework 多对多查询的写法
同学们,看下面的代码段就明白了: 一对多: public ICollection<ReportLookup> GetReportLookup(IEnumerable<Guid> ...
- MYSQL随机抽取查询 MySQL Order By Rand()效率问题
MYSQL随机抽取查询:MySQL Order By Rand()效率问题一直是开发人员的常见问题,俺们不是DBA,没有那么牛B,所只能慢慢研究咯,最近由于项目问题,需要大概研究了一下MYSQL的随机 ...
- mysql笔记03 查询性能优化
查询性能优化 1. 为什么查询速度会慢? 1). 如果把查询看作是一个任务,那么它由一系列子任务组成,每个子任务都会消耗一定的时间.如果要优化查询,实际上要优化其子任务,要么消除其中一些子任务,要么减 ...
- MySQL多表查询之外键、表连接、子查询、索引
MySQL多表查询之外键.表连接.子查询.索引 一.外键: 1.什么是外键 2.外键语法 3.外键的条件 4.添加外键 5.删除外键 1.什么是外键: 主键:是唯一标识一条记录,不能有重复的,不允许为 ...
- mybatis(一、原理,一对多,多对一查询)
MyBatis框架及原理分析 MyBatis 是支持定制化 SQL.存储过程以及高级映射的优秀的持久层框架,其主要就完成2件事情: 封装JDBC操作 利用反射打通Java类与SQL语句之间的相互转换 ...
- mybatis结合mysql批量操作及查询sql
MySQL数据库 批量操作主要使用的是Mybatis的foreach,遍历参数列表执行相应的操作,所以批量插入/更新/删除的写法是类似的,只是SQL略有区别而已.MySql批量操作需要数据库连接配置a ...
- MyBatis多对多查询
-------------------siwuxie095 MyBatis 多对多查询 以订单和商品为例,即 一个订单可 ...
- MySQL多表查询回顾
----------------------siwuxie095 MySQL 多表查询回顾 以客户和联系人为例(一对多) 1.内连接 /*内连接写法一*/ select * from t_custom ...
- 基于对象的跨表查询,多对多查询,多对多操作,聚合查询和分组查询,F查询和Q 查询
基于对象的跨表查询 一对多查询(班级表和学生表) 表结构创建 class Class(models.Model): id = models.AutoField(primary_key=True) cn ...
随机推荐
- npm发布包
一.发布一个新包第一步:进入要发布的项目根目录,初始化为npm包: npm init 依次按提示填入包名.版本.描述.github地址.关键字.license等 这步完成之后会生成一个package. ...
- tensorflow 中 inter_op 和 intra_op
[root@localhost custom-resnet-v2]# cat runme.sh #python demo_slim.py -h #python demo_slim.py --cpu_n ...
- AtCoder Regular Contest 092 Two Sequences AtCoder - 3943 (二进制+二分)
Problem Statement You are given two integer sequences, each of length N: a1,…,aN and b1,…,bN. There ...
- 计蒜客 蓝桥模拟 G. 数列求值
递归式移项得Ai+1 = 2Ai + 2Ci - Ai-1; 1.A2 = 2A1 + 2C1 - A0; 2.A3 = 2A2 + 2C2 - A1; . . . n.An+1 = 2An + 2C ...
- case_match
//箭头符号 => 隔开了模式和表达式.//选择器 match {备选项}.//只要发现有一个匹配的case,剩下的case不会继续匹配. //object case_test {//// de ...
- L5 Swagger 使用说明
网上看了看,关于这个扩展介绍很少.今天工作恰好用到,研究了一下,觉得有必要分享一下. 一. 简介: 这个包是Swagger-php和Swagger-ui的封装,适用于Laravel5. 二.版本要求 ...
- 安装php-solr扩展
本人qq群也有许多的技术文档,希望可以为你提供一些帮助(非技术的勿加). QQ群: 281442983 (点击链接加入群:http://jq.qq.com/?_wv=1027&k=29Lo ...
- postman(三):详解postman动态变量使用
参考: Variables Dynamic variables
- bzoj4025 二分图 LCT + 最小生成树
题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=4025 题解 貌似这道题有一个非常简单的做法是线段树分治+并查集. 可是我是为了练 LCT 来做 ...
- Kali Linux的发展史,专为数字取证和渗透测试而设计
Kali Linux拥有非常强大的网络功能,Kali Linux是一个Debian衍生的Linux发行版,专为数字取证和渗透测试而设计.它是由OffensiveSecurityLtd维护和资助,是由M ...