MySQL数据库基础第一篇(SQL通用语法与分类)

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS AI 助手,专业版
简介: MySQL数据库基础第一篇(SQL通用语法与分类)

在当今数据库驱动的世界里,SQL(结构化查询语言)作为一门管理数据的语言,对开发者而言极为关键。不论你是在做后端开发、数据科学,或者是设计和维护数据库,一个深入的SQL基础知识对你都大有裨益。

在这篇博客中,我将为你提供一个全套的SQL教程,涵盖了从最基础的SQL通用语法,到更复杂的DDL(数据定义语言),DML(数据操作语言)以及DQL(数据查询语言)等。每一部分都包含了相应的图解以及示例代码,以便于你更好地理解和掌握SQL语句的使用。

不论你是初学者还是有一些SQL使用经验的开发者,我希望这篇博客都能对你有所帮助。让我们一起深入到SQL的世界里,掌握这门强大的数据管理语言。

一、SQL通用语法

二、SQL分类

三、DDL语句

四、DML语句

1.案例代码

代码如下(示例):

INSERT 表_name VALUES (1,'小明',19,92,85,95),
                     (2,'小红',18,82,75,95),
                     (3,'小王',21,66,88,55),
                     (4,'小聪',20,92,84,95),
                     (5,'小东',20,98,95,65);
UPDATE  表_name SET name = '张三',age = 25 where ID=1;
UPDATE  表_name SET name = '王五',age = 35 where ID=3;
UPDATE  表_name SET name = '李四',age = 28 where ID=5;

2.读出结果

五、DQL语句

1.DQL-基本查询

2.DQL-条件查询

3.DQL-聚合函数

注意:null值不参与所有聚合函数运算。

4.DQL-分组查询

5.DQL-排序查询

6.DQL-分页查询

7.DQL语句-执行顺序

1.案例代码

代码如下(示例):

create table emp
(
    id          int comment '编号',
    workno      varchar(10) comment '工号',
    name        varchar(10) comment '姓名',
    gender      char(1) comment '性别',
    age         tinyint unsigned comment '年龄',
    idcard      char(18) comment '身份证号',
    workaddress varchar(50) comment '工作地址',
    entrydate   date comment '入职时间'
) comment '员工表';
insert into emp(id, workno, name, gender, age, idcard, workaddress, entrydate)
VALUES (1, '1', '柳岩', '女', 20, '123456789012345678', '北京', '2000-01-01'),
       (2, '2', '张无忌', '男', 18, '123456789012345670', '北京', '2005-09-01'),
       (3, '3', '韦一笑', '女', 38, '123456789012345670', '上海', '2005-08-01'),
       (4, '4', '赵敏', '女', 18, '123456789012345670', '北京', '2009-12-01'),
       (5, '5', '小昭', '女', 16, '123456789012345678', '上海', '2007-07-01'),
       (6, '6', '杨逍', '男', 28, '12345678901234567X', '北京', '2006-01-01'),
       (7, '7', '范瑶', '男', 40, '123456789012345670', '北京', '2005-05-01'),
       (8, '8', '黛绮丝', '女', 38, '123456789012345670', '天津', '2015-05-01'),
       (9, '9', '范凉凉', '女', 45, '123456789012345678', '北京', '2010-04-01'),
       (10, '10', '陈友谅', '男', 53, '123456789012345670', '上海', '2011-01-01'),
       (11, '11', '张士诚', '男', 55, '123456789012345670', '江苏', '2015-05-01'),
       (12, '12', '常遇春', '男', 32, '123456789012345670', '北京', '2004-02-01'),
       (13, '13', '张三丰', '男', 88, '123456789012345678', '江苏', '2020-11-01'),
       (14, '14', '灭绝', '女', 65, '123456789012345670', '西安', '2019-05-01'),
       (15, '15', '胡青牛', '男', 70, '12345678901234567X', '西安', '2018-04-01'),
       (16, '16', '周芷若', '女', 18, null, '北京', '2012-06-01');
- ------------------------------------ -> 查询需求 <- ----------------------------------------------
-- 基本查询
-- 1,查询指定字段 name ,woekno , age 返回
select name,workno,age from emp;
-- 2,查询指定所有字段 返回
select id, workno, name, gender, age, idcard, workaddress, entrydate from  emp;
select * from emp;
-- 查询所有员工的工作地址,起别名
select workaddress as '工作地址' from emp;
-- 查询所有员工的工作地址(不要重复)
select distinct workaddress as '工作地址' from emp;
-- 条件查询
-- 1,查询年龄等于 88 的员工
select * from emp where age = 88;
-- 2,查询没有身份证的员工信息
select * from emp where idcard is null;
-- 3,查询年龄在 15 到 20 岁之间的员工
select * from emp where age >=15 && age <=20 ;
-- 4,查询性别为女年龄小于 25 岁的员工
select * from emp where gender = '女' && age < 25;
-- 5,查询年龄等于20或40或18岁的员工
select * from emp where age iN(18,20,40);
-- 6,查询性别为两个字员工
select * from emp where name like '__';
-- 7.查询身份证号码最后一位为X的员工信息
select * from emp where idcard like '%X';
-- 聚合函数
-- 1,统计该企业员工数量
select count(*) from emp;
select count(idcard) from emp;
-- 2,统计该企业员工的平均年龄
select avg(age) from emp;
-- 3,统计该企业西安地区员工的年龄之和
select sum(age) from emp where workaddress = '西安';
-- 分组查询
-- 1,根据性别分组,统计男员工与女员工的数据
select gender, count(*) from emp group by gender;
-- 2,根据性别分组,统计男员工与女员工的平均成绩
select gender, avg(age) from emp group by gender;
-- 3,调查年龄小于45的员工,并根据工作地址分组,获取员工数量大于等于3的工作地址
select workaddress, count(*) from emp where age<=45 group by  workaddress;
-- 排序查询
-- 1,根据性别分组,统计男员工与女员工的数据
 select  * from  emp order by  age asc ;
-- 2,根据入职时间对公司的员工,进行降序排序
 select  * from  emp order by  entrydate desc ;
-- 3,根据年龄对公司的员工进行升序排序,如果年龄相同,再根据入职时间进行降序排序
 select  * from  emp order by  age asc , entrydate desc ;
-- 分页查询
-- 1,查询第一页的员工数据,每页展示10条记录
select  *  from  emp limit 0,10;
-- 2,查询第二页的员工数据,每页展示10条记录
select  *  from  emp limit 10,10;

2.读出结果

– 1,查询指定字段 name ,woekno , age 返回

– 2,查询指定所有字段 返回

– 查询所有员工的工作地址,起别名

– 查询所有员工的工作地址(不要重复)

– 1,查询年龄等于 88 的员工

– 2,查询没有身份证的员工信息

– 3,查询年龄在 15 到 20 岁之间的员工

– 4,查询性别为女年龄小于 25 岁的员工

– 4,查询年龄等于20或40或18岁的员工

– 6,查询性别为两个字员工

– 7.查询身份证号码最后一位为X的员工信息

– 聚合函数

– 1,统计该企业员工数量

– 2,统计该企业员工的平均年龄

– 3,统计该企业西安地区员工的年龄之和

– 分组查询

– 1,根据性别分组,统计男员工与女员工的数据

– 2,根据性别分组,统计男员工与女员工的平均成绩

– 3,调查年龄小于45的员工,并根据工作地址分组,获取员工数量大于等于3的工作地址

– 分组查询

– 1,根据年龄对公司的员工进行升序排序

– 2,根据入职时间对公司的员工,进行降序排序

– 3,根据年龄对公司的员工进行升序排序,如果年龄相同,再根据入职时间进行降序排序

– 分页查询

– 1,查询第一页的员工数据,每页展示10条记录

– 2,查询第二页的员工数据,每页展示10条记录

六、DCL语句

1.DCL-管理用户

2.DCL-权限控制

1.案例代码

代码如下(示例):

-- 创建用户 itcast ,只能够在当前主机localhost访问,密码123456;
create user 'itcast'@'localhost' identified by '123456';
-- 创建用户 heima ,可以在任意主机访问数据库,密码123456;
create user 'heima'@'%' identified by '123456';
-- 修改用户 heima 密码,为 1234 ;
alter user 'heima'@'%' identified with mysql_native_password by '1234';
-- 删除用户 'itcast'@'localhost'用户
drop user 'itcast'@'localhost';
-- 查询权限
show grants for 'heima'@'%';
-- 授予权限
grant all on itcast.* to 'heima'@'%';
-- 撤销权限
revoke all on itcast.*from 'heima'@'%';


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
5月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
1009 152
|
5月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。
808 156
|
5月前
|
SQL 人工智能 Linux
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
528 5
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
|
4月前
|
SQL 存储 监控
SQL日志优化策略:提升数据库日志记录效率
通过以上方法结合起来运行调整方案, 可以显著地提升SQL环境下面向各种搜索引擎服务平台所需要满足标准条件下之数据库登记作业流程综合表现; 同时还能确保系统稳健运行并满越用户体验预期目标.
299 6
|
5月前
|
SQL 监控 关系型数据库
SQL优化技巧:让MySQL查询快人一步
本文深入解析了MySQL查询优化的核心技巧,涵盖索引设计、查询重写、分页优化、批量操作、数据类型优化及性能监控等方面,帮助开发者显著提升数据库性能,解决慢查询问题,适用于高并发与大数据场景。
|
5月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
5月前
|
SQL 监控 关系型数据库
查寻MySQL或SQL Server的连接数,并配置超时时间和最大连接量
以上步骤提供了直观、实用且易于理解且执行的指导方针来监管和优化数据库服务器配置。务必记得,在做任何重要变更前备份相关配置文件,并确保理解每个参数对系统性能可能产生影响后再做出调节。
588 11
|
5月前
|
SQL Oracle 关系型数据库
Oracle数据库创建表空间和索引的SQL语法示例
以上SQL语法提供了一种标准方式去组织Oracle数据库内部结构,并且通过合理使用可以显著改善查询速度及整体性能。需要注意,在实际应用过程当中应该根据具体业务需求、系统资源状况以及预期目标去合理规划并调整参数设置以达到最佳效果。
404 8
|
SQL 数据库 索引
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")

推荐镜像

更多