注册 | 登录
收藏 | 帮助
热门文章
编辑推荐
相关文章  
如何根据名称识别计算机病毒
教你如何防止脚本病毒执行的通用
在网吧如何防止病毒和快速杀毒
如何判断电脑是否感染了病毒
特络伊木马如何利用文件关联和设
深入揭秘木马是如何盗取QQ密码的
从Melissa到Zotob:Windows蠕虫1
如何知道你的电脑是否含有病毒
杀毒软件如何被XP SP2的安全中心
教你如何手工剿灭QQ广告弹出的木
您现在的位置: 顶尖设计 >> IT学院 >> 编程开发 >> Delphi >> 文章正文
如何从MySQL数据库表中检索数据
作者:zaowei21  来源:csdn  点击:  更新:2006-12-19
简介:
那么我们如何从数据库表中检索数据呢?

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






  • 上一篇文章:
  • 下一篇文章:
  • 分享此文:该页面添加到 Mister Wong 添加到雅虎Yahoo!收藏 Add to:Del.icio.us Post to Furl Digg this 添加到Google书签 reddit spurl blogmarks 365Key 评论  收藏  分享  打印
     我来说两句
    姓名:       验证码:   
    主页: 
    评分: 1分 2分 3分 4分 5分
    本频道近期热评文章:
      关于我们 | 联系我们 | 站点地图 | 广告投放 | 友情链接 | 在线留言 | 版权申明
    版权所有 © 2004-2007 顶尖设计(bobd.cn)
    未经授权禁止转载,摘编,复制本站内容或建立镜像. 沪ICP备07504942号 
    网络110
    报警服务