mysql 关联查询技巧

废话不多说,直接进入正题

#数据准备

班级表class:

CREATE TABLE `class` (
  `class_no` int(2) unsigned zerofill NOT NULL AUTO_INCREMENT COMMENT ‘班级编号‘,
  `class_name` varchar(30) CHARACTER SET utf8 NOT NULL COMMENT ‘班级名称‘,
  PRIMARY KEY (`class_no`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1;
insert into class values(1, ‘培优班‘);
insert into class values(2, ‘普通班‘);
insert into class values(3, ‘提升班‘);

学生表student:

CREATE TABLE `student` (
  `stu_no` int(2) unsigned zerofill NOT NULL AUTO_INCREMENT COMMENT ‘学员编号‘,
  `stu_name` varchar(30) CHARACTER SET utf8 NOT NULL COMMENT ‘学员姓名‘,
  `stu_sex` varchar(3) CHARACTER SET utf8 NOT NULL COMMENT ‘学员性别‘,
  `stu_age` tinyint(2) unsigned zerofill DEFAULT NULL COMMENT ‘学员年代‘,
  `grade` double(5,2) unsigned zerofill DEFAULT NULL COMMENT ‘成绩‘,
  `class_no` int(2) unsigned zerofill DEFAULT NULL COMMENT ‘所在班级编号‘,
  PRIMARY KEY (`stu_no`),
  KEY `class_no` (`class_no`)
) ENGINE=MyISAM AUTO_INCREMENT=11 DEFAULT CHARSET=latin1;

insert into student values(01, ‘李白‘, ‘男‘, 18, 60, 01);
insert into student values(02, ‘杜甫‘, ‘男‘, 20, 76, 01);
insert into student values(03, ‘张飞‘, ‘男‘, 32, 80, 02);
insert into student values(04, ‘韩信‘, ‘男‘, 26, 98, 02);
insert into student values(05, ‘了龙‘, ‘男‘, 27, 56, 02);
insert into student values(06, ‘大乔‘, ‘女‘, 17, 88, 01);
insert into student values(07, ‘小乔‘, ‘女‘, 16, 96, 01);
insert into student values(08, ‘小乔‘, ‘女‘, 16, 90, 01);
insert into student values(09, ‘关哥‘, ‘男‘, 32, 80, 02);
insert into student values(10, ‘刘备‘, ‘男‘, 36, 98, null);

1: exists子查询

如果子查询有返回结果则为true,如果没有返回值则为false

select * from student where exists(select * from student where grade = 80)

比如not exists:

select * from student where not exists(select * from student where grade = 80);

以上结果返回空,因为 not exists 返回了 false

select * from student where exists (select * from class where class.class_no = student.class_no);

上面的查询可以看到,我们少了一条数据,第十条的clas_no 是null。。。所以这条数据是flase....而

class.class_no = student.class_no 为true的,就全部返回了

 2: [union] 并合查询

需求: 拿到01班级的最高成绩 和 02班级的最低成绩

我们一般会这样

select max(grade) from student where class_no = 01;
select min(grade) from student where class_no = 02;

优化这个查询我们可以这样:

(select concat(‘1号班级最高成绩:‘, max(grade)) ‘成绩‘ from student where class_no = 01)
union
(select concat(‘2号班级最低成绩:‘, min(grade)) ‘成绩‘ from student where class_no = 02);

这里再说下union 和union all的区别:

union:

(select class_no, stu_name, stu_age from student where class_no = 1)
union
(select class_no, stu_name, stu_age from student where class_no = 2);

union all:

(select class_no, stu_name, stu_age from student where class_no = 1)
union all
(select class_no, stu_name, stu_age from student where class_no = 2);

通过以上两个查询,我们可以看到:union并合查询它会自动的去重复的记录, 如果不想要去掉重复的记录则可以使用 union all;

我们加个排序:

(select class_no, stu_name, stu_age from student where class_no = 1)
union all
(select class_no, stu_name, stu_age from student where class_no = 2) order by stu_age desc;

连接查询的分类
    1: 内连接
    2: 外连接
    3: 自然连接

1: inner join(内连接)
    需求: 查询出学员的学号, 姓名, 所在的班级名称

select stu_no, stu_name, class_name from student  join class where `student`.class_no = `class`.class_no;

以上sql等同于:

select stu_no, stu_name, class_name from student join class where `student`.class_no = `class`.class_no;
select stu_no,stu_name,class_name from student,class where student.class_no = class.class_no;

内连接的inner字符可以不用写

2: cross join(交叉连接,迪卡尔集) 没有条件的内连接
    例: select * from student cross join class;
    例: select * from student inner join class;
    例: select * from student cross join class where `student`.class_no = `class`.class_no;
    ps: cross join 与 inner join 在使用上没有区分,只是在mysql中把cross join定义成交叉连接而已

就写到这把。。其他的连接方式也简单,资料也很多啦。。。

时间: 2024-10-07 11:47:22

mysql 关联查询技巧的相关文章

mysql关联查询和联合查询

一.内联方式 1.传统关联查询 "select * from students,transcript where students.sid=transcript.sid and transcript.total>600 and transcript.date=2015-6"; 上面是查询出在2015-6月,月考中总成绩超过600的学生信息.where的条件有三个,要看出是哪些是关联条件,哪些是查询过滤还是挺简单,若是多个表多个查询条件那么就不是那么容易了 2.JOIN...ON

[MySQL]多表关联查询技巧

示例表A: author_id author_name 1 Kimmy 2 Abel 3 Bill 4 Berton 示例表B: book_id author_id start_date end_date 9 1 2017-09-25 21:16:04 2017-09-25 21:16:06 10 3     11 2 2017-09-25 21:21:46 2017-09-25 21:21:47 12 1     13 8     示例表C: order_id book_id price or

MySql 关联查询

1.内连接 将两张表中相同意义字段连接起来,返回结果是两个表中都存在的信息: select * from TableA,TableB where TableA.字段c=TableB.字段c; select * from TableA inner join TableB on TableA.字段c=TableB.字段c; TableA.字段c=TableB.字段c是一种过滤条件. 2.左外连接 用第一张表中的每一条记录去匹配第二张表对应的记录,不管能不能匹配到记录,查询结果都显示第一个表的所有内容

MySQL 关联查询 内连接

内连接    [INNER| CROSS] JOIN无条件内连接:无条件内连接,又名交叉连接/笛卡尔连接第一张表种的每一项会和另一张表的每一项依次组合#例:mysql>  select  *  from  student inner join  department;有条件内连接:在无条件的内连接基础上,加上一个ON子句当连接的时候,筛选出那些有实际意义的记录行来进行拼接#例:mysql> select   *  from   student  inner join  department  

mysql关联查询

mysql数据库的统计------生成统计信息 1.distinct:在一组之中将各个唯一的值找出来,如找出所有的品牌种类 mysql>select distinct brand_kind from brand;+---------------+| brand_kind |+---------------+| A                || B                || C                |+---------------+ 2.计数统计,使用count(*),

MySQL 关联查询  外连接 { LEFT| RIGHT } JOIN

左外连接: (以左表为基准)两张表做连接的时候,在连接条件不匹配的时候留下左表中的数据,而右表中的数据以NULL填充例:使用左连接把学生的数据全取出来,该学生没有学院信息的用NULL填充 mysql>  select * from  student  left join  department         ->  on dept_id= d_id; 右外连接: (以右表为基准)对两张表做连接的时候,在连接条件不匹配的时候留下右表中的数据,而左表中的数据以NULL填充例:使用右外连接,把没有

提高MySQL数据库查询效率的几个技巧(转载)

[size=5][color=Red]提高MySQL数据库查询效率的几个技巧(转)[/color][/size]      MySQL由于它本身的小巧和操作的高效, 在数据库应用中越来越多的被采用.我在开发一个P2P应用的时候曾经使用MySQL来保存P2P节点,由于P2P的应用中,结点数动辄上万个,而且节点变化频繁,因此一定要保持查询和插入的高效.以下是我在使用过程中做的提高效率的三个有效的尝试. l 使用statement进行绑定查询 使用statement可以提前构建查询语法树,在查询时不再

MySQL多表关联查询与存储过程

1.多表关联查询 --  **************关联查询(多表查询)**************** -- 需求:查询员工及其所在部门(显示员工姓名,部门名称) -- 1.1 交叉连接查询(不推荐.产生笛卡尔乘积现象:4 * 4=16,有些是重复记录) SELECT empName,deptName FROM employee,dept; -- 需求:查询员工及其所在部门(显示员工姓名,部门名称) -- 多表查询规则:1)确定查询哪些表   2)确定查询哪些字段   3)表与表之间连接条件

[转] hibernate Mysql 自增长 注解配置,表无关联的注解方式关联查询

不同数据库 自增长ID配置 正对不同的数据库可以同时使用         @Id         @GeneratedValue(strategy = GenerationType.AUTO) 2 针对mysql  @Id  @GeneratedValue(strategy = GenerationType.IDENTITY) 3 针对oracle        @Id        @GeneratedValue(strategy = GenerationType.SEQUENCE,gener