MySQL使用教程(基础篇02)
- 1、语法规范
- 2、基础查询
- 2-1查询表中的字段
- 2-1-1查询时的细节补充
- 2-2查询常量_表达式_函数
- 2-3起别名
- 2-4去重
- 2-5 +号的作用
- 3、条件查询
- 3-1介绍
- 3-2条件运算符的使用
- 3-3逻辑运算符的使用
- 3-4模糊查询_like关键字
- 3-5模糊查询_between and
- 3-6模糊查询_in关键字
- 3-7模糊查询_is null关键字
1、语法规范
- 不区分大小写,但是建议关键字大写,表名、列名小写;
- 每条命令最好用分号结尾;
- 每条命令根据需要,可以进行缩进、换行;
- 注释;
单行注释:#注释文字
单行注释:-- 注释文字
多行注释:/*注释文字 */
2、基础查询
语法:select 查询列表 from 表名;
特点:
- (1)查询列表可以是:表中的字段、常量值、表达式、函数;
- (2)查询的结果是一个虚拟的表格
2-1查询表中的字段
示例1:查询表中的单个字段
select last_name from employees;
示例2:查询表中的多个字段
select last_name,salary,email from employees;
示例3:查询表中的所有字段
select * from employees;
2-1-1查询时的细节补充
加着重号:区分是否是关键字还是字段
2-2查询常量_表达式_函数
示例1:查询常量值
select 100;
select 'john';
示例2:查询表达式
select 100%98;
示例3:查询函数
select version();
2-3起别名
特点:
- (1)便于理解;
- (2)如果要查询的字段有重名的情况,使用别名可以区分。
方式一 使用as
select 100%98 as 结果;
select last_name as 姓,first_name as 名 from employees;
方式二 使用空格
2-4去重
- 案例:查询员工表中涉及的所有的部门编号
select distinct department_id from employees;
2-5 +号的作用
+号的作用、使用concat实现链接。
- 案例:查询员工名和姓链接成一个字段,并显示为 姓名
select concat(last_name ,first_name) as 姓名 from employees;
select concat('a','b','c') as 结果;
3、条件查询
3-1介绍
分类:
(1)按条件表达式刷选;条件运算符;
(2)按逻辑表达式刷选;
(3)模糊查询;
3-2条件运算符的使用
- 案例1:查询工资》12000的员工信息
select * from employees where salary>12000;
- 案例2:查询部门编号不等于90的员工名和部门编号
select last_name,department_id from employees where department_id!=90;
3-3逻辑运算符的使用
- 案例1:查询工资在10000到20000之间的员工名、工资和奖金
select last_name,salary,commission_pct from employees where salary>=10000 and salary<=20000;
- 案例2:查询部门编号不是在90到110之间,或者工资高于15000的员工信息
select * from employees
where department_id<90 or department_id>100 or salary>15000;
3-4模糊查询_like关键字
特点:
1)一般和通配符搭配使用;
2)通配符:% 任意多个字符,包含0个字符, _任意单个字符
- 案例1:查询员工名中包含字符a的员工信息
select * from employees where last_name like '%a%';
- 案例2:查询员工名中第三个字符为e,第五个字符为a的员工名和工资
select last_name,salary from employees where last_name like '__n_a%';
3-5模糊查询_between and
特点:
1)使用between and可以提高语句的简洁渡;
2)包含临界值;
3)两个临界值不要调换顺序。
- 案例1 :查询员工编号在100到120之间的员工信息
select * from employees where employee_id>=100 and employee_id<=120;
-- 方式二
select * from employees where employee_id between 100 and 120;
3-6模糊查询_in关键字
特点:
1)使用in提高语句简洁渡;
2)in列表的值类型必须统一或兼容。
- 案例1:查询员工的工种编号是IT_PROT AD_VP AD_PRES中的一个员工名和工种编号
select last_name,job_id from employees where job_id='IT_PROT' or job_id='AD_VP' or job_id='AD_PRES';
-- 方式二
select last_name,job_id from employees where job_id in('IT_PROT','AD_VP','AD_PRES');
3-7模糊查询_is null关键字
特点:
1)is null:=或<>不能用于判断null值
2)is null或is not null可以判断null值
- 案例1:查询没有奖金的员工名和奖金率
select last_name,commission_pct
from employees
where commission_pct is null;