《MySQL必知必会》检索数据,排序检索数据(select ,* ,distinct ,limit , . , order by ,desc)
《MySQL必知必会》检索数据,排序检索数据
1、检索数据
1.1 select 语句
为了使用SELECT检索表数据,必须至少给出两条信息一想选择什
么,以及从什么地方选择。
1.2 检索单个列
select prod_name
from products;

(此时,检索得到的数据并未进行排序。)
MySQL执行多条SQL语句,结束每条SQL语句时,必须加上“ ; ”分隔,尽管这是单条SQL语句,你加上也可以执行,但其他部分的DBMS却可能需要单条SQL语句也需要加上“ ; ”才可以执行,为了代码的可复用性,培养这一习惯十分重要。
MySQL4.1版本后,SQL语句是不区分大小写的。大小写这取决于个人习惯。
在处理SQL语句时,其中所有空格都被忽略。SQL语句可以在一行上给出,也可以分成许多行。多数SQL开发人员认为将SQL语句分成多行更容易阅读和调试。
1.3 检索多个列
要想从一个表中检索多个列,使用相同的SELECT语句。唯-的不同是必须在SELECT关键字后给出多个列名,列名之间必须以逗号分隔(注意:最后一个列名不需要加逗号)。
select prod_name , prod_price
from products;

1.4检索所有列
select *
from products;

所有列用(*)通配符来表示。
给出的列的顺序按照表结构中的列顺序展示数据。
使用通配符一般, 除非你确实需要表中的每个列,否则最好别使用*通配符。虽然使用通配符可能会使你自己省事,不用明确列出所需列,但检索不需要的列通常会降低检索和应用程序的性能。
通过*通配符可以检索到未知列名的列。
1.5检索不同的行
使用distinct关键字指示MySQL只返回不同的值,排除掉相同的值。
distinct关键字必须放在列名的前面。
select distinct prod_price
from products;

不能部分使用distinct distinct关键字应用于所有列不仅是前置它的列。如果给出select distinct vend id,prodprice,除非指定的两个列都不同,否则所有行都将被检索出来。
1.6 限制显示结果
select prod_name , prod_price
from products limit 5;

使用关键字 limit , 限制只显示 5 行数据。
select prod_name , prod_price
from products limit 5 ,5;

还可以限制开始行 和 显示行数。上图表示显示从第6行数据开始,显示5 行数据(0表示第1行数据,5即表示第6行数据)。
在行数不够时,LIMIT中指定要检索的行数为检索的最大行数。如果没有足 够的行(例如,给出LIMIT10, 5,但只有13行,则返回最后3行数据),MySQL将只返回它能返回的那么多行。
MySQL 5 后,还有一种 limit 替代语法 , limit 3 offset 4 等同于 limit 4 , 3 ;意为从第5行开始取3行数据。
1.7 使用完全限定的表名(库名)
使用 “ . ” 指定
select products.prod_name
from mydb.products;
效果等同于
select prod_name
from products;
products表在 mydb 数据库中 ,prod_name 列在 products 表中。这样使用可以明确指定数据库,表。遇上不同库中相同表名,列名时,可以派上用场。
2、排序检索数据
2.1 排序数据
使用关键字 order by
select vend_name
from vendors
order by vend_name;

vend_name 以字母顺序排序数据。
2.2 按多个列排序
select prod_name , prod_price
from products
order by prod_price , prod_name;

先按价格排序,出现相同价格时,再按名称字母顺序排序。如果价格不相同,则不会按名称字母顺序排序。
2.3 指定排序方向
select prod_name , prod_price
from products
order by prod_price desc;

使用关键字 DESC 表示 降序排序方向,默认是升序排序方向(ASC)一般不需要指定。
select prod_name , prod_price
from products
order by prod_price desc,prod_name;
desc 并未指定到 prod_name 列,则prod_name 列还是按照升序排序显示数据结果。
同理, 在多个列上降序排序如果想在多个列上进行降序排序,必须对每个列指定DESC关键字。
在字典( dictionary )排序顺序中,A被视为与a相同,这是MySQL(和大多数数据库管理系统)的默认行为。但是,许多数据库管理员能够在需要时改变这种行为(如果你的数据库包含大量外语字符,:可能必须这样做)。这里,关键的问题是,如果确实需要改变这种排序顺序,用简单的ORDER BY子句做不到。你必须请求数据库管理员的帮助。
order by 可以和 limit 组合使用
select prod_name , prod_price
from products
order by prod_price desc
limit 3;

如果使用order by 和 limit 组合,limit 必须在 order by 子句之后。
《MySQL必知必会》检索数据,排序检索数据(select ,* ,distinct ,limit , . , order by ,desc)的更多相关文章
- 【SQL必知必会笔记(2)】检索数据、排序检索数据
上个笔记中介绍了一些关于数据库.SQL的基础知识,并且创建我们后续练习所需的数据库.表以及表之间的关系,从本文开始进入我们的正题:SQL语句的练习. 文章目录 1.检索数据(SELECT语句) 1.1 ...
- MySql必知必会实战练习(三)数据过滤
在之前的博客MySql必知必会实战练习(一)表创建和数据添加中完成了各表的创建和数据添加,MySql必知必会实战练习(二)数据检索中介绍了所有的数据检索操作,下面对数据过滤操作进行总结. 1. whe ...
- 《MySQL必知必会》过滤数据,数据过滤(where ,in ,null ,not)
<MySQL必知必会>过滤数据,数据过滤 1.过滤数据 1.1 使用 where 子句 在SEL ECT语句中,数据根据WHERE子句中指定的搜索条件进行过滤. WHERE子句在表名(FR ...
- 《MySQL 必知必会》读书总结
这是 <MySQL 必知必会> 的读书总结.也是自己整理的常用操作的参考手册. 使用 MySQL 连接到 MySQL shell>mysql -u root -p Enter pas ...
- 《MySQL必知必会》[01] 基本查询
<MySQL必知必会>(点击查看详情) 1.写在前面的话 这本书是一本MySQL的经典入门书籍,小小的一本,也受到众多网友推荐.之前自己学习的时候是啃的清华大学出版社的计算机系列教材< ...
- mysql必知必会系列(一)
mysql必知必会系列是本人在读<mysql必知必会>中的笔记,方便自己以后查看. MySQL. Oracle以及Microsoft SQL Server等数据库是基于客户机-服务器的数据 ...
- mysql必知必会
春节放假没事,找了本电子书mysql必知必会敲了下.用的工具是有道笔记的markdown文档类型. 下面是根据大纲已经敲完的章节,可复制到有道笔记的查看,更美观. # 第一章 了解SQL## 什么是S ...
- 《MySQL必知必会》整理
目录 第1章 了解数据库 1.1 数据库基础 1.1.1 什么是数据库 1.1.2 表 1.1.3 列和数据类型 1.1.4 行 1.1.5 主键 1.2 什么是SQL 第2章 MySQL简介 2.1 ...
- mysql 必知必会总结
以前 mysql 用的不是很多, 2 天看了一遍 mysql 必知必会又复习了一下基础. 200 页的书,很快就能看完, 大部分知识比较基础, 但还是了解了一些以前不知道的知识点.自己做一个备份,随 ...
随机推荐
- centos 安装 nginx 及配置 的坑
centos 安装 nginx 教程 1.创建/etc/yum.repos.d/nginx. centos 安装 nginx 教程 1.创建/etc/yum.repos.d/nginx.repo to ...
- APP自动化 -- contexts(上下文切换)
一.上下文是什么? 1.解释 1)在混合型APP中包含了 原生页面 和 H5页面,如果需要进入APP内嵌的H5页面里面去操作就需要先切换进去,如果要继续回到原生页面操作就需要切回来. 2)这个就像是 ...
- python新手70个练手项目
不管学习哪门语言都希望能做出实际的东西来,这个实际的东西当然就是项目啦,不用多说大家都知道学编程语言一定要做项目才行. 这里整理了70个Python实战项目列表,都有完整且详细的教程,你可以从中选择自 ...
- 导弹拦截问题 dp c++
// // Created by snnnow on 2020/4/13. // //每一次拦截只能是降续的导弹 //如果该次不能拦截成功,则拦截次数需要加一 //求每次最大拦截量,以及需要的拦截次数 ...
- vue脚手架创建项目名字报错
vue inti webpack TimeManger 报错 Sorry, name can no longer contain capital letters 原来这个capital是大写的意思,上 ...
- 定义 WSGI 接口
# WSGI服务器调用 def application(environ,start_response): start_response('200 OK',[('Content-Type','text/ ...
- ASP.NET Core 监听SQL Server数据库的实时信息
1.开发环境: 开发工具:Visual Studio 2019 数据库:SQL Server2012 开发环境:.Net Core 3.1 2.使用技术: Signalr:实现消息推送 SqlDepe ...
- PHP getdate() 函数
------------恢复内容开始------------ 实例 返回当前本地的日期/时间的日期/时间信息: <?phpprint_r(getdate());?> 运行实例 » 定义和用 ...
- CF R 209 div 2 CF359B Permutation 构造
LINK:Permutation 休闲一下 开了一道构造题. 看起来毫无头绪 其实仔细观察第二个条件 0<=2k<=n. 容易想到当n是奇数的时候 k的范围更小 再手玩一下第一个条件 容易 ...
- luogu P3279 [SCOI2013]密码
LINK:密码 给出来manacher的数组 让还原出字典序最小的字符串.字符集为小写字母. 当没有任何限制时 放字典序最小的'a'.如果此时还在最长的回文串中的话那么 直接得到当前字符即可. 注意这 ...