当前位置:操作系统 > Unix/Linux >>

如何从MySQL数据库表中检索数据

1、从数据库表中检索信息

  实际上,前面我们已经用到了SELECT语句,它用来从数据库表中检索信息。

  select语句格式一般为:

  SELECT 检索关键词 FROM 被检索的表 WHERE 检索条件(可选)

  以前所使用的“ * ”表示选择所有的列。

  下面继续使用我们在上篇文章中创建的表mytable。

  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)

  如果想列出姓名和性别两列,则可以用逗号将关键词name和birth分开: 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对SEX进行了分组。

  

上一个:学习MySQL多表操作和备份处理
下一个:"函数递归"实现php和MySQL动态树型菜单

更多Unix/Linux疑问解答:
路由原理介绍
子网掩码快速算法
改变网络接口的速度和协商方式的工具miitool和ethtool
Loopback口的作用汇总
OSPF的童话
增强的ACL修改功能
三层交换机和路由器的比较
用三层交换机组建校园网
4到7层交换识别内容
SPARC中如何安装Linux系统(2)
SPARC中如何安装Linux系统(1)
用Swatch做Linux日志分析
实战多种Linux操作系统共存
浅析Linux系统帐户的管理和审计
Linux2.6对新型CPU的支持(2)
电脑通通透
玩转网络
IE/注册表
DOS/Win9x
Windows Xp
Windows 2000
Windows 2003
Windows Vista
Windows 2008
Windows7
Unix/Linux
苹果机Mac OS
windows8
安卓/Android
Windows10
如果你遇到操作系统难题:
访问www.zzzyk.com 试试
CopyRight © 2022 站长资源库 编程知识问答 zzzyk.com All Rights Reserved
部分文章来自网络,