【黄啊码】MySQL入门—3、我用select *,老板直接赶我坐火车回家去,买的还是站票

大家好!我是黄啊码,学会了DDL语句了吗?那我们今天就来学习一下基本的查询语法,我见过很多外包机构的程序员都是万物皆可select *,然后项目跑了一段时间就基本跑不动了,问就回答:服务器配置不够,加钱!好家伙,居然可以这样,学习啦【狗头保护】如果你在维护自家公司的项目,老板稍微会点技术,你相信他会打你吗?

好了,废话少说,先上课程目录:

SELECT 查询的基础语法;
如何排序检索数据;
什么情况下用SELECT*,如何提升 SELECT 查询效率?
SELECT 查询的基础语法
SELECT 可以帮助我们从一个表或多个表中进行数据查询。我们知道一个数据表是由列(字段名)和行(数据行)组成的,我们要返回满足条件的数据行,就需要在 SELECT 后面加上我们想要查询的列名,可以是一列,也可以是多个列。如果你不知道所有列名都有什么,也可以检索所有列。

1、检索所有列【你:好家伙,这么简单,我爸妈看到都会说我是大聪明】

select * from user_info;

呐,不就出来了吗?

【黄啊码】MySQL入门—3、我用select *,老板直接赶我坐火车回家去,买的还是站票

2、检索单个列【你:这也太简单了吧,小瞧我大聪明了?】

select user_name from user_info;

【黄啊码】MySQL入门—3、我用select *,老板直接赶我坐火车回家去,买的还是站票

黄啊码:但,你这结果好像顺序不对啊,张三不是该排在最前吧 。

你:嗯哼,我不管,能得到结果就行了。

黄啊码:啪,啪,老老实实给我看到最后。

3、起别名,说通俗易懂就是给它起个外号,比如你的外号就是二狗,哦,不对,是靓仔、靓女

select user_name as u_name from user_info;

【黄啊码】MySQL入门—3、我用select *,老板直接赶我坐火车回家去,买的还是站票

你:啊码,我很懒,我不想写那么多代码;

黄啊码:啪,就知道你不想写那么多,把as去掉不就少写两个字母了吗?

【黄啊码】MySQL入门—3、我用select *,老板直接赶我坐火车回家去,买的还是站票

黄啊码:结果是不是一样?

你:是一样,但,但是,下次能不能不打我?

黄啊码:打是亲,骂是爱,不打不骂不自在。

你:好家伙,待我东西学到手,让你知道什么叫做人间大爱!

4、查询常数

SELECT 查询还可以对常数进行查询。对的,就是在 SELECT 查询结果中增加一列固定的常数列。这列的取值是我们指定的,而不是从数据表中动态取出的。你可能会问为什么我们还要对常数进行查询呢?SQL 中的 SELECT 语法的确提供了这个功能,一般来说我们只从一个表中查询数据,通常不需要增加一个固定的常数列,但如果我们想整合不同的数据源,用常数列作为这个表的标记,就需要查询常数。

比如我们想在user_name前增加一列’u_name’代表人物名称,我们可以这么写:

select ‘人物名称’ as u_name,user_name from user_info;

【黄啊码】MySQL入门—3、我用select *,老板直接赶我坐火车回家去,买的还是站票

你:啊码,你这样写有点像脱裤子放屁,我一看觉得那是人物名称;

黄啊码:啪,啪,啪,你说什么? 不要你觉得,我要我觉得,我觉得这是在教你东西就行了,这三丈红给你个记性。

但切记,如果把人物名称改为数字,就不需要加单引号了,直接这样

【黄啊码】MySQL入门—3、我用select *,老板直接赶我坐火车回家去,买的还是站票

你:666,啊码就是厉害;

黄啊码:啪,要你夸,我厉害我能不知道?

5、去除重复行,比如:

【黄啊码】MySQL入门—3、我用select *,老板直接赶我坐火车回家去,买的还是站票

这明显就有两个张三,我想获取这张表里边的所有user_name,并且是独一无二的,该咋弄?

你:啊码,我知道,我知道,distinct!distinct!;

黄啊码:谁让你说的,你这样会让我很没面子的,啪!

select distinct user_name from user_info;

【黄啊码】MySQL入门—3、我用select *,老板直接赶我坐火车回家去,买的还是站票

这里有两点需要注意:

DISTINCT 需要放到所有列名的前面,如果写成SELECT user_age, DISTINCT user_name FROM user_info会报错。
DISTINCT 其实是对后面所有列名的组合进行去重,
如何排序检索数据
最最最普通的方式如下:

select * from user_info ORDER BY user_id asc;

【黄啊码】MySQL入门—3、我用select *,老板直接赶我坐火车回家去,买的还是站票

你:啊码,那是不是可以asc去掉;

黄啊码:啪,你终于有点觉悟了,确实是的。

【黄啊码】MySQL入门—3、我用select *,老板直接赶我坐火车回家去,买的还是站票

你:啊码,我说对了,你为啥还要打我;

我:不好意思,纯粹顺手,习惯了,啪;

你:捂着脸,敢怒不敢言。

使用 ORDER BY 子句有以下几个点需要掌握:

排序的列名:ORDER BY 后面可以有一个或多个列名,如果是多个列名进行排序,会按照后面第一个列先进行排序,当第一列的值相同的时候,再按照第二列进行排序,以此类推。
排序的顺序:ORDER BY 后面可以注明排序规则,ASC 代表递增排序,DESC 代表递减排序。如果没有注明排序规则,默认情况下是按照 ASC 递增排序。我们很容易理解 ORDER BY 对数值类型字段的排序规则,但如果排序字段类型为文本数据,就需要参考数据库的设置方式了,这样才能判断 A 是在 B 之前,还是在 B 之后。比如使用 MySQL 在创建字段的时候设置为 BINARY 属性,就代表区分大小写。
非选择列排序:ORDER BY 可以使用非选择列进行排序,所以即使在 SELECT 后面没有这个列名,你同样可以放到 ORDER BY 后面进行排序。
ORDER BY 的位置:ORDER BY 通常位于 SELECT 语句的最后一条子句,否则会报错。
至于WHERE … GROUP BY … HAVING .. 我们后边在学,黄啊码怕你吃太多会消化不良,到时啪的可是我。

什么情况下用 SELECT*,如何提升 SELECT 查询效率?
如果我们只是练习,或者对数据表进行探索,那么是可以使用SELECT * 的。它的查询效率和把所有列名都写出来再进行查询的效率相差并不大。这样可以方便你对数据表有个整体的认知。但是在生产环境下,不推荐你直接使用SELECT * 进行查询,如果你想强制上【潮汕话:硬爱】那没办法,这边建议您回炉重造。

好了,今天的课程学到这里,有问题的留个言,别忘了一键三连,下次我们还会再见!

最后留个问题,这文章出现了几个”啪”,数错了给我重新学一遍!

我是黄啊码,码字的码,退。。。退。。。退。。。朝!

Original: https://www.cnblogs.com/huangama/p/16506696.html
Author: 黄啊码
Title: 【黄啊码】MySQL入门—3、我用select *,老板直接赶我坐火车回家去,买的还是站票

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/619695/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • 数据库中异常与隔离级别

    数据库相对于其它存储软件一个核心的特征是它支持事务,所谓事务的ACID就是原子性,一致性,隔离性和持久性。其中原子性,一致性,持久性更多是关注单个事务本身,比如,原子性要求事务中的…

    数据库 2023年6月9日
    081
  • Go语言常见的并发模式

    Go语言常见的并发模式 并发不是并行 并发关注的是程序的设计层面,并发的程序也可以顺序执行,在多核CPU上才可能真正同时的运行,并行关注的是程序的运行层面,如GPU中对图像处理都会…

    数据库 2023年6月16日
    077
  • Java中CMD命令来备份mysql数据库备份文件出来为0字节问题

    Java中CMD命令来备份mysql&#…

    数据库 2023年5月24日
    0113
  • MySQL实战45讲 16

    16 | “order by”是怎么工作的? 以市民表为例,假设要查询城市是”杭州”的所有人名字,并且按照姓名 排序返回前 1000…

    数据库 2023年6月14日
    098
  • MySQL 日志管理

    日志文件记录 MySQL 数据库运行期间发生的变化,当数据库遭到意外的损害时,可以通过日志文件查询出错原因,并进件数据恢复 MySQL 日志文件可以分成以下几类: 二进制日志:记录…

    数据库 2023年5月24日
    060
  • Linux_文件传输工具_FileZilla

    FileZilla功能介绍: Filezilla是如此容易的下载和启动,你可能不会意识到它是多么强大。只需输入几个基本的服务器设置,您就可以点击一下启动并运行。要上传和下载文件,只…

    数据库 2023年6月11日
    0139
  • 域名ICP备案<阿里云>

    阅读指引 适用人:想要通过国内域名访问页面或者接口,需要进行ICP备案解决问题:备案过程中发生的问题阅读耗时:3分钟参考链接:阿里云ICP流程-视频、备案相关问题、注销备案相关问题…

    数据库 2023年6月9日
    096
  • 什么是回表,怎么解决?

    表tbl有a,b,c三个字段,其中a是主键,b上建了索引,然后编写sql语句SELECT * FROM tbl WHERE a=1这样不会产生回表,因为所有的数据在a的索引树中均能…

    数据库 2023年6月16日
    0122
  • 代码更新提交到GIT

    1、先克隆代码到本地做备份(在需要克隆项目的的那个文件夹下使用Git Bash Here可以直接定位到当前目录,不让需要定位cd命令到目录再使用克隆命令) $ git clone …

    数据库 2023年6月11日
    0103
  • 05-ElasticSearch高级搜索

    * package com.coolman.hotel.test; import com.coolman.hotel.pojo.HotelDoc; import com.faste…

    数据库 2023年6月16日
    088
  • Linux 下统计文件夹下文件的数量

    1、查看当前目录下的文件数量(不包含子目录中的文件) 2、查看当前目录下的文件数量(包含子目录中的文件) 3、 查看当前目录下的文件夹目录个数(不包含子目录中的目录),同上述理,如…

    数据库 2023年6月14日
    081
  • 爬虫基础

    1.爬虫是什么? 爬虫:一段自动抓取互联网信息的程序,从互联网上抓取对于我们有价值的信息。 2.爬虫原理 _3.第一个爬虫程序 _ 1.扒取网页 : 扒取网页和基本代码 首先我们调…

    数据库 2023年6月11日
    079
  • 精心总结十三条建议,帮你创建更合适的MySQL索引

    上篇文章讲到使用MySQL的Explain命令可以分析SQL性能瓶颈,优化SQL查询,以及查看是否用到了索引。 我们都知道创建索引可以提高查询效率,但是究竟如何创建索引呢? [En…

    数据库 2023年5月24日
    0109
  • 【转】SpringBoot ElasticSearch 各种查询汇总

    一:文档对象如下 二:非聚合复杂查询(这儿展示了非聚合复杂查询的常用流程) 三:精确查询(必须完全匹配上) 单个匹配termQuery 多个匹配 四:模糊查询(只要包含即可) 五:…

    数据库 2023年6月6日
    076
  • 网卡限速工具之WonderShaper

    GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源。 GreatSQL是MySQL的国产分支版本,使用上与MySQL一致。 什么是WonderShaper …

    数据库 2023年5月24日
    096
  • Redis学习

    Redis 因为没有指定配置文件 需配置 redis-server redis.windows.conf 之后自动启动 测试性能 redis-benchmark -p 6379 -…

    数据库 2023年6月16日
    078
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球