MySQL學習筆記 四

2021-08-23 15:32:41 字數 3014 閱讀 5839

上篇我們學會了如何建立乙個資料庫和資料庫表,並知道如何向資料庫表中新增記錄。

那麼我們如何從資料庫表中檢索資料呢?

1、從資料庫表中檢索資訊

實際上,前面我們已經用到了select語句,它用來從資料庫表中檢索資訊。

select語句格式一般為:

以前所使用的「 * 」表示選擇所有的列。

2、查詢所有資料:

mysql> select * from mytable;

+----------+------+------------+----------+

| name | *** | birth | birthaddr |

+----------+------+------------+--------+

| abccs|f| 1977-07-07 | china |

| mary |f| 1978-12-12 | usa |

| tom |m| 1970-09-02 | usa |

+----------+------+------------+----------+

3 row in set (0.00 sec)

3、修正錯誤記錄:

假如tom的出生日期有錯誤,應該是1973-09-02,則可以用update語句來修正:

mysql> update mytable set birth = "1973-09-02" where name = "tom";

再用2中的語句看看是否已更正過來。

4、選擇特定行

上面修改了tom的出生日期,我們可以選擇tom這一行來看看是否已經有了變化:

mysql> select * from mytable where name = "tom";

+--------+------+------------+------------+

| name |*** | birth | birthaddr |

+--------+------+------------+------------+

| tom|m| 1973-09-02 | usa|

+--------+------+------------+------------+

1 row in set (0.06 sec)

上面where的引數指定了檢索條件。我們還可以用組合條件來進行查詢:

mysql> select * from mytable where *** = "f" and birthaddr = "china";

+--------+------+------------+------------+

| name |*** | birth | birthaddr |

+--------+------+------------+------------+

| abccs |f| 1977-07-07 | china |

+--------+------+------------+------------+

1 row in set (0.06 sec)

5、 選擇特定列

假如你想檢視表中的所有人的姓名,則可以這樣操作:

mysql> select name from mytable;

+----------+

| name |

+----------+

| abccs |

| mary |

| tom |

+----------+

3 row in set (0.00 sec)

myaql> select name,birth from mytable;

6、對行進行排序

我們可以對錶中的記錄按生日大小進行排序:

mysql> select name, birth from mytable order by birth;

+----------+------------+

| name | birth |

+----------+------------+

| tom | 1973-09-02 |

| abccs| 1977-07-07 |

| mary | 1978-12-12 |

+----------+------------+

3 row in set (0.00 sec)

我們可以用desc來進行逆序排序:

mysql> select name, birth from mytable order by birth desc;

+----------+------------+

| name | birth |

+----------+------------+

| mary | 1978-12-12 |

| abccs| 1977-07-07 |

| tom | 1973-09-02 |

+----------+------------+

3 row in set (0.00 sec)

7、 行計數

資料庫經常要統計一些資料,如表中員工的數目,我們就要用到行計數函式count()。

count()函式用於對非null結果的記錄進行計數:

mysql> select count(*) from mytable;

+----------+

| count(*) |

+----------+

|3 |

+----------+

1 row in set (0.06 sec)

員工中男女數量:

mysql> select ***, count(*) from mytable group by ***;

+------+----------+

| *** | count(*) |

+------+----------+

| f|2 |

| m|1 |

+------+----------+

2 row in set (0.00 sec)

注意我們使用了group by對***進行了分組。

MySQL學習筆記(四)

mysql支援regexp的正規表示式 找出以a d 為開頭的sname select from stu where sname regexp a d 接下來介紹一下與時間有關的函式。獲取當前時分秒 獲取當前的年月日 獲取當前的時間,年月日時分秒 返回日期date是星期幾 1 星期天,2 星期一,7...

mysql學習筆記(四)

23資料備份和恢復 1 備份 使用mysqldump命令備份 mysqldump u user h localhost p password dbname table1,table2 filename.sql 備份所有資料庫 mysqldump u user h localhost p all da...

MySQL學習筆記 四

補充知識,後續可能會用到 1,auto increment關鍵字 在尾部新增,放在主鍵後面 設定變數為自增變數 2,一般情況下,mysql的預設是以 作為結束執行語句,與觸發器中需要的分行起衝突 解決辦法 delimiter 可以將結束符號變成 當觸發器建立後,可用delimiter 還原 一,觸發...