一、 案例表
2.1、部门信息表:dept
列名 |
类型 |
描述 |
DEPTNO |
int(2) |
部门编号;最多由2位数字组成 |
DNAME |
varchar(14) |
部门名称;最多由14个字节组成 |
LOC |
varchar(50) |
部门所在的位置地址;最多由50个字节组成 |
2.2、员工(雇员)信息表:emp(employees)
列名 |
类型 |
描述 |
EMPNO |
int(10) |
员工编号;由4位数字组成 |
ENAME |
VARCHAR(15) |
员工姓名 |
JOB |
VARCHAR(10) |
员工职位 |
MGR |
NUMBER(10) |
员工领导的编号 |
HIREDATE |
DATE |
员工雇佣日期;DATA 包含了日期和时间 |
SAL |
decimal(7,2) |
基本工资;如:99999.99 |
COMM |
decimal(7,2) |
佣金(提成),一般只有销售才有佣金的概念。 |
DEPTNO |
int(2) |
员工所在的部门编号。和 dept表的 DEPTNO对应 |
二 、查询(控制列)
1、简单查询
1.1、语法格式
SELECT [DISTINCT] * | 列名 [AS] [别名] ,列名 [AS] [别名] , 2、 控制要显示的数据列
FROM 表名称 [别名] ; 1、 确定查询的数据来源
1.2、参数说明
1、SELECT 关键字 查询数据
2、FROM 关键字 后面跟数据来源
3、 DISTINCT --表示去掉重复行数据 distinct关键字只能跟在select关键字之后
4、* --查询选择所有的列,count(*)意味着计算所有的行,表示通配符时,表示0个或任意多个字符
5、AS --关键字不能用于指定表的别名,可以用来指定列名的别名,指定列的别名的时候可以省略
1.3、示例代码
- 查询雇员(emp)表的所有数据,即所有行和所有列的数据
SELECT *
FROM emp
- 查询每个雇员(emp)的编号(empno)、姓名(ename)、职位(job)、基本工资(sal)
SELECT empno,ename,job,sal
FROM emp;
- 使用别名方式查询(开发中禁止使用中文别名,看到用中文别名的直接拖出打死)
SELECT empno 编号,ename 姓名,job 职位,sal 薪资
FROM emp;
- 去掉重复数据(DISTINCT)
SELECT job
FROM emp;
SELECT DISTINCT job
FROM emp;
- 表的别名的使用(当多表联查时各表有相同列名时就可以使用别名来特指查询的列)
SELECT e.empno,e.ename,e.deptno
FROM emp e;
2、简单查询(+、-、×、÷)
2.1、说明
- 四则运算可以对数字类型,日期类型,数字类型的字符串进行运算
- 运算符的优先级跟数学的加,减,乘,除一样
2.2 、示例代码
- 查询每个雇员的编号、姓名、基本年薪
SELECT empno,ename,sal*12
FROM emp ;
- 查询每个雇员的编号、姓名、职位、年薪,而且每位雇员,每个月有 300 元的饭食补助、180元的交通补助,年底的时候可以领到 14个月的基本工资
SELECT empno 编号,ename 姓名 ,job 职位,(sal*14 + (300+180)*12) 年薪
FROM emp
网友评论