mysql 数据检索_MySQL从零开始:06 数据检索

所谓数据检索,就是前面所讲的”增删改查“的”查“。

注:本文使用的“行”指数据表中的“记录”,“列”指数据表中的“字段”。

在第四节《表的增删改查》中已经介绍了 select 查询记录的几种使用方法:查询所有行的所有列、查询指定行的所有列、查询所有行的指定列和查询指定行的指定列。本文介绍一些数据检索的其他高级使用方法。

1、数据准备

首先准备文需要的数据,如下图所示:

01_%E6%88%90%E7%BB%A9%E8%A1%A8.png

01_成绩表

使用如下语句进行数据库的创建、表的创建及记录的插入:

mysql> create database scoredb;

Query OK, 1 row affected (0.08 sec)

mysql> use scoredb;

Database changed

mysql> CREATE TABLE score(

-> name VARCHAR(4) NOT NULL DEFAULT '',

-> math_score TINYINT NOT NULL DEFAULT 0,

-> chinese_score TINYINT NOT NULL DEFAULT 0,

-> english_score TINYINT NOT NULL DEFAULT 0

-> )engine myisam charset utf8;

Query OK, 0 rows affected, 1 warning (0.08 sec)

mysql> INSERT INTO score VALUES

-> ('赵一', 87, 90, 79),

-> ('钱二', 80, 87, 92),

-> ('孙三', 89, 94, 90),

-> ('李四', 74, 85, 97),

-> ('王五', 79, 71, 91),

-> ('周六', 73, 84, 77),

-> ('吴七', 94, 90, 93),

-> ('郑八', 87, 98, 97),

-> ('冯九', 69, 82, 83),

-> ('陈十', 96, 97, 96);

Query OK, 10 rows affected (0.00 sec)

Records: 10 Duplicates: 0 Warnings: 0

2、限制结果

SELECT 语句返回所有的匹配行,它们可能是指定表中的每个行。如果想要SELECT 语句返回指定的行数,可以使用LIMIT 子句。 LIMIT 接受一个或两个数字的参数,参数必须是一个整数常量。如果给定两个参数,第一个参数指定第一个返回记录行的偏移量,第二个参数指定返回记录行的最大数目。

LIMIT 三种语法,第二种和第三种语法完全等价:

1.

SELECT column1, column2, columnN

FROM table_name

LIMIT [no of rows];

2.

SELECT column1, column2, columnN

FROM table_name

LIMIT [row num] [no of rows];

3.

SELECT column1, column2, columnN

FROM table_name

LIMIT [no of rows] OFFSET [row num];

注:

初始记录行的偏移量为 0 。

示例1,检索前3条记录:

mysql> SELECT name FROM score LIMIT 3;

+------+

| name |

+------+

| 赵一 |

| 钱二 |

| 孙三 |

+------+

3 rows in set (0.00 sec)

示例2,检索从偏移量为5的记录开始后3条记录:

mysql> SELECT name FROM score LIMIT 5, 3;

+------+

| name |

+------+

| 周六 |

| 吴七 |

| 郑八 |

+------+

3 rows in set (0.00 sec)

也可以使用下面这种语法:

mysql> SELECT name FROM score LIMIT 3 OFFSET 5;

+------+

| name |

+------+

| 周六 |

| 吴七 |

| 郑八 |

+------+

3 rows in set (0.00 sec)

在行数不够时,LIMIT 中指定要检索的行数为检索的最大行数。比如我们从第8条记录开始取5条记录,那么我们只能取到3条记录:

mysql> SELECT name FROM score LIMIT 5 OFFSET 7;

+------+

| name |

+------+

| 郑八 |

| 冯九 |

| 陈十 |

+------+

3 rows in set (0.01 sec)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值