时间:2021-07-01 10:21:17 帮助过:2人阅读

一对多:在多方需要添加一个字段,并且和一方主键的类型必须是相同的。
建表原则(都是在多方表中维护):
画图举例部门与员工的关系 

在生活中一个学生可以选择多门课程,每一门课程也可以被多个学生所选择。这些例子在数据库设计中可以使用多对多来完成。
建表原则:
外键指向两个多对多关系表的主键。 
主键对应 唯一外键对应 

笛卡尔积的概念:(了解) 

查询的语法 
select * from 表A,表B;    返回的结果就是笛卡尔积。
多表查询时,如果不指定表之间的连接条件,则连接变成笛卡尔乘积操作,笛卡尔积的效果如本页所示。
进行笛卡尔积后,查询结果中存在大量无意义的数据,示例中只有A表中的A_ID和B表中A_ID一致的行才有意义,这样我们通过加上WHERE过滤条件得到想要的数据。这种横跨多表的查询操作一般用连接完成。
如果一张表的记录为m,另一张表的记录是n,两个表做交叉连接后,查询结果的数量为m*n条。

左外链接(看左表,把左表所有的数据全部查询出来)
右外链接(看右表,把右表所有的数据全部查询出来)
外链接与内连接的关系

嵌套查询,也称为子查询。外层的查询块称为父查询,内层的查询块称为子查询。
语法:select * from table where 条件 > (select * from table where 条件)
>any 大于结果的最小值>all 大于结果的最大值create table dept(
    did int primary key auto_increment,
    dname varchar(30)
);
create table emp(
    eid int primary key auto_increment,
    ename varchar(20),
    salaly double,
    dno int
);
//查看所有人所属的部门名称和员工名称?
    //方法一:
    select dept.dname,emp.ename from dept,emp where dept.did = emp.dno;
    //方法二:
    select d.dname,e.ename from dept d,emp e where d.did = e.dno;
//统计每个部门的人数(按照部门名称统计,分组group by  count)
    select d.dname,count(*) from dept d,emp e where d.did = e.dno group by d.dname;
//统计部门的平均工资(按部门名称统计 ,分组group by  avg)
    select d.dname,avg(salaly) from dept d,emp e where d.did = e.dno group by d.dname;
//统计部门的平均工资大于公司平均工资的部门(子查询)
    * 公司的平均工资
        select avg(salaly) from emp;
    * 部门的平均工资
        select d.dname,avg(e.salaly) as sa from dept d,emp e where d.did = e.dno group by d.dname having sa > (select avg(salaly) from emp);DROP TABLE dept;
--部门表
CREATE TABLE dept(
    deptno int  PRIMARY KEY,
    dname VARCHAR(14) , --部门名称
    loc VARCHAR(13)  ---部门地址
    ) ;
CREATE TABLE dept(
    deptno int  PRIMARY KEY,
    dname VARCHAR(14) , 
    loc VARCHAR(13) 
    ) ;
    INSERT INTO DEPT VALUES (10,‘ACCOUNTING‘,‘NEW YORK‘);
    INSERT INTO DEPT VALUES (20,‘RESEARCH‘,‘DALLAS‘);
    INSERT INTO DEPT VALUES (30,‘SALES‘,‘CHICAGO‘);
    INSERT INTO DEPT VALUES (40,‘OPERATIONS‘,‘BOSTON‘);
drop table emp;
--员工表
CREATE TABLE emp(
    empno int  PRIMARY KEY, --员工编号
    ename VARCHAR(10), ---员工姓名
    job VARCHAR(9), --员工工作
    mgr int, ----员工直属领导编号
    hiredate DATE, ----入职时间
    sal double, ---工资
    comm double, --奖金
    deptno int  REFERENCES dept);  --关联dept表
CREATE TABLE emp(
    empno int  PRIMARY KEY,
    ename VARCHAR(10),
    job VARCHAR(9),
    mgr int, 
    hiredate DATE, 
    sal double,
    comm double,
    deptno int ,
    foreign key emp(deptno) REFERENCES dept(deptno)
);  
INSERT INTO EMP VALUES(7369,‘SMITH‘,‘CLERK‘,7902,"1980-12-17",800,NULL,20);
INSERT INTO EMP VALUES(7499,‘ALLEN‘,‘SALESMAN‘,7698,‘1981-02-20‘,1600,300,30);
INSERT INTO EMP VALUES(7521,‘WARD‘,‘SALESMAN‘,7698,‘1981-02-22‘,1250,500,30);
INSERT INTO EMP VALUES(7566,‘JONES‘,‘MANAGER‘,7839,‘1981-04-02‘,2975,NULL,20);
INSERT INTO EMP VALUES(7654,‘MARTIN‘,‘SALESMAN‘,7698,‘1981-09-28‘,1250,1400,30);
INSERT INTO EMP VALUES(7698,‘BLAKE‘,‘MANAGER‘,7839,‘1981-05-01‘,2850,NULL,30);
INSERT INTO EMP VALUES(7782,‘CLARK‘,‘MANAGER‘,7839,‘1981-06-09‘,2450,NULL,10);
INSERT INTO EMP VALUES(7788,‘SCOTT‘,‘ANALYST‘,7566,‘1987-07-03‘,3000,NULL,20);
INSERT INTO EMP VALUES(7839,‘KING‘,‘PRESIDENT‘,NULL,‘1981-11-17‘,5000,NULL,10);
INSERT INTO EMP VALUES(7844,‘TURNER‘,‘SALESMAN‘,7698,‘1981-09-08‘,1500,0,30);
INSERT INTO EMP VALUES(7876,‘ADAMS‘,‘CLERK‘,7788,‘1987-07-13‘,1100,NULL,20);
INSERT INTO EMP VALUES(7900,‘JAMES‘,‘CLERK‘,7698,‘1981-12-03‘,950,NULL,30);
INSERT INTO EMP VALUES(7902,‘FORD‘,‘ANALYST‘,7566,‘1981-12-03‘,3000,NULL,20);
INSERT INTO EMP VALUES(7934,‘MILLER‘,‘CLERK‘,7782,‘1981-01-23‘,1300,NULL,10);
CREATE TABLE salgrade( 
    grade int,--等级
    losal double, --最低工资
    hisal double ); --最高工次
CREATE TABLE salgrade( 
    grade int,
    losal double, 
    hisal double );
INSERT INTO SALGRADE VALUES (1,700,1200);
INSERT INTO SALGRADE VALUES (2,1201,1400);
INSERT INTO SALGRADE VALUES (3,1401,2000);
INSERT INTO SALGRADE VALUES (4,2001,3000);
INSERT INTO SALGRADE VALUES (5,3001,9999);1、返回拥有员工的部门名、部门号。
2、工资水平多于smith的员工信息。
3、返回员工和所属经理的姓名。
4、返回雇员的雇佣日期早于其经理雇佣日期的员工及其经理姓名。
5、返回员工姓名及其所在的部门名称。
6、返回从事clerk工作的员工姓名和所在部门名称。
7、返回部门号及其本部门的最低工资。
8、返回销售部(sales)所有员工的姓名。
9、返回工资水平多于平均工资的员工。
10、返回与SCOTT从事相同工作的员工。
11、返回与30部门员工工资水平相同的员工姓名与工资。
MySQL快速入门(二)——Java进阶学习第十六天
标签: