新聞中心

站在用戶的角度思考問題,與客戶深入溝通,找到平定網(wǎng)站設(shè)計與平定網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:網(wǎng)站制作、成都做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣、申請域名、虛擬空間、企業(yè)郵箱。業(yè)務(wù)覆蓋平定地區(qū)。
SELECT 的語法格式如下:
SELECT
{* | <字段列名>}
[
FROM <表 1>, <表 2>…
[WHERE <表達式>
[GROUP BY
[HAVING [{ }…]]
[ORDER BY ]
[LIMIT[,] ]
]
其中,各條子句的含義如下:
-
{*|<字段列名>}包含星號通配符的字段列表,表示所要查詢字段的名稱。 -
<表 1>,<表 2>…,表 1 和表 2 表示查詢數(shù)據(jù)的來源,可以是單個或多個。 -
WHERE <表達式>是可選項,如果選擇該項,將限定查詢數(shù)據(jù)必須滿足該查詢條件。 -
GROUP BY< 字段 >,該子句告訴 MySQL 如何顯示查詢出來的數(shù)據(jù),并按照指定的字段分組。 -
[ORDER BY< 字段 >],該子句告訴 MySQL 按什么樣的順序顯示查詢出來的數(shù)據(jù),可以進行的排序有升序(ASC)和降序(DESC),默認情況下是升序。 -
[LIMIT[,該子句告訴 MySQL 每次顯示查詢出來的數(shù)據(jù)條數(shù)。,] ]
下面先介紹一些簡單的 SELECT 語句,關(guān)于 WHERE、GROUP BY、ORDER BY 和 LIMIT 等限制條件,后面我們會一一講解。
查詢表中所有字段
查詢所有字段是指查詢表中所有字段的數(shù)據(jù)。MySQL 提供了以下 2 種方式查詢表中的所有字段。
- 使用“*”通配符查詢所有字段
- 列出表的所有字段
1)使用“*”查詢表的所有字段
SELECT 可以使用“*”查找表中所有字段的數(shù)據(jù),語法格式如下:
SELECT * FROM 表名;
使用“*”查詢時,只能按照數(shù)據(jù)表中字段的順序進行排列,不能改變字段的排列順序。
例 1
從 tb_students_info 表中查詢所有字段的數(shù)據(jù),SQL 語句和運行結(jié)果如下所示。
mysql> use test_db; Database changed mysql> SELECT * FROM tb_students_info; +----+--------+---------+------+------+--------+------------+ | id | name | dept_id | age | sex | height | login_date | +----+--------+---------+------+------+--------+------------+ | 1 | Dany | 1 | 25 | F | 160 | 2015-09-10 | | 2 | Green | 3 | 23 | F | 158 | 2016-10-22 | | 3 | Henry | 2 | 23 | M | 185 | 2015-05-31 | | 4 | Jane | 1 | 22 | F | 162 | 2016-12-20 | | 5 | Jim | 1 | 24 | M | 175 | 2016-01-15 | | 6 | John | 2 | 21 | M | 172 | 2015-11-11 | | 7 | Lily | 6 | 22 | F | 165 | 2016-02-26 | | 8 | Susan | 4 | 23 | F | 170 | 2015-10-01 | | 9 | Thomas | 3 | 22 | M | 178 | 2016-06-07 | | 10 | Tom | 4 | 23 | M | 165 | 2016-08-05 | +----+--------+---------+------+------+--------+------------+ 10 rows in set (0.26 sec)
結(jié)果顯示,使用“*”通配符時,將返回所有列,數(shù)據(jù)列按照創(chuàng)建表時的順序顯示。
2)列出表的所有字段
SELECT 關(guān)鍵字后面的字段名為需要查找的字段,因此可以將表中所有字段的名稱跟在 SELECT 關(guān)鍵字后面。如果忘記了字段名稱,可以使用 DESC 命令查看表的結(jié)構(gòu)。
有時,由于表的字段比較多,不一定能記得所有字段的名稱,因此該方法很不方便,不建議使用。
例 2
查詢 tb_students_info 表中的所有數(shù)據(jù),SQL 語句還可以書寫如下:
SELECT id,name,dept_id,age,sex,height,login_date FROM tb_students_info;
運行結(jié)果和例 1 相同。
這種查詢方式比較靈活,如果需要改變字段顯示的順序,只需調(diào)整 SELECT 關(guān)鍵字后面的字段列表順序即可。
雖然列出表的所有字段的方式比較靈活,但是查詢所有字段時通常使用“*”通配符。使用“*”這種方式比較簡單,尤其是表中的字段很多的時候,這種方式的優(yōu)勢更加明顯。當(dāng)然,如果需要改變字段顯示的順序,可以選擇列出表的所有字段。
查詢表中指定的字段
查詢表中的某一個字段的語法格式為:
SELECT < 列名 > FROM < 表名 >;
例 3
查詢 tb_students_info 表中 name 列所有學(xué)生的姓名,SQL 語句和運行結(jié)果如下所示。
mysql> SELECT name FROM tb_students_info; +--------+ | name | +--------+ | Dany | | Green | | Henry | | Jane | | Jim | | John | | Lily | | Susan | | Thomas | | Tom | +--------+ 10 rows in set (0.00 sec)
輸出結(jié)果顯示了 tb_students_info 表中 name 字段下的所有數(shù)據(jù)。
使用 SELECT 聲明可以獲取多個字段下的數(shù)據(jù),只需要在關(guān)鍵字 SELECT 后面指定要查找的字段名稱,不同字段名稱之間用逗號“,”分隔開,最后一個字段后面不需要加逗號,語法格式如下:
SELECT <字段名1>,<字段名2>,…,<字段名n> FROM <表名>;
例 4
從 tb_students_info 表中獲取 id、name 和 height 三列,SQL 語句和運行結(jié)果如下所示。
mysql> SELECT id,name,height
-> FROM tb_students_info;
+----+--------+--------+
| id | name | height |
+----+--------+--------+
| 1 | Dany | 160 |
| 2 | Green | 158 |
| 3 | Henry | 185 |
| 4 | Jane | 162 |
| 5 | Jim | 175 |
| 6 | John | 172 |
| 7 | Lily | 165 |
| 8 | Susan | 170 |
| 9 | Thomas | 178 |
| 10 | Tom | 165 |
+----+--------+--------+
10 rows in set (0.00 sec)
輸出結(jié)果顯示了 tb_students_info 表中 id、name 和 height 三個字段下的所有數(shù)據(jù)。
新聞標題:MySQLSELECT:數(shù)據(jù)表查詢語句
網(wǎng)頁URL:http://m.5511xx.com/article/cdgedjp.html


咨詢
建站咨詢
