上一篇文章我们主要教会大家的是正确创建一个MySQL数据库与数据库表的实际操作步骤,以及并知道如何正确的向数据库表中添加相关的记录。今天那么我们就像大家讲讲从数据库表中检索数据的实际操作步骤?
MySQL入门学习1、从数据库表中检索信息
实际上,前面我们已经用到了SELECT语句,它用来从MySQL数据库表中检索信息。
select语句格式一般为:
SELECT 检索关键词 FROM 被检索的表 WHERE 检索条件(可选)
以前所使用的“ * ”表示选择所有的列。
下面继续使用我们在上篇文章中创建的表mytable:
2、查询所有数据:
MySQL(和PHP搭配之最佳组合)> select * from mytable;
+----------+------+------------+----------+
| name | sex | 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)
- 1.
- 2.
- 3.
- 4.
- 5.
- 6.
- 7.
- 8.
- 9.
3、修正错误记录:
假如tom的出生日期有错误,应该是1973-09-02,则可以用update语句来修正:
MySQL(和PHP搭配之最佳组合)> update mytable set birth = "1973-09-02" where name = "tom";
- 1.
再用2中的语句看看是否已更正过来。
MySQL入门学习4、选择特定行
上面修改了tom的出生日期,我们可以选择tom这一行来看看是否已经有了变化:
MySQL(和PHP搭配之最佳组合)> select * from mytable where name = "tom";
+--------+------+------------+------------+
| name |sex | birth | birthaddr |
+--------+------+------------+------------+
| tom |m | 1973-09-02 | usa |
+--------+------+------------+------------+
1 row in set (0.06 sec)
- 1.
- 2.
- 3.
- 4.
- 5.
- 6.
- 7.
上面WHERE的参数指定了检索条件。我们还可以用组合条件来进行查询:
MySQL(和PHP搭配之最佳组合)> SELECT * FROM mytable WHERE sex = "f" AND birthaddr = "china";
+--------+------+------------+------------+
| name |sex | birth | birthaddr |
+--------+------+------------+------------+
| abccs |f | 1977-07-07 | china |
+--------+------+------------+------------+
1 row in set (0.06 sec)
- 1.
- 2.
- 3.
- 4.
- 5.
- 6.
- 7.
5、 选择特定列
假如你想查看表中的所有人的姓名,则可以这样操作:
MySQL(和PHP搭配之最佳组合)> SELECT name FROM mytable;
+----------+
| name |
+----------+
| abccs |
| mary |
| tom |
+----------+
3 row in set (0.00 sec)
- 1.
- 2.
- 3.
- 4.
- 5.
- 6.
- 7.
- 8.
- 9.
如果想列出姓名和性别两列,则可以用逗号将关键词name和birth分开:
myaql> select name,birth from mytable;
- 1.
6、对行进行排序
我们可以对表中的记录按生日大小进行排序:
MySQL(和PHP搭配之最佳组合)> 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)
- 1.
- 2.
- 3.
- 4.
- 5.
- 6.
- 7.
- 8.
- 9.
我们可以用DESC来进行逆序排序:
MySQL(和PHP搭配之最佳组合)> 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)
- 1.
- 2.
- 3.
- 4.
- 5.
- 6.
- 7.
- 8.
- 9.
7、 行计数
MySQL数据库经常要统计一些数据,如表中员工的数目,我们就要用到行计数函数COUNT()。 COUNT()函数用于对非NULL结果的记录进行计数:
MySQL(和PHP搭配之最佳组合)> SELECT COUNT(*) FROM mytable;
+----------+
| COUNT(*) |
+----------+
| 3 |
+----------+
1 row in set (0.06 sec)
- 1.
- 2.
- 3.
- 4.
- 5.
- 6.
- 7.
员工中男女数量:
MySQL(和PHP搭配之最佳组合)> SELECT sex, COUNT(*) FROM mytable GROUP BY sex;
+------+----------+
| sex | COUNT(*) |
+------+----------+
| f | 2 |
| m | 1 |
+------+----------+
2 row in set (0.00 sec)
- 1.
- 2.
- 3.
- 4.
- 5.
- 6.
- 7.
- 8.
注意我们使用了GROUP BY对SEX进行了分组。 以上的相关内容就是对MySQL数据库的介绍,望你能有所收获。
【编辑推荐】