声明:本篇文章大多数内容出自《MySQL必知必会》,仅供学习参考,勿作他用!

第4章 检索数据

4.1 SELECT语句

SELECT子句用于检索数据库中的表数据。它几乎是MySQL中最常用的语句。我们一定要掌握好。为了能够检索表数据,必须至少给出两条信息 —— 想选择什么(表字段,即列),以及从什么地方选择(哪张表)。

4.2 检索单个列

输入: select prod_name from products;

分析:

上述语句利用SELECT语句从products表中检索一个名为prod_name的列。选择什么 —— prod_name列;从什么地方选 —— products表。

形式: SELECT 列名 FROM 表名;  (列应该是表中的列)

输出:    如图

注释:

1 你可能得到不同的顺序。这很正常。如果没有排序的话,顺序是随机的。只要数据正确即可。

2 每一条SQL语句都应该以分号(英文)结尾。一 为了规范,二 如果是命令行则必须如此。

3 无论何种编程语言,语法中的符号都是英文下的(半角输入法)。以后不再强调。

4 大小写的说明。MySQL中的SQL语句不区分大小写。但是,为了规范,一般将关键字大写,其它标识符小写。如 SELECT prod_name FROM products;

我为了节省书写博文的时间,便一律采用小写了,请见谅。

4.3 检索多个列

要想从一个表中检索多个列,使用相同的SELECT语句。惟一的不同即SELECT关键字后跟多个列名,且这些列名之间要用逗号(英文的)隔开。

输入:  select prod_id, prod_name, prod_price from products;

分析: 没啥分析的。

输出:

4.4 检索所有列

格式:    SELECT * FROM 表名; 或者SELECT 列名1, 列名2... FROM 表名;

输入:

select * from products;

或者

select prod_id, vend_id, prod_name, prod_price, prod_desc from products;

分析:

第一种方式采用了通配符*代表了所有列。第二种方式将所有列的列出了。

如果不是真的需要,不要为了方便使用*查询。这样会检索到不需要的列,从而增加时间。

输出:

方式一

方式二

4.5 检所不同的行

正如所见,SELECT语句默认会返回所有匹配的行。而如果我们不想每个值每次都出现,怎么办?加入你想得出products表中的供应商的id

输入: select vend_id from products;

输出:

我们发现,相同的id多次出现。如果我们想解决这一问题,那么就需要DISTINCT关键字。意思: 独特的,不同的。

格式: SELECT DISTINCT 列名 FROM 表名;

输入:

select distinct vend_id from products;

分析:

如果使用DISTINCT关键字,它必须直接放在列名前面。

    如果DISTINCT后面接多个列名,则无效。

输出:

4.6 限制结果

SELECT语句返回所有匹配的行,有时可能是指定表中所有的行。为了返回第一行或前几行,可使用LIMIT关键字。

格式: SELECT 单列名或多个列名 FROM 表名 LIMIT 显示的结果行数;

输入:    select prod_name from products limit 5;

分析:    LIMIT 5指示MySQL返回的结果行数不得多于5条。

输出:

如果想要显示下一个5行,可以指定要检索的开始行和行数。如下所示:

格式:    SELECT 单列名或多个列名 FROM 表名 LIMIT 开始的索引(第一行的索引为0,第二行的索引为1...), 显示的结果行数,

输入: mysql> select prod_name from products limit 0,5;

分析:

limit A, B。从行5,即索引为0,结果的第1行开始获取5行, 限制显示条数不得多于B,

输出:

注释

1 行0: 如果是LIMIT A, B的格式。那么检索出来的第一行为行0,即索引为0,而非1. 如LIMIT 1, 1检索出第二行而非第一行。

2 MySQL5的LIMIT语法:    LIMIT A, B的格式很容易令人混淆,所以MySQL5.0支持LIMIT的另一种语法。LIMIT 结果显示条数 OFFSET 索引(行N);

OFFSET是偏移量的意思,即索引,行N。

输入: select prod_name from products limit 5 offset 3;

分析:

limit 5 offst 3; 限制显示结果条数为5,索引为3,从行3即第四行开始获取。

输出:

4.7 使用完全限定名

迄今为止使用的SQL例子只通过列名引用咧。也可能会使用完全限定名字来引用列(同时使用表名和列名)。请看下面例子:

格式: 完全限定的列名 —— 列名.表名

输入:    select distinct products.vend_id from products;

分析:    结果与select distinct vend_id from products; 一致。

输出:

表名也可以完全限定。

格式: 数据库名.表名

输入:     select distinct vend_id from mysqlcrashcourse.products;

输出:

有一些情形下需要使用完全限定名,这在之后的博文中会介绍。现在,我们需要注意这个语法,以便日后的学习与使用。

4.8 小结

本章学习了如何使用SELECT语句检索表的单列、多列数据以及所有列。下一篇讲讲解如何排序检索出来的数据。

MySQL数据库学习02: SELECT语句的更多相关文章

  1. MySQL数据库学习: 02 —— 数据库的安装与配置

                             MySQL安装图解 一.MYSQL的安装 1.打开下载的mysql安装文件mysql-5.0.27-win32.zip,双击解压缩,运行“setup. ...

  2. MYSQL数据库学习笔记1

      MYSQL数据库学习笔记1 数据库概念 关系数据库 常见数据库软件 SQL SQL的概念 SQL语言分类 数据库操作 创建数据库 查看数据库的定义 删除数据库 修改数据库 创建表 数据类型 约束 ...

  3. MySQL数据库学习笔记(十)----JDBC事务处理、封装JDBC工具类

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  4. MySQL数据库学习笔记(九)----JDBC的ResultSet接口(查询操作)、PreparedStatement接口重构增删改查(含SQL注入的解释)

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  5. MySQL使用查看表SELECT语句

    来源:实验楼 本节实验中学习了 SELECT 语句的常用方法: 基本语法 数学符号条件 AND OR IN 通配符 排序 SQL 内置函数和计算 子查询与连接查询 输入命令,下载代码: git clo ...

  6. MySQL数据库学习笔记(十二)----开源工具DbUtils的使用(数据库的增删改查)

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  7. Mysql数据库学习笔记之数据库索引(index)

    什么是索引: SQL索引有两种,聚集索引和非聚集索引,索引主要目的是提高了SQL Server系统的性能,加快数据的查询速度与减少系统的响应时间. 聚集索引:该索引中键值的逻辑顺序决定了表中相应行的物 ...

  8. MySQL数据库学习: 01 —— 数据库的概述

    壹 概述 一 了解SQL 1.1 数据库基础 1.1.1 什么是数据库 数据库(database)保存有组织的数据的容器(通常是一个文件或一组文件). 易混淆:人们常常用“数据库”这个词语来代表他们使 ...

  9. MySQL数据库(增删改查语句)

    MySQL数据库(增删改查语句)一.登录数据库:---->  mysql -uroot -proot;(对应用户名和密码)二.SQL语句:    数据定义语言DDL  用来定义数据库.表.列,关 ...

随机推荐

  1. 使用Bitbucket Pipeline进行.Net Core项目的自动构建、测试和部署

    1. 引言 首先,Bitbucket提供支持Mercurial和Git版本控制系统的网络托管服务.简单来说,它类似于GitHub,不同之处在于它支持个人免费创建私有项目仓库.除此之外,Bitbucke ...

  2. ASP.NET MVC5+EF6+EasyUI 后台管理系统(88)-Excel导入和导出-主从表结构导出

    前言 前面一篇详细讲解了导入导出,本节演示混合结构的导出功能!同时提供代码下载.. 代码下载 vs2015+无数据库 先看效果图:这个一个混合的Excel,列表与自定义信息的混合! 我们的步骤大概分为 ...

  3. 如果nginx启动失败,错误解决

    解决上面问题: /usr/sbin/groupadd -f www /usr/sbin/useradd -g www www 这方法常见出现时反向代理时,ssl的授权用户不存在的情况下出现的:.

  4. Yahoo网站性能优化的34条军规

    1.尽量减少HTTP请求次数 终端用户响应的时间中,有80%用于下载各项内容,这部分时间包括下载页面中的图像.样式表.脚本.Flash等.通过减少页面中的元素可以减少HTTP请求的次数,这是提高网页速 ...

  5. CentOS安装Nginx 报错“configure: error: the HTTP rewrite module requires the PCRE library”解决办法

    错误提示: ./configure: error: the HTTP rewrite module requires the PCRE library.      yum install gcc gc ...

  6. 双向bfs-八数码问题

    [八数码][1] [1]: https://www.luogu.org/problem/show?pid=1379 其实除了搜索恶心一点,好像也没什么提高+的 bfs搜的是状态. 双向bfs同时从起点 ...

  7. 【Win 10 应用开发】MIDI 音乐合成——音符消息篇

    在上一篇中,老周介绍了一些乐理知识,有了那些常识后,进行 MIDI 编程就简单得多了.尽管微软已经把 API 封装好,用起来也很简单,但是,如果你没有相应的音乐知识基础,你是无法进行 MIDI 编程的 ...

  8. Winform开发中如何将数据库字段绑定到ComboBox控件

    最近开始自己动手写一个财务分析软件,由于自己也是刚学.Net不久,所以自己写的的时候遇到了很多问题,希望通过博客把一些印象深刻的问题记录下来. Winform开发中如何将数据库字段绑定到ComboBo ...

  9. 剑指 offer代码解析——面试题39推断平衡二叉树

    题目:输入一颗二叉树的根结点.推断该树是不是平衡二叉树. 假设某二叉树中随意结点的左右子树的高度相差不超过1,那么它就是一棵平衡二叉树. 分析:所谓平衡二叉树就是要确保每一个结点的左子树与右子树的高度 ...

  10. SSM框架开发web项目系列(四) MyBatis之快速掌握动态SQL

    前言 通过前面的MyBatis部分学习,已经可以使用MyBatis独立构建一个数据库程序,基本的增删查改/关联查询等等都可以实现了.简单的单表操作和关联查询在实际开的业务流程中一定会有,但是可能只会占 ...