MySQL从删库到跑路: 入门篇

MySQL 入门


1. 查询语句
1.1 SQL的分类

# DDL: 数据定义语言  create \ alter \ drop \ rename \ truncate
# DML: 数据操作语言  insert \ delete \ update \ select
# DCL: 数据控制语言  commit \ rollback \ savepoint \ grant \ revoke
1.2 单表select语句

  1. select...from...
select * from employees;
select employee_id, salary from employees;
  1. 列的别名
select employee_id emp_id from employees;
select employe_id as emp_id from employees;		# as 可省略, 别名可用"" eg "部门id"
  1. 去除重复行
select distinct department_id from employees;  # 字段前 + distinct
select salary, distinct department_id from employees;  # 错误
select distinct department_id, salary, from employees;  # 整体去重, 没实际意义
  1. 空值参与运算
# null 不等同于0, '', 'null'
# 空值参与运算 结果一定为空
select 
	employee_id, salary "月工资", salary * (1 + commision_pct) * 12 "年工资" 
from 
	employees;		# commision_pct为null的 年工资全为null
	
select 
	employee_id, salary "月工资", salary * (1 + ifnull(commision_pct, 0)) * 12 "年工资" 
from 
	employees;		# 使用ifnull()
  1. 着重号
select * from order;  # 错误 order为关键字
select * from `order`;
  1. 查询常数
select "Mysql", employee_id, last_name from employees;	# 三列, 匹配常数Mysql
  1. 显示表结构
describe employees;  # 显示表中相关字段的详细信息
desc employees;
  1. 过滤数据
# 查询90号部门的员工信息
select * from employees where department_id = 90;
  1. 运算符
# 算术运算符 +, -, *, /, div, %, mod
# 比较运算符 =, <=> 安全等于, <>(!=) 不等于, <, <=, >, >=

# is null, is not null, isnull
select last_name, salary, commision_pct from employees where commision_pct is null;

# least(), greatest()
select least('g', 'b', 'r'), greatest('g', 'T', 'c') from dual;

# between..and...	闭区间, between前可加not
select employee_id, last_name, salary from employees where salary between 6000 and 8000;

# in, not in
select last_name, salary, department_id from employees where department_id in (10, 20, 30);

# like, % 代表不确定个数的字符, _代表一个不确定字符
# 查询第二个字符是'_' 且 第三个字符为 'a'的员工信息  --> 使用转义字符
select last_name from employees where last_name like '_\_a%';

# regexp, rlike 正则表达式

# 逻辑运算符: or, ||, and, &&, not, !, XOR(逻辑异或, 一真一假)
select 
	last_name, salary, department_id 
from 
	employees 
where 
	department_id = 50 and salary >= 10000;
	
# 位运算符: &, |, ^, ~, >
  1. 排序
select employee_id, last_name, salary from employees order by salary desc;  # desc asc
  1. 分页
# limit 分页
select employee_id, last_name, salary from employees limit 0, 20;	# START_INDEX, PAGESIZE

在这里插入图片描述

1.3 多表select语句

  1. 笛卡尔积
# 1 -> x, 每个员工都与每个部门匹配了一遍, 笛卡尔积(交叉连接), 缺少了多表的连接条件
select employee_id, department_name from employees, department;
  1. 等值连接
select 
	e.employee_id, d.department_name 
from 
	employees e, departments d
where
	e.department_id = d.department_id;
  1. 非等值连接
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_salary;
  1. 自连接
select
	e.employee_id, e.last_name, m.employee_id, m.last_name
from
	employees e, employees m
where
	e.manage_id = m.employee_id;
  1. 非自连接
# 以上几个case均为非自连接
  1. 内连接
# 以上几个case均为内连接
  1. 外连接
# 查询所有的员工的employee_id, department_name 信息
# SQL92语法实现外连接 使用 (+), MySQL 不支持
select
	e.employee_id, d.department_name
from
	employees e, departments d
where
	e.department_id = d.department_id(+);

# SQL99 语法使用join..on.. 实现多表查询
select
	e.employee_id, d.department_name
from
	employees e
left outer join
	departments d
on
	e.department_id = d.department_id;	# 左外连接
	
select
	e.employee_id, d.department_name
from
	departments d
right outer join
	employees e
on
	d.department_id = e.department_id;	# 右外连接
	
select
	e.employee_id, d.department_name
from
	departments d
full outer join
	employees e
on
	d.department_id 
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
MySQL数据库是一种开源的关系型数据库管理系统,广泛应用于各种应用程序中。要从入门到精通MySQL数据库,您可以按照以下步骤进行学习: 1. 学习基本概念:了解关系型数据库的基本概念,包括表、字段、行、主键、外键等。掌握SQL语言的基本语法,包括创建表、插入数据、查询数据、更新数据和删除数据等操作。 2. 安装和配置MySQL:下载并安装MySQL数据库软件,并进行必要的配置。根据您的操作系统类型,可以选择适合的安装包和安装方法。 3. 学习SQL语言:深入学习SQL语言,包括数据定义语言(DDL)、数据操作语言(DML)、数据查询语言(DQL)和数据控制语言(DCL)等。掌握各种语句的使用方法和常见的函数。 4. 数据库设计和建模:学习如何设计和规划数据库结构,包括确定表结构、定义关系、创建索引等。了解各种数据类型和约束条件的使用。 5. 数据库操作:学习如何创建、修改和删除数据库、表和字段。掌握如何插入、更新和删除数据,以及查询数据并进行排序、过滤和分组等操作。 6. 数据库优化:了解数据库性能优化的方法和技巧,包括索引设计、查询优化、表结构调整等。学习如何监控和调优数据库性能,提高系统的响应速度和并发能力。 7. 高级特性和扩展:学习MySQL数据库的高级特性,如事务处理、存储过程、触发器、视图等。了解如何进行备份和恢复数据,以及故障处理和错误调试等。 8. 实践项目:通过实践项目来巩固所学知识,例如创建一个简单的博客系统或电子商务平台。在实际应用中遇到问题时,学会查找文档和寻求帮助。 9. 持续学习和探索:MySQL数据库是一个庞大而复杂的系统,持续学习和探索新的功能和技术是提升自己的关键。阅读官方文档、参与社区讨论和参加培训课程都是不错的学习途径。 通过以上步骤的学习和实践,您可以逐步掌握MySQL数据库的基本知识和技能,并不断提升自己的水平。记得多动手实践,不断积累经验才能更好地理解和掌握MySQL数据库

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值