《MySQL必知必会》检索数据,排序检索数据(select ,* ,distinct ,limit , . , order by ,desc)
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了《MySQL必知必会》检索数据,排序检索数据(select ,* ,distinct ,limit , . , order by ,desc),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3582字,纯文字阅读大概需要6分钟。
内容图文
![《MySQL必知必会》检索数据,排序检索数据(select ,* ,distinct ,limit , . , order by ,desc)](/upload/InfoBanner/zyjiaocheng/871/286fc8052809467ba4c7436f8b16a28f.jpg)
《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行数据。
**需要注意的是 LIMIT 是MySQL 特有的关键字,Oracle 没有的,考虑到可复用性,应减少使用。**
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)全部内容,希望文章能够帮你解决《MySQL必知必会》检索数据,排序检索数据(select ,* ,distinct ,limit , . , order by ,desc)所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。