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

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

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

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

select * from user_info;

呐,不就出来了吗?

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

select user_name from user_info;

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

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

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

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

select user_name as u_name from user_info;

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

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

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

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

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

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

4、查询常数

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

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

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

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

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

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

你:666,啊码就是厉害;

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

5、去除重复行,比如:

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

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

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

select distinct user_name from user_info;

这里有两点需要注意:

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

select * from user_info ORDER BY user_id asc;

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

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

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

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

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

使用 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 * 进行查询,如果你想强制上【潮汕话:硬爱】那没办法,这边建议您回炉重造。

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

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

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

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

  1. MySQL入门02-MySQL二进制版本快速部署

    在上篇文章 MySQL入门01-MySQL源码安装 中,我们介绍了MySQL源码安装的方法. 源码安装虽然有着更加灵活和更加优化等诸多优势.但源码编译安装部署的过程相对复杂,而且整个过程所花费的时间很 ...

  2. MySQL入门笔记

    MySQL入门笔记 版本选择: 5.x.20 以上版本比较稳定 一.MySQL的三种安装方式: 安装MySQL的方式常见的有三种: ·          rpm包形式 ·          通用二进制 ...

  3. MySQL入门介绍(mysql-8.0.13)

    MySQL入门介绍(mysql-8.0.13单机部署) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MySQL数据库介绍 1>.MySQL是一种开放源代码的关系型数据库 ...

  4. 【数据库】4.0 MySQL入门学习(四)——linux系统环境下MySQL安装

    1.0 我的操作系统是CentOS Linux release 7.6.1810  (Core) 系统详细信息如下: Linux version 3.10.0-957.1.3.el7.x86_64 ( ...

  5. MySQL入门——在Linux下安装和卸载MySQL

    MySQL入门——在Linux下安装和卸载MySQL 摘要:本文主要学习了如何在Linux系统中安装和卸载MySQL数据库. 查看有没有安装过MySQL 使用命令查看有没有安装过: [root@loc ...

  6. MySQL入门(5)——运算符

    MySQL入门(5)--运算符 算术运算符 MySQL支持的算数运算符包括加.减.乘.除.求余. 符号 作用 + 加法运算 - 减法运算 * 乘法运算 / 除法运算 % 求余运算 DIV 除法运算,返 ...

  7. 21分钟 MySQL 入门教程(转载!!!)

    21分钟 MySQL 入门教程 目录 一.MySQL的相关概念介绍 二.Windows下MySQL的配置 配置步骤 MySQL服务的启动.停止与卸载 三.MySQL脚本的基本组成 四.MySQL中的数 ...

  8. MYSQL入门全套(第三部)

    MYSQL入门全套(第一部) MYSQL入门全套(第二部) 索引简介 索引是对数据库表中一个或多个列(例如,employee 表的姓名 (name) 列)的值进行排序的结构.如果想按特定职员的姓来查找 ...

  9. MySQL入门(三)

    写了两篇<MySQL入门>以后我发现,写书的人还是都挺有本事的,起码人家知道怎么编排自己想讲的知识点,我实在是不知道该先说那里后说哪里,那我就想到什么讲什么吧. 一 写SQL 其实我是不想 ...

随机推荐

  1. zipper题解

    -请奆佬们洁身自好,好好打代码从我做起 - 题目大意: 给三个字符串,判断C字符串是否由A B字符串顺序组成, 题意分析: 很容易想到的是,A的长度加上B的长度为C的长度 其实进一步想,这 提供了一个 ...

  2. Java学习笔记-基础语法Ⅴ

    学习一些Java常用的API Math:包含执行基本数字运算的方法 如果没有构造方法,一般类的成员都是静态的,通过类名可以直接调用 Java中有两种random函数,Math.Random()函数能够 ...

  3. Doker从0-1

    1.docker思想: 它是一种集装箱的思想,,在以前我们部署一个项目上线的时候,我们要部署各种各样的环境.配置.依赖等,各种各样的环境的配置是十分麻烦的,所以就有了docker.他就是将我们的项目和 ...

  4. ArcGIS和ArcEngine导出地图时,png格式支持背景透明

    1.ArcGIS支持导出PNG,背景透明 导出png时,背景色和透明色不能设置为空,必须设置为同一个颜色,通常使用白色. 2.ArcEngine支持导出PNG,背景透明 //1.创建export IE ...

  5. AJAX——POST请求

    POST.html <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...

  6. Hadoop: 单词计数(Word Count)的MapReduce实现

    1.Map与Reduce过程 1.1 Map过程 首先,Hadoop会把输入数据划分成等长的输入分片(input split) 或分片发送到MapReduce.Hadoop为每个分片创建一个map任务 ...

  7. 理“ Druid 元数据”之乱

    vivo 互联网大数据团队-Zheng Xiaofeng 一.背景 Druid 是一个专为大型数据集上的高性能切片和 OLAP 分析而设计的数据存储系统. 由于Druid 能够同时提供离线和实时数据的 ...

  8. es6.4.2api

    这是讲数据库的数据导入到es里  所有用到了mysql! 1.依赖 <?xml version="1.0" encoding="UTF-8"?> & ...

  9. BUUCTF-easycap

    easycap 看这个题目应该是流量包来的,wireshark打开即可.没什么特征,直接打开第一个包发现flag

  10. Sublime Text 新建代码片段(图解)

    新建代码片段 1.打开NEW Snippet- 2.编辑代码片段 3.设置快捷键,按tab键执行 更多内容请见原文,原文转载自:https://blog.csdn.net/weixin_4451949 ...