MySQL基础学习(三)

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 在实际开发中不建议,可以自己玩没问题。 你可以在DOS命令窗口中想快速的看一看全表数据可以采用这种方式。

1677578646753.png


简单查询


查询一个字段?


select 字段名 from 表名;


查询两个字段,或者多个字段怎么办? 使用逗号隔开“,”


查询所有字段?


使用:select * from 表名;


别把把这种写法写到 Java 程序中,因为到时还要把 * 先转换成字段


缺点:①效率低 ②可读性差。


在实际开发中不建议,可以自己玩没问题。 你可以在DOS命令窗口中想快速的看一看全表数据可以采用这种方式。


给查询的列起别名?


使用 as 关键字,可以省略 select deptno,dname as deptname from dept;


假设起别名的时候,别名里面有空格,怎么办? mysql> select deptno,dname dept name from dept; DBMS看到这样的语句,进行SQL语句的编译,不符合语法,编译报错。 怎么解决? select deptno,dname 'dept name' from dept; //加单引号 select deptno,dname "dept name" from dept; //加双引号


注意:在所有的数据库当中,字符串统一使用单引号括起来, 单引号是标准,双引号在oracle数据库中用不了。但是在mysql 中可以使用。


再次强调:数据库中的字符串都是采用单引号括起来。这是标准的。 双引号不标准。


字段可以使用数学表达式


select ename,sal*12 from emp;


显示时字段名是 sal*12 这样时一般取个别名 select ename,sal*12 year_sal from emp;


条件查询


什么是条件查询?


查询出来符合条件的  语法格式:  select  字段1,字段2,字段3....  from  表名  where  条件;


都有哪些条件?


= 等于 查询薪资等于800的员工姓名和编号? select empno,ename from emp where sal = 800;


<> 或 != 不等于 查询薪资不等于800的员工姓名和编号? select empno,ename from emp where sal != 800;


同理还有:<=,<,>=,>


between … and …. 两个值之间, 等同于 >= and <=


查询薪资在2450和3000之间的员工信息?包括2450和3000?


注意: 使用between and的时候,必须遵循左小右大。 between and是闭区间,包括两端的值。


is null 表示为 null(is not null 不为空)


查询哪些员工的津贴/补助为null? select empno,ename,sal,comm from emp where comm = null;(像这样用=是查不到的) Empty set (0.00 sec)


注意:在数据库当中null不能使用等号进行衡量。需要使用is null 因为数据库中的null代表什么也没有,它不是一个值,所以不能使用 等号衡量。


正确的:select empno,ename,sal,comm from emp where comm is null;


and 并且 查询工作岗位是MANAGER并且工资大于2500的员工信息?


select empno,ename,job,sal from emp where job = 'MANAGER' and sal > 2500;

or 或者


查询工作岗位是MANAGER或SALESMAN的员工?


select empno,ename,job from emp where job = 'MANAGER' or job = 'SALESMAN';


and和or同时出现的话,有优先级问题吗?(开发中如不记得优先级,加小括号) 查询工资大于2500,并且部门编号为10或20部门的员工? select * from emp where sal > 2500 and deptno = 10 or deptno = 20; 分析以上语句的问题?


and优先级比or高。 以上语句会先执行and,然后执行or。 以上这个语句表示什么含义? 找出工资大于2500并且部门编号为10的员工,或者20部门所有员工找出来。 正确做法:select * from emp where sal > 2500 and (deptno = 10 or deptno = 20);


in 包含,相当于多个 or (not in 不在这个范围中) 查询工作岗位是MANAGER和SALESMAN的员工? select empno,ename,job from emp where job = 'MANAGER' or job = 'SALESMAN'; select empno,ename,job from emp where job in('MANAGER', 'SALESMAN');


注意:in不是一个区间。in后面跟的是具体的值。


查询薪资是800和5000的员工信息? select ename,sal from emp where sal = 800 or sal = 5000; select ename,sal from emp where sal in(800, 5000); //这个不是表示800到5000都找出来。


not in 表示不在这几个值当中的数据。 select ename,sal from emp where sal not in(800, 5000, 3000);


not 可以取非,主要用在 is 或 in 中 is null is not null in not in


like 称为模糊查询,支持%或下划线匹配 %匹配任意多个字符 下划线:任意一个字符。 (%是一个特殊的符号,_ 也是一个特殊符号)


找出名字中含有O的? mysql> select ename from emp where ename like '%O%';


找出名字以T结尾的? select ename from emp where ename like '%T';


找出名字以K开始的? select ename from emp where ename like 'K%';


找出第二个字每是A的? select ename from emp where ename like '_A%';


找出第三个字母是R的? select ename from emp where ename like '__R%';


找出名字中有“_”的? select name from t_student where name like '%_%'; //这样不行。


正确: select name from t_student where name like '%\_%'; // \转义字符。


对查询结果排序


排序 order by( 默认是升序!!!)


查询所有员工薪资,排序? select ename,sal from emp order by sal;


怎么降序(后面加上desc)?


指定降序: select ename,sal from emp order by sal desc;


可以两个字段排序吗?或者说按照多个字段排序? 查询员工名字和薪资,要求按照薪资升序,如果薪资一样的话, 再按照名字升序排列。 select ename,sal from emp order by sal desc, ename asc; // sal在前,起主导,只有sal相等的时候,才会考虑启用ename排序。


了解内容:根据字段的位置也可以排序 select ename,sal from emp order by 2; // 2表示第二列。第二列是sal 按照查询结果的第2列sal排序。


了解一下,不建议在开发中这样写,因为不健壮。 因为列的顺序很容易发生改变,列顺序修改之后,2就废了


综合一点的案例: 找出工资在1250到3000之间的员工信息,要求按照薪资降序排列。 select ename,sal from emp where sal between 1250 and 3000 order by sal desc;


以上语句的执行顺序必须掌握: 第一步:from 第二步:where 第三步:select 第四步:order by

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1月前
|
分布式计算 关系型数据库 MySQL
大数据-88 Spark 集群 案例学习 Spark Scala 案例 SuperWordCount 计算结果数据写入MySQL
大数据-88 Spark 集群 案例学习 Spark Scala 案例 SuperWordCount 计算结果数据写入MySQL
50 3
|
5月前
|
SQL 关系型数据库 MySQL
关于MySQL数据库的学习指南总结
【6月更文挑战第17天】MySQL是流行的关系型DBMS,适合各种应用。学习要点包括安装配置、数据类型、SQL(如SELECT、INSERT)、关系模型、表设计、SQL查询(如WHERE、ORDER BY)、事务处理、用户管理、性能优化和高级技术如存储过程、触发器。了解ACID特性,使用索引和内存优化提升性能,通过备份恢复确保数据安全。不断学习新技术以提升技能。
97 3
|
1月前
|
关系型数据库 MySQL Java
Django学习二:配置mysql,创建model实例,自动创建数据库表,对mysql数据库表已经创建好的进行直接操作和实验。
这篇文章是关于如何使用Django框架配置MySQL数据库,创建模型实例,并自动或手动创建数据库表,以及对这些表进行操作的详细教程。
66 0
Django学习二:配置mysql,创建model实例,自动创建数据库表,对mysql数据库表已经创建好的进行直接操作和实验。
|
1月前
|
Java 关系型数据库 MySQL
springboot学习五:springboot整合Mybatis 连接 mysql数据库
这篇文章是关于如何使用Spring Boot整合MyBatis来连接MySQL数据库,并进行基本的增删改查操作的教程。
98 0
springboot学习五:springboot整合Mybatis 连接 mysql数据库
|
1月前
|
Java 关系型数据库 MySQL
springboot学习四:springboot链接mysql数据库,使用JdbcTemplate 操作mysql
这篇文章是关于如何使用Spring Boot框架通过JdbcTemplate操作MySQL数据库的教程。
29 0
springboot学习四:springboot链接mysql数据库,使用JdbcTemplate 操作mysql
|
1月前
|
关系型数据库 MySQL 数据库
mysql关系型数据库的学习
mysql关系型数据库的学习
20 0
|
1月前
|
Kubernetes 关系型数据库 MySQL
k8s学习--利用helm部署应用mysql,加深helm的理解
k8s学习--利用helm部署应用mysql,加深helm的理解
199 0
|
2月前
|
SQL 关系型数据库 MySQL
学习MySQL操作的有效方法
学习MySQL操作的有效方法
46 3
|
2月前
|
SQL 关系型数据库 MySQL
如何学习 MySQL?
如何学习 MySQL?
39 3
|
3月前
|
SQL 关系型数据库 MySQL
学习mysql基础操作
【8月更文挑战第20天】学习mysql基础操作
40 1

热门文章

最新文章

下一篇
无影云桌面