当前位置:数据库 > MySQL >>

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

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

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

  select语句格式一般为:

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

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

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

  2、查询所有数据:

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

  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进行了分组。

  

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

更多MySQL疑问解答:
如何将SQL 2005中的数据实时同步到MYSQL中
java对mysql数据库备份后,它的备份记录怎么显示查出来啊。 求告诉、
如何查询mysql表中的相似度。
mysql 查看表有没有被锁
mysql front 和mysql
mysql 建表 问题 求解答 为什么不能创建表
mysql查询问题
mysql中怎么让union all不打乱顺序
mysql中修改表字段
mysql用户操作表权限的问题(java)
mysql 如何在查询时防止插入
mysql中的 insert into select 问题,想在同个服务器下复制不同数据库的表的内容,在线求方法,谢谢
mysql中的concat用法!
使用mysql中,我想把表product的数据备份到同个服务器创建一个新表出来,刚学习mysql,用SELECT INTO 出错
mysql delete语句删除指定列的指定关键字的所以数据
Oracle
MySQL
Access
SQLServer
DB2
Excel
SQLite
SYBASE
Postgres
如果你遇到数据库难题:
请访问www.zzzyk.com 试试
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,