在sql查询中,我们经常需要用到条件查询,然而where的效率没有join的高,连接查询非为外连接和内连接,外连接又分为左外连接和又外连接。
开始之前,我们先建几张表
CREATE TABLE `stu` (
`id` int(11) NOT NULL auto_increment,
`stunum` varchar(15) default NULL,
`stuname` varchar(20) default NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=7 ;
CREATE TABLE `teacher` (
`id` tinyint(4) NOT NULL auto_increment,
`name` varchar(20) default NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=4 ;
CREATE TABLE `course` (
`id` tinyint(4) NOT NULL auto_increment,
`name` varchar(20) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=3 ;
CREATE TABLE `courseteacher` (
`id` int(11) NOT NULL auto_increment,
`courseid` int(11) default NULL,
`teacherid` int(11) default NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=3 ;
CREATE TABLE `score` (
`id` int(11) NOT NULL auto_increment,
`stuid` int(11) default NULL,
`courseid` int(1) default NULL,
`score` tinyint(4) default NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=8 ;
这是创建表的sql语句,可以自己试着往里面添加一些测是的值,左外连接就是除了返回满足条件的记录以外还会返回所有左表中的记录,右外连接是除了返回满足条件的记录还要返回右表中的全部记录,比如select stu.stuname,score.score from stu left outer join score on stu.id=score.stuid;和select stu.stuname,score.score from score right outer join stu on stu.id=score.stuid;返回的结果是一样的。
注:我事先已经在数据库里写入的相应的值。必须现在我们有一个需求是我们需要查询所有修名字为math的这门学科的学生的成绩和学生的姓名和学号以及这门课的任课教师的名字,只用一条sql语句完成。select stu.stuname,stu.stunum,score.score,course.name,teacher.name from stu join score on stu.id=score.stuid join course on score.courseid = course.id join courseteacher on course.id=courseteacher.courseid join teacher on courseteacher.teacherid = teacher.id where course.name='math';