
首先,由上图创建表
-  mysql> create table worker(
-  -> dept_id int(11) not null,
-  -> emp_id int (11) not null,
-  -> work_time date not null,
-  -> salary float(8,2) not null,
-  -> poli_face varchar(10) not null default '群众',
-  -> name varchar(20) not null,
-  -> birth date not null,
-  -> primary key(emp_id)
-  -> )engine=innodb default charset=utf8 row_format=dynamic;
-  Query OK, 0 rows affected, 4 warnings (0.03 sec)
然后,向表内插入数据
-  mysql> insert into worker values(101,1001,'2015-5-4', 3500.00,'群众','张三','1990-7-1');
-  Query OK, 1 row affected (0.00 sec)
-  mysql> insert into worker values(101,1002,'2017-2-6', 3200.00,'团员','李四','1990-2-8');
-  Query OK, 1 row affected (0.01 sec)
-  mysql> insert into worker values(102,1003,'2011-2-4',8500.00,'党员','王亮','1983-6-8');
-  Query OK, 1 row affected (0.01 sec)
-  mysql> insert into worker values(102,1004,'2016-10-10',5500.00,'群众','赵六','1994-9-5');
-  Query OK, 1 row affected (0.00 sec)
-  mysql> insert into worker values(102,1005,'2014-4-1',4800.00,'党员','钱七','1992-12-30');
-  Query OK, 1 row affected (0.00 sec)
-  mysql> insert into worker values(102,1006,'2017-5-5',4500.00,'党员','孙八','1996-9-2');
-  Query OK, 1 row affected (0.00 sec)

1,显示所有职工的基本信息

2,查询所有职工所属部门的部门号,不显示重复的部门号

3,求出所有职工的人数

4,列入最高工和最低工资

5,列入职工的平均工资和总工资

6,创建一个只有职工号,姓名和参加工作的新表,名为工作日期表
-  mysql> create table workdate select emp_id,name from worker;
-  Query OK, 6 rows affected (0.02 sec)
-  Records: 6 Duplicates: 0 Warnings: 0
-  mysql> select *from workdate;
-  +--------+--------+
-  | emp_id | name |
-  +--------+--------+
-  | 1001 | 张三 |
-  | 1002 | 李四 |
-  | 1003 | 王亮 |
-  | 1004 | 赵六 |
-  | 1005 | 钱七 |
-  | 1006 | 孙八 |
-  +--------+--------+
-  6 rows in set (0.00 sec)

7,显示所有女职工的年龄(要给表中增加性别和年龄,然后给每人插入年龄和性别)
-  mysql> alter table worker add age tinyint default 18;
-  Query OK, 0 rows affected (0.03 sec)
-  Records: 0 Duplicates: 0 Warnings: 0
-  mysql> alter table worker add gender char(1) check(gender in ('F','M'));
-  Query OK, 6 rows affected (0.04 sec)
-  Records: 6 Duplicates: 0 Warnings: 0
-  mysql> update worker set age=19,gender='F' where name='张三';
-  Query OK, 1 row affected (0.01 sec)
-  Rows matched: 1 Changed: 1 Warnings: 0
-  mysql> update worker set age=20,gender='F' where name='李四';
-  Query OK, 1 row affected (0.00 sec)
-  Rows matched: 1 Changed: 1 Warnings: 0
-  mysql> update worker set age=21,gender='M' where name='王亮';
-  Query OK, 1 row affected (0.00 sec)
-  Rows matched: 1 Changed: 1 Warnings: 0
-  mysql> update worker set gender='M' where name='赵六';
-  Query OK, 1 row affected (0.00 sec)
-  Rows matched: 1 Changed: 1 Warnings: 0
-  mysql> update worker set gender='M' where name='钱七';
-  Query OK, 1 row affected (0.01 sec)
-  Rows matched: 1 Changed: 1 Warnings: 0
-  mysql> update worker set gender='M' where name='孙八';
-  Query OK, 1 row affected (0.00 sec)
-  Rows matched: 1 Changed: 1 Warnings: 0

查看表内容

最后差询女职工的年龄

8,列出所有姓刘的职工的职工号,姓名和出生日期

9,列出1960年以前出生的职工的姓名,参加工作日期

Empty set (0.00 sec)  没有符合条件的职工,所以为空
10,列出工资在1000-2000之间的所有职工姓名

11,列出所有姓陈和姓李的职工姓名

12,列出所有部门号为2和3的职工号,姓名,党员

13,将职工表worker中的职工按先后顺序排序

14,显示工资最高的前3名职工的职工号和姓名

15,求出个部门党员的人数

16,统计个部门的工资和平均工资
 
17,统计总人数大于4的部门号和总人数
