时间:2021-07-01 10:21:17 帮助过:4人阅读
接着前面的写
举个栗子:我想给这些pet们过身日,我就要知道pet们的名字和他们的生日。我该怎么办?
操作如下:
SELECT name, birth FROM pet;
mysql> SELECT name, birth
    -> FROM pet;
+----------+------------+
| name     | birth      |
+----------+------------+
| Whistler | 1997-12-09 |
| Puffball | 1999-03-30 |
| Fluffy   | 1993-02-04 |
| Claws    | 1994-03-17 |
| Buffy    | 1989-05-13 |
| Fang     | 1990-08-27 |
| Bowser   | 1989-08-31 |
| Chirpy   | 1998-09-11 |
| Slim     | 1996-04-29 |
+----------+------------+
9 rows in set (0.00 sec)
mysql>
这样我就可以给这些pet们过生日了。
再举一个栗子:没有故事,我就是想看一看这些小天使们的主人都有谁?
操作如下:
SELECT owner FROM pet;
mysql> SELECT owner
    -> FROM pet;
+--------+
| owner  |
+--------+
| Gwen   |
| Diane  |
| Harold |
| Gwen   |
| Harold |
| Benny  |
| Diane  |
| Gwen   |
| Benny  |
+--------+
9 rows in set (0.00 sec)
mysql>
you会发现you查询到的 owner 中有好多是重复的诶,这好烦啊。
为了让他们值出现一次 ,加一个关键字 DISTINCT
SELECT DISTINCT owner FROM pet;
mysql> SELECT DISTINCT owner
    -> FROM pet;
+--------+
| owner  |
+--------+
| Gwen   |
| Diane  |
| Harold |
| Benny  |
+--------+
4 rows in set (0.00 sec)
mysql>
这下子看着舒服多了
再带条件举一个栗子:要想查询狗和猫的出生日期
操作如下:
SELECT name, species, birth FROM pet WHERE species = ‘dog‘ OR species = ‘cat‘;
mysql> SELECT name, species, birth
    -> FROM pet
    -> WHERE species = ‘dog‘ OR species = ‘cat‘;
+--------+---------+------------+
| name   | species | birth      |
+--------+---------+------------+
| Fluffy | cat     | 1993-02-04 |
| Claws  | cat     | 1994-03-17 |
| Buffy  | dog     | 1989-05-13 |
| Fang   | dog     | 1990-08-27 |
| Bowser | dog     | 1989-08-31 |
+--------+---------+------------+
5 rows in set (0.00 sec)
mysql>
年轻人,你可能注意到了,前面的栗子中的结果,是没有排好序的。这要是给你的老坂看的话,是要挨批的(虽然你愚蠢的老坂可能看不懂)。所以,就有了ORDER BY 这个关键字
举个栗子:给pet们的出生日期排序。 不要问为什么,无聊。
操作如下:
SELECT name, birth FROM pet ORDER BY birth;
mysql> SELECT name, birth
    -> FROM pet
    -> ORDER BY birth;
+----------+------------+
| name     | birth      |
+----------+------------+
| Buffy    | 1989-05-13 |
| Bowser   | 1989-08-31 |
| Fang     | 1990-08-27 |
| Fluffy   | 1993-02-04 |
| Claws    | 1994-03-17 |
| Slim     | 1996-04-29 |
| Whistler | 1997-12-09 |
| Chirpy   | 1998-09-11 |
| Puffball | 1999-03-30 |
+----------+------------+
9 rows in set (0.18 sec)
mysql>
这样看起来就better了呢(然并卵)。
顺便多一句嘴,有一个ORDER BY BINARY col_name 自己百度自己查。
默认的排序是升序,最小的值在第一行。
if(想要以降序排列){
在排序的列名上增加DESC(降序)关键字
}
操作如下:
SELECT name, birth FROM pet ORDER BY birth DESC;
mysql> SELECT name, birth
    -> FROM pet
    -> ORDER BY birth DESC;
+----------+------------+
| name     | birth      |
+----------+------------+
| Puffball | 1999-03-30 |
| Chirpy   | 1998-09-11 |
| Whistler | 1997-12-09 |
| Slim     | 1996-04-29 |
| Claws    | 1994-03-17 |
| Fluffy   | 1993-02-04 |
| Fang     | 1990-08-27 |
| Bowser   | 1989-08-31 |
| Buffy    | 1989-05-13 |
+----------+------------+
9 rows in set (0.00 sec)
mysql>
还可以对多个列进行排序, 并且可以按不同的方向对不同的列进行排序。(书上写的好复杂啊)
举个例子:按升序对动物的种类进行排序,然后按降序根据生日对各动物种类进行排序(最年轻的动物在最前面)
操作如下:
SELECT name, species, birth FROM pet ORDER BY species, birth DESC;
mysql> SELECT name, species, birth
    -> FROM pet
    -> ORDER BY species, birth DESC;
+----------+---------+------------+
| name     | species | birth      |
+----------+---------+------------+
| Chirpy   | bird    | 1998-09-11 |
| Whistler | bird    | 1997-12-09 |
| Claws    | cat     | 1994-03-17 |
| Fluffy   | cat     | 1993-02-04 |
| Fang     | dog     | 1990-08-27 |
| Bowser   | dog     | 1989-08-31 |
| Buffy    | dog     | 1989-05-13 |
| Puffball | hamster | 1999-03-30 |
| Slim     | snake   | 1996-04-29 |
+----------+---------+------------+
9 rows in set (0.08 sec)
mysql>
我的理解:二级排序,升序排动物五中,降序排年龄。
注意:(书真是为了你们操碎了心)DESC 关键字, 只影响了birth, 不影响species。
先写到这里吧。ヾ(≧O≦)〃嗷~

Mysql学习笔记004
标签:esc 操作 多个 dog binary select des 没有 tle