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;