运算符,排序分页,多表,约束

启动和关闭服务
启动:

net start mysql

关闭:

net stop mysql

去除重复行

在SELECT语句中使用关键字DISTINCT去除重复行

SELECT DISTINCT department_id salary FROM employees;

DISTINCT 其实是对后面所有列名的组合进行去重
department_id 和 salary的组合

空值参与运算

所有运算符或列值遇到null值,运算的结果都为null

SELECT employee_id,salary,commission_pct,
12 * salary * (1 + commission_pct) "annual_sal"
FROM employees;

在这里插入图片描述

这里你一定要注意,在 MySQL 里面, 空值不等于空字符串。一个空字符串的长度是 0,而一个空值的长
度是空。而且,在 MySQL 里面,空值是占用空间的。

着重号

我们需要保证表中的字段、表名等没有和保留字、数据库系统或常用方法冲突。如果真的相同,请在SQL语句中使用一对``(着重号)引起来。

mysql> SELECT * FROM `order`;

运算符

在这里插入图片描述
注:整数和字符串比较如果字符串转化不出来就转化为0.
<=>: 为null而生
’ '<=>null---->0
null<=>---->1
不等于运算符:
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

  • 回避特殊符号:使用转义字符。
#查询第二个字符是_且第三个字符是'a'的员工信息
SELECT last_name
FROM employees
WHERE last_name LIKE '_\_a%';

在这里插入图片描述

逻辑运算符

在这里插入图片描述

位运算符

在这里插入图片描述

正则表达式

排序与分页

排序

在这里插入图片描述
多列排序:
在这里插入图片描述

分页

LIMIT 起始位置,行数

多表查询

在这里插入图片描述

#查询员工的employee_id,last_name,department_name,city
SELECT e.employee_id,e.last_name,d.department_name,l.city,e.department_id,l.location_id
FROM employees e,departments d,locations l
WHERE e.`department_id` = d.`department_id`
AND d.`location_id` = l.`location_id`;

多表查询分类

等值连接 vs 非等值连接

非等值连接:

SELECT e.last_name,e.salary,j.grade_level
FROM employees e,job_grades j
#where e.`salary` between j.`lowest_sal` and j.`highest_sal`;
WHERE e.`salary` >= j.`lowest_sal` AND e.`salary` <= j.`highest_sal`;

自连接 vs 非自连接

自连接

#自连接的例子:
#练习:查询员工id,员工姓名及其管理者的id和姓名

SELECT emp.employee_id,emp.last_name,mgr.employee_id,mgr.last_name
FROM employees emp ,employees mgr
WHERE emp.`manager_id` = mgr.`employee_id`;

非自连接

内连接 vs 外连接

# 内连接:合并具有同一列的两个以上的表的行, 结果集中不包含一个表与另一个表不匹配的行
SELECT employee_id,department_name
FROM employees e,departments d
WHERE e.`department_id` = d.department_id;  #只有106条记录

# 外连接:合并具有同一列的两个以上的表的行, 结果集中除了包含一个表与另一个表匹配的行之外,
#         还查询到了左表 或 右表中不匹配的行。

# 外连接的分类:左外连接、右外连接、满外连接

# 左外连接:两个表在连接过程中除了返回满足连接条件的行以外还返回左表中不满足条件的行,这种连接称为左外连接。
# 右外连接:两个表在连接过程中除了返回满足连接条件的行以外还返回右表中不满足条件的行,这种连接称为右外连接。

#练习:查询所有的员工的last_name,department_name信息 

SELECT employee_id,department_name
FROM employees e,departments d
WHERE e.`department_id` = d.department_id;   # 需要使用左外连接

#SQL99语法中使用 JOIN ...ON 的方式实现多表的查询。这种方式也能解决外连接的问题。MySQL是支持此种方式的。
#SQL99语法如何实现多表的查询。

#SQL99语法实现内连接:
SELECT last_name,department_name
FROM employees e INNER JOIN departments d
ON e.`department_id` = d.`department_id`;

SELECT last_name,department_name,city
FROM employees e JOIN departments d
ON e.`department_id` = d.`department_id`
JOIN locations l
ON d.`location_id` = l.`location_id`;

#SQL99语法实现外连接:

#练习:查询所有的员工的last_name,department_name信息 
# 左外连接:
SELECT last_name,department_name
FROM employees e LEFT JOIN departments d
ON e.`department_id` = d.`department_id`;

#右外连接:
SELECT last_name,department_name
FROM employees e RIGHT OUTER JOIN departments d
ON e.`department_id` = d.`department_id`;

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

约束

约束的概念

角度3:约束的作用(或功能)

① not null (非空约束)unique  (唯一性约束)primary key (主键约束)foreign key (外键约束)check (检查约束)default (默认值约束)

在这里插入图片描述

查看表中约束

在这里插入图片描述

非空约束

在这里插入图片描述
在这里插入图片描述

唯一性约束

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

主键约束

在这里插入图片描述
在这里插入图片描述

自增列:AUTO_INCREMENT

在这里插入图片描述
在这里插入图片描述

FOREIGN KEY 约束

在这里插入图片描述
在这里插入图片描述
(8)当创建外键约束时,系统默认会在所在列上建立对应的普通索引。但是索引是列名,不是外键的约束名。(根据外键的查询效率很高)
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

pk5515

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值