|
上篇我们学会了如何创建一个数据库和数据库表,并知道如何向数据库表中添加记录。
那么我们如何从数据库表中检索数据呢?
1、从数据库表中检索信息
实际上,前面我们已经用到了SELECT语句,它用来从数据库表中检索信息。
select语句格式一般为:
SELECT检索关键词FROM被检索的表WHERE检索条件(可选)
以前所使用的“*”表示选择所有的列。
下面继续使用我们在上篇文章中创建的表mytable:
2、查询所有数据:
mysql>select*frommytable;
+----------+------+------------+----------+
|name|sex|birth|birthaddr|
+----------+------+------------+--------+
|abccs|f|1977-07-07|china|
|mary|f|1978-12-12|usa|
|tom|m|1970-09-02|usa|
+----------+------+------------+----------+
3rowinset(0.00sec)
3、修正错误记录:
假如tom的出生日期有错误,应该是1973-09-02,则可以用update语句来修正:
mysql>updatemytablesetbirth="1973-09-02"wherename="tom";
再用2中的语句看看是否已更正过来。
4、选择特定行
上面修改了tom的出生日期,我们可以选择tom这一行来看看是否已经有了变化:
mysql>select*frommytablewherename="tom";
+--------+------+------------+------------+
|name|sex|birth|birthaddr|
+--------+------+------------+------------+
|tom|m|1973-09-02|usa|
+--------+------+------------+------------+
1rowinset(0.06sec)
上面WHERE的参数指定了检索条件。我们还可以用组合条件来进行查询:
mysql>SELECT*FROMmytableWHEREsex="f"ANDbirthaddr="china";
+--------+------+------------+------------+
|name|sex|birth|birthaddr|
+--------+------+------------+------------+
|abccs|f|1977-07-07|china|
+--------+------+------------+------------+
1rowinset(0.06sec)
5、选择特定列
假如你想查看表中的所有人的姓名,则可以这样操作:
mysql>SELECTnameFROMmytable;
+----------+
|name|
+----------+
|abccs|
|mary|
|tom|
+----------+
3rowinset(0.00sec)
如果想列出姓名和性别两列,则可以用逗号将关键词name和birth分开:
myaql>selectname,birthfrommytable;
6、对行进行排序
我们可以对表中的记录按生日大小进行排序:
mysql>SELECTname,birthFROMmytableORDERBYbirth;
+----------+------------+
|name|birth|
+----------+------------+
|tom|1973-09-02|
|abccs|1977-07-07|
|mary|1978-12-12|
+----------+------------+
3rowinset(0.00sec)
我们可以用DESC来进行逆序排序:
mysql>SELECTname,birthFROMmytableORDERBYbirthDESC;
+----------+------------+
|name|birth|
+----------+------------+
|mary|1978-12-12|
|abccs|1977-07-07|
|tom|1973-09-02|
+----------+------------+
3rowinset(0.00sec)
7、行计数
数据库经常要统计一些数据,如表中员工的数目,我们就要用到行计数函数COUNT()。
COUNT()函数用于对非NULL结果的记录进行计数:
mysql>SELECTCOUNT(*)FROMmytable;
+----------+
|COUNT(*)|
+----------+
|3|
+----------+
1rowinset(0.06sec)
员工中男女数量:
mysql>SELECTsex,COUNT(*)FROMmytableGROUPBYsex;
+------+----------+
|sex|COUNT(*)|
+------+----------+
|f|2|
|m|1|
+------+----------+
2rowinset(0.00sec)
注意我们使用了GROUPBY对SEX进行了分组。 |
|
|
|
|
|
|