拼吾爱程序人生

首页 » 数据库编程 » SQL » SQL语言快速入门之三(一)
Systemjudge - 2007-8-6 16:51:00
&;middot;EXCEL快速操作技巧&;middot;CroelDraw教你快速打造珍珠手链&;middot;吸烟有害健康,快速制作禁烟标志&;middot;用Photoshop快速打造美女肖像速写&;middot;超级快速的PS曲线磨皮大法&;middot;Croel Draw教你快速打造珍珠手链&;middot;在Excel快速录入小数的技巧&;middot;EXCEL大量数据快速录入技巧&;middot;
教你简单技巧 快速完成Excel 操作
&;middot;Ruby语言快速入门之对象,方法和类SQL语言快速入门之三
 
 
  我们日常使用SQL语言的工作过程中,使用最多的还是从已经建立好的数据库中查询信息。下面,我们就来详细介绍一下如何使用SQL语言实现各种数据库查询操作。 
 
SELECT…FROM 
  为方便讲解,我们在数据库中创建名为Store_Information的如下数据表。 
 
Store_Information 






Store_Name 

Sales 

Date 


Los Angeles 

$1500 

Jan-10-2000 


San Diego 

$250 

Jan-11-2000 


Los Angeles 

$300 

Jan-12-2000 


Boston 

$700 

Jan-12-2000 
 
  SQL语言中用于数据库查询的最简单的命令就是SELECT…FROM,语法格式为: 
SELECT "column_name" FROM "table_name" 
例如,如果我们希望查询Store_Information数据表中所有的商店名称时,可以使用如下命令: 
SELECT store_nam ROM Store_Information 
查询结果显示为: 
Store_Name 
Los Angeles 
San Diego 
Los Angeles 
Boston 
如果用户希望一次查询多个字段,可以将所要查询的字段名称依次加入SELECT关键字之后,中间用“,”隔开即可。 
 
DISTINCT 
  SELECT关键字支持用户查询数据表中指定字段的所有数据,但是这样有时就会不可避免的出现重复信息。如果用户希望只查询那些具有不同记录值的信息的话,可以使用SQL语言的DISTINCT关键字。语法格式如下: 
SELECT DISTINCT "column_name" 
FROM "table_name" 
例如,我们可以使用以下命令查询Store_Information数据表具有不同记录值的所有记录。 
SELECT DISTINCT Store_Name FROM Store_Information 
查询结果如下: 
Store_Name 
Los Angeles 
San Diego 
Boston 
 
WHERE 
  除了选择具有不同记录值的记录之外,有时我们可能还会需要根据某些条件对数据库中的数据进行查询。例如,我们可能需要查询Store_Information数据表中销售额超过1000美圆的商店。为此,我们可以使用SQL语言的WHERE关键字设定查询条件。语法格式如下: 
SELECT "column_name" 
FROM "table_name" 
WHERE "condition" 
由此,我们可以使用如下命令查询销售额超过1000美圆的商店信息: 
SELECT store_name FROM Store_Information WHERE Sales $#@62; 1000 
查询结果显示为: 
store_name 
Los Angeles 
 
运算函数 
  现在,我们已经了解到在使用SQL语言进行数据库查询操作时可以通过对数值的判断设定灵活的查询条件。为了增强对运算的支持能力,SQL提供了众多实用的运算函数供广大用户使用。例如,我们可以直接在SQL命令中调用SUM或AVG这两个分别用于计算总数和平均数的函数。语法格式如下: 
SELECT "function type"("column_name") 
FROM "table_name" 
如果我们希望查询Store_Information数据表中所有商店的总销售额的话,可以使用如下命令: 
SELECT SUM(Sales) FROM Store_Information 
查询结果显示为: 
SUM(Sales) 
$2750 
 
COUNT 
  除了SUM和AVG函数之外,COUNT函数是SQL语言中另一个较为常用的运算函数。COUNT函数可以用来计算数据表中指定字段所包含的记录数目。语法格式为: 
SELECT COUNT("column_name") 
FROM "table_name" 
例如,如果我们希望查询Store_Information数据表中的有关商店的记录条数时,可以使用如下命令: 
SELECT COUNT(store_name) 
FROM Store_Information 
查询结果显示为: 
Count(store_name) 

COUNT函数可以和DISTINCT关键字一起使用从而可以查询数据表中指定字段中所有具有不同记录值的记录数目。例如,如果我们希望查询Store_Information数据表中不同商店的数目时,可以使用如下命令: 
SELECT COUNT(DISTINCT store_name) 
FROM Store_Information 
查询结果显示为: 
Count(DISTINCT store_name) 

 
GROUP BY 
下面我们来进一步看一下SQL语言中的集合函数。上文中,我们曾使用SUM函数计算所有商店的销售总额,如果我们希望计算每一家商店各自的总销售额时该怎么办呢?要实现这一目的我们需要做两件事:首先,我们需要查询商店名称和销售额两个字段;然后,我们使用SQL语言的GROUP BY命令将销售额按照不同的商店进行分组,从而计算出不同商店的销售总额。GROUP BY命令的语法格式为: 
SELECT "column_name1", SUM("column_name2") 
FROM "table_name" 
GROUP BY "column_name1" 
我们可以使用如下命令实现上述查询目的: 
SELECT store_name, SUM(Sales) 
FROM Store_Information 
GROUP BY store_name 
查询结果显示为: 
store_name SUM(Sales) 
Los Angeles $1800 
San Diego $250 
Boston $700 
小注: 
GROUP BY关键字一般应用于同时查询多个字段并对字段进行算术运算的SQL命令中。 
 
HAVING 
用户在使用SQL语言的过程中可能希望解决的另一个问题就是对由sum或其它集合函数运算结果的输出进行限制。例如,我们可能只希望看到Store_Information数据表中销售总额超过1500美圆的商店的信息,这时我们就需要使用HAVING从句。语法格式为: 
SELECT "column_name1", SUM("column_name2") 
FROM "table_name" 
GROUP BY "column_name1" 
HAVING (arithematic function condition) 
(GROUP BY从句可选) 
由此,我们可以使用如下命令实现上述查询目的: 
SELECT store_name, SUM(sales) 
FROM Store_Information 
GROUP BY store_name 
HAVING SUM(sales) $#@62; 1500 
查询结果显示为: 
store_name SUM(Sales) 
Los Angeles $1800 
小注: 
SQL语言中设定集合函数的查询条件时使用HAVING从句而不是WHERE从句。通常情况下,HAVING从句被放置在SQL命令的结尾处。

 您可能对 [SQL] 的这些文章也感兴趣:

NHibernate 2.0带来了很多新特性
数据库访问抽象类实现项目数据库灵活切换
使用Transact-SQL进行数据导入导出的方法详解
SQL Prompt 3.8,SQL Refator 的发布,破解和下载
破解SQL Prompt3
Castle-Active Record的使用方法
Castle ActiveRecord使用笔记
数据库开发的持续集成 - 方法和流程
数据库开发的持续集成 - Liquibase的简介和应用
微软发布3款SQL Injection攻击检测工具
远程数据库管理三思而后行
基于.NET平台开源的数据持久框架:NHibernate 2.0.0.Beta1发布
1
查看完整版本: SQL语言快速入门之三(一)
Modify by pin5i DZNT_ExpandPackage 2.1.3293 2007-2009 pin5i.com
 Total Unique Visitors: