电脑软硬件应用网
当前位置: 电脑软硬件应用网 > 设计学院 > 网络编程 > 数据库 > 正文
SQL分组实例使用GROUP BY做示例
SQL分组实例使用GROUP BY做示例
2010-4-4 14:26:59  文/佚名   出处:电脑软硬件应用网   

学习SQL的朋友都知道GROUP BY是用于数据统计的分组功能,本文使用GROUP BY做一个示例。

GROUP BY 语法:

SELECT column_name, function(column_name)
FROM table_name
WHERE column_name operator value
GROUP BY column_name

实例

表结构如下:

BookComments

列 名

类型

长度

是否允许为空

说明

CommentsNo

bigint

8

主键 非负 自增

BookNo

varchar

50

外键 book表主键

Created

Time

 

Datetime

 

评论生成时间

Uid

Varchar

10

评论人ID

Text

Text

 

评论内容

BookList表:

列 名

类 型

大 小

是否允许为空

说明

BookNo

Varchar

10

书号 主键

BookName

Varchar

200

书名

Auther

Varchar

200

作者

Introduction

Text

 

简介

 

       Connection conn = DatabaseConn.getConnection(); //此处调用的是前面篇章中的连接池的方法
       Statement stm = conn.createStatement();
      ResultSet result=stm.executeQuery("" +
        "select BookComments.BookNo,BookList.BookName,BookList.Auther," +
        "COUNT(BookComments.BookNo) AS  CountNo " +
        "from BookComments,BookList " +
        "where BookList.BookNo=BookComments.BookNo " +
        "GROUP BY BookComments.BookNo,BookList.BookName,BookList.Auther " +
        "order by CountNo desc ");
         

实现功能:统计图书的评论数,然后按照从多到少的顺序排列起来,首先使用BookNo将BookComments,BookList连接起来,然后将BookComments.BookNo,BookList.BookName,BookList.Auther这些列聚组,COUNT(BookComments.BookNo) AS  CountNo统计不同的BookNo出现的次数,即实现记录评论的数量的目的

  • 上一篇文章:

  • 下一篇文章:
  • 最新热点 最新推荐 相关文章
    详解如何查找SQL数据库自增ID值不连…
    SQL重建索引重新释放掉字段因更改而…
    SQL教程:SQL Server备份和灾难恢复
    SQL注入攻击:防御和检查SQL注入的手…
    SQL Server日志文件丢失 进行恢复方…
    解决安装SQL Server出现command lin…
    Mysql数据库名和表名在不同系统下的…
    mysql全文搜索:sql的写法
    Windows 7下如何安装SQL Server 200…
    详解SQL数据仓库之时间维度创建的开…
    关于45IT | About 45IT | 联系方式 | 版权声明 | 网站导航 |

    Copyright © 2003-2011 45IT. All Rights Reserved 浙ICP备09049068号