当前位置: 首页 > 图文教程 > 数据库 > MYSQL > 如何从MySQL数据库表中检索数据

MYSQL
Mysql教程:如何修改默认密码
SQL Server教程:三种导入导出数据使用方式比较
Mysql技巧:指定只监听某个特定地址的设置方法
Mysql教程:1067错误解决方法
解决Mysql 错误:cannot create windows service for
解决Mysql连接过多错误的方法
Mysql教程:数据库字符替换和replace函数的使用
Mysql教程:性能跟踪语句
Mysql教程:对MySQL中的锁机制的总结
Mysql教程:介绍TIMESTAMP时间戳的使用
Mysql教程:将txt文本中的数据轻松导入MySQL表中的方法
MySQL:小编浅谈MySQL中的Geometry类
大型门户网站架构设计的可伸缩性
MYSQL教程:缓慢的drop table 操作
优化SQL语句需要注意的4点
MySQL前途难料开源数据库下一个领袖是谁?
网站Access数据库文件更安全的3种措施
sql xml入门:xpath和xquery
QA里执行sp_attach_db出现错误1813
MySQL中文模糊检索问题解决方法

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-17   浏览: 73 ::
收藏到网摘: n/a

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

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

select语句格式一般为:

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

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

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

2、查询所有数据:


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 |sex | birth | birthaddr |
  +--------+------+------------+------------+
  | tom |m | 1973-09-02 | usa |
  +--------+------+------------+------------+
  1 row in set (0.06 sec)

上面WHERE的参数指定了检索条件。我们还可以用组合条件来进行查询:

以下为引用的内容:

  mysql> 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)

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 sex, COUNT(*) FROM mytable GROUP BY sex;
  +------+----------+
  | sex | COUNT(*) |
  +------+----------+
  | f | 2 |
  | m | 1 |
  +------+----------+
  2 row in set (0.00 sec)

注意我们使用了GROUP BY对SEX进行了分组。