SQL技术第十一章总结数据

<html xmlns:v="urn:schemas-microsoft-com:vml"
xmlns:o="urn:schemas-microsoft-com:office:office"
xmlns:w="urn:schemas-microsoft-com:office:word"
xmlns="http://www.w3.org/TR/REC-html40">

<head>
<meta http-equiv=Content-Type content="text/html; charset=gb2312">
<meta name=ProgId content=Word.Document>
<meta name=Generator content="Microsoft Word 11">
<meta name=Originator content="Microsoft Word 11">
<link rel=File-List href="第十一章总结数据.files/filelist.xml">
<title>第十一章总结数据</title>
<!--[if gte mso 9]><xml>
 <o:DocumentProperties>
  <o:Author>china</o:Author>
  <o:LastAuthor>china</o:LastAuthor>
  <o:Revision>2</o:Revision>
  <o:TotalTime>3</o:TotalTime>
  <o:Created>2010-11-11T04:13:00Z</o:Created>
  <o:LastSaved>2010-11-11T04:16:00Z</o:LastSaved>
  <o:Pages>1</o:Pages>
  <o:Words>246</o:Words>
  <o:Characters>1404</o:Characters>
  <o:Company>Microsoft</o:Company>
  <o:Lines>11</o:Lines>
  <o:Paragraphs>3</o:Paragraphs>
  <o:CharactersWithSpaces>1647</o:CharactersWithSpaces>
  <o:Version>11.9999</o:Version>
 </o:DocumentProperties>
</xml><![endif]--><!--[if gte mso 9]><xml>
 <w:WordDocument>
  <w:SpellingState>Clean</w:SpellingState>
  <w:GrammarState>Clean</w:GrammarState>
  <w:ValidateAgainstSchemas/>
  <w:SaveIfXMLInvalid>false</w:SaveIfXMLInvalid>
  <w:IgnoreMixedContent>false</w:IgnoreMixedContent>
  <w:AlwaysShowPlaceholderText>false</w:AlwaysShowPlaceholderText>
  <w:Compatibility>
   <w:UseFELayout/>
  </w:Compatibility>
  <w:BrowserLevel>MicrosoftInternetExplorer4</w:BrowserLevel>
 </w:WordDocument>
</xml><![endif]--><!--[if gte mso 9]><xml>
 <w:LatentStyles DefLockedState="false" LatentStyleCount="156">
 </w:LatentStyles>
</xml><![endif]-->
<style>
<!--
 /* Font Definitions */
 @font-face
 {font-family:宋体;
 panose-1:2 1 6 0 3 1 1 1 1 1;
 mso-font-alt:SimSun;
 mso-font-charset:134;
 mso-generic-font-family:auto;
 mso-font-pitch:variable;
 mso-font-signature:3 680460288 22 0 262145 0;}
@font-face
 {font-family:"\@宋体";
 panose-1:2 1 6 0 3 1 1 1 1 1;
 mso-font-charset:134;
 mso-generic-font-family:auto;
 mso-font-pitch:variable;
 mso-font-signature:3 680460288 22 0 262145 0;}
 /* Style Definitions */
 p.MsoNormal, li.MsoNormal, div.MsoNormal
 {mso-style-parent:"";
 margin:0cm;
 margin-bottom:.0001pt;
 mso-pagination:widow-orphan;
 font-size:12.0pt;
 font-family:宋体;
 mso-bidi-font-family:宋体;
 color:green;}
pre
 {font-size:12.0pt;
 font-family:宋体;
 mso-bidi-font-family:宋体;
 color:green;}
span.SpellE
 {mso-style-name:"";
 mso-spl-e:yes;}
span.GramE
 {mso-style-name:"";
 mso-gram-e:yes;}
@page Section1
 {size:595.3pt 841.9pt;
 margin:72.0pt 90.0pt 72.0pt 90.0pt;
 mso-header-margin:42.55pt;
 mso-footer-margin:49.6pt;
 mso-paper-source:0;}
div.Section1
 {page:Section1;}
-->
</style>
<!--[if gte mso 10]>
<style>
 /* Style Definitions */
 table.MsoNormalTable
 {mso-style-name:普通表格;
 mso-tstyle-rowband-size:0;
 mso-tstyle-colband-size:0;
 mso-style-noshow:yes;
 mso-style-parent:"";
 mso-padding-alt:0cm 5.4pt 0cm 5.4pt;
 mso-para-margin:0cm;
 mso-para-margin-bottom:.0001pt;
 mso-pagination:widow-orphan;
 font-size:10.0pt;
 font-family:"Times New Roman";
 mso-fareast-font-family:"Times New Roman";
 mso-ansi-language:#0400;
 mso-fareast-language:#0400;
 mso-bidi-language:#0400;}
</style>
<![endif]--><!--[if gte mso 9]><xml>
 <o:shapedefaults v:ext="edit" spidmax="2050"/>
</xml><![endif]--><!--[if gte mso 9]><xml>
 <o:shapelayout v:ext="edit">
  <o:idmap v:ext="edit" data="1"/>
 </o:shapelayout></xml><![endif]-->
</head>

<body lang=ZH-CN style='tab-interval:21.0pt'>

<div class=Section1><pre><span lang=EN-US><o:p> </o:p></span></pre><pre
style='text-align:center'><span style='font-size:22.0pt;color:red'>第十一章 总结数据<span
lang=EN-US><o:p></o:p></span></span></pre><pre>列函数介绍:表中的数据是使用列函数进行总结的。列函数会检查出列中的所有数据,这里的总结总是在结果表中的一个<span
class=GramE>单行上</span>进行的。</pre><pre style='text-align:center'><span
style='color:#FF6600'>第一节 总结一个列中的所有数据<span lang=EN-US><o:p></o:p></span></span></pre><pre>列可以是一个行函数,也可以是存储在磁盘上的一个数据列。随后可以使用列函数对这个<span
class=GramE>列进行</span>操作。</pre><pre style='text-align:center'><span
style='color:red'>第二节 列函数清单<span lang=EN-US><o:p></o:p></span></span></pre><pre>列函数也被称为聚合函数或者组函数。主要有七种列函数</pre><pre><span
lang=EN-US>null</span>被一个列函数之外的所有列函数忽略</pre><pre>列函数忽略了数据中的<span lang=EN-US>NULL</span>,列函数会它们不存在一样处理。这种列函数的一个例就是<span
lang=EN-US>count(*)</span>函数。来计算表中所有的行。</pre><pre><span lang=EN-US>max </span>列中最大值</pre><pre><span
lang=EN-US>min<span style='mso-spacerun:yes'>  </span></span>列中最小值</pre><pre><span
lang=EN-US>count(*)<span style='mso-spacerun:yes'>  </span></span>计算所有的行数</pre><pre><span
lang=EN-US>count(column)<span style='mso-spacerun:yes'>  </span></span>计算不为<span
lang=EN-US>NULL</span>的某一列的所有行数</pre><pre><span lang=EN-US>sum<span style='mso-spacerun:yes'>  </span></span>求列中所有值的<span
class=GramE>和</span></pre><pre><span class=SpellE><span lang=EN-US>avg</span></span><span
lang=EN-US><span style='mso-spacerun:yes'>  </span></span>平均数</pre><pre
style='text-align:center'><span style='color:red'>第三节 找出最大值和最小值<span
lang=EN-US><o:p></o:p></span></span></pre><pre><span class=GramE><span
lang=EN-US>select</span></span><span lang=EN-US> min(<span class=SpellE>credit_limit</span>),</span></pre><pre><span
class=GramE><span lang=EN-US>max(</span></span><span class=SpellE><span
lang=EN-US>credit_limit</span></span><span lang=EN-US>),</span></pre><pre><span
class=GramE><span lang=EN-US>max(</span></span><span class=SpellE><span
lang=EN-US>first_name</span></span><span lang=EN-US>),</span></pre><pre><span
class=GramE><span lang=EN-US>from</span></span><span lang=EN-US> 1_employees;</span></pre><pre
style='text-align:center'><b style='mso-bidi-font-weight:normal'><span
style='color:red'>第四节 使用包含列函数的<span lang=EN-US>where</span>子句<span lang=EN-US><o:p></o:p></span></span></b></pre><pre><span
lang=EN-US>where</span>子句将会先被处理。在上一节中的最后加上:</pre><pre><span class=GramE><span
lang=EN-US>where</span></span><span lang=EN-US> <span class=SpellE>employ_id</span> between 202 and 206</span></pre><pre
style='text-align:center'><b style='mso-bidi-font-weight:normal'><span
style='color:red'>第五节 找出最大值和最小值的行<span lang=EN-US><o:p></o:p></span></span></b></pre><pre>任务:找出有最小信贷的雇员</pre><pre><span
class=GramE><span lang=EN-US>select</span></span><span lang=EN-US> <span
class=SpellE>employee_id</span>,</span></pre><pre><span class=SpellE><span
lang=EN-US>first_name</span></span><span lang=EN-US>,</span></pre><pre><span
class=SpellE><span lang=EN-US>last_name</span></span><span lang=EN-US>,</span></pre><pre><span
class=SpellE><span lang=EN-US>credit_limit</span></span><span lang=EN-US>,</span></pre><pre><span
class=GramE><span lang=EN-US>from</span></span><span lang=EN-US> 1_employees</span></pre><pre><span
class=GramE><span lang=EN-US>where</span></span><span lang=EN-US> <span
class=SpellE>credit_limit</span>=(select min(<span class=SpellE>credit_limit</span>) from 1_employees)</span></pre><pre><span
class=GramE><span lang=EN-US>order</span></span><span lang=EN-US> by <span
class=SpellE>employee_id</span>;</span></pre><pre><b style='mso-bidi-font-weight:
normal'><span style='color:red'>第六节 对行和数据计数<span lang=EN-US><o:p></o:p></span></span></b></pre><pre><span
class=GramE><span lang=EN-US>select</span></span><span lang=EN-US> count(*),</span></pre><pre><span
class=GramE><span lang=EN-US>count(</span></span><span class=SpellE><span
lang=EN-US>last_name</span></span><span lang=EN-US>),</span></pre><pre><span
class=GramE><span lang=EN-US>from</span></span><span lang=EN-US> 1_employees;</span></pre><pre><b
style='mso-bidi-font-weight:normal'><span style='color:red'>第七节 零计数<span
lang=EN-US><o:p></o:p></span></span></b></pre><pre>在<span class=SpellE><span
lang=EN-US>ACcess</span></span>中,对只包含<span lang=EN-US>NULL</span>的<span
class=GramE>列使用</span>所有的列函数。我们会看到,<span lang=EN-US>count(column)</span>函数的结果是一个零。而其它列函数的结果都是<span
lang=EN-US>NULL</span>。</pre><pre><b style='mso-bidi-font-weight:normal'><span
style='color:red'>第八节 对列中<span class=GramE>相异值</span>计数<span lang=EN-US><o:p></o:p></span></span></b></pre><pre><span
class=GramE><span lang=EN-US>select</span></span><span lang=EN-US> distinct <span
class=SpellE>manager_id</span></span></pre><pre><span class=GramE><span
lang=EN-US>into</span></span><span lang=EN-US> step1</span></pre><pre><span
class=GramE><span lang=EN-US>from</span></span><span lang=EN-US> 1_employees;</span></pre><pre>第二步:</pre><pre><span
class=GramE><span lang=EN-US>select</span></span><span lang=EN-US> count(*)</span></pre><pre><span
class=GramE><span lang=EN-US>from</span></span><span lang=EN-US> <span
class=SpellE>temp_manager_credit</span>;</span></pre><pre><b style='mso-bidi-font-weight:
normal'><span style='color:red'>第九节 计算机多个列中<span class=GramE>相异值</span>的数目<span
lang=EN-US><o:p></o:p></span></span></b></pre><pre>第一步:</pre><pre><span
class=GramE><span lang=EN-US>select</span></span><span lang=EN-US> distinct <span
class=SpellE>manager_id</span>,</span></pre><pre><span class=SpellE><span
lang=EN-US>credit_limit</span></span></pre><pre><span class=GramE><span
lang=EN-US>into</span></span><span lang=EN-US> <span class=SpellE>temp_manager_credit</span></span></pre><pre><span
class=GramE><span lang=EN-US>from</span></span><span lang=EN-US> 1_employees;</span></pre><pre>第二步<span
lang=EN-US>:</span></pre><pre><span class=GramE><span lang=EN-US>select</span></span><span
lang=EN-US> count(*)</span></pre><pre><span class=GramE><span lang=EN-US>from</span></span><span
lang=EN-US> <span class=SpellE>temp_manager_credit</span>;</span></pre><pre
style='text-align:center'><b style='mso-bidi-font-weight:normal'><span
style='color:red'>第十节 求和函数和平均函数<span lang=EN-US><o:p></o:p></span></span></b></pre><pre><span
class=GramE><span lang=EN-US>select</span></span><span lang=EN-US> sum(<span
class=SpellE>credit_limit</span>),</span></pre><pre><span class=SpellE><span
class=GramE><span lang=EN-US>avg</span></span></span><span class=GramE><span
lang=EN-US>(</span></span><span lang=EN-US>credit_limit0</span></pre><pre><span
class=GramE><span lang=EN-US>from</span></span><span lang=EN-US> 1_employees</span></pre><pre><b
style='mso-bidi-font-weight:normal'><span style='color:red'>第十一节 加法存在的问题及如何解决<span
lang=EN-US><o:p></o:p></span></span></b></pre><pre><span class=GramE>当以下</span>两种条件都成立时,<span
lang=EN-US>SQL</span>的加法会有问题:</pre><pre><span lang=EN-US>1.</span>将两个或者列多的列加在一起</pre><pre><span
lang=EN-US>2.</span>这些列中的一些包含<span lang=EN-US>null;</span></pre><pre>解决办法:</pre><pre><span
class=GramE><span lang=EN-US>select</span></span><span lang=EN-US> sum(<span
class=SpellE>nz</span>(col,0))+sum(<span class=SpellE>nz</span>(col,0))</span></pre><pre><span
class=GramE><span lang=EN-US>as</span></span><span lang=EN-US> <span
class=SpellE>column_first</span>,</span></pre><pre><span class=GramE><span
lang=EN-US>sum(</span></span><span class=SpellE><span lang=EN-US>nz</span></span><span
lang=EN-US>(col,0)+<span class=SpellE>nz</span>(col,0))</span></pre><pre><span
class=GramE><span lang=EN-US>as</span></span><span lang=EN-US> <span
class=SpellE>row_second</span></span></pre><pre><span class=GramE><span
lang=EN-US>from</span></span><span lang=EN-US> sec1111;</span></pre><pre><b
style='mso-bidi-font-weight:normal'><span style='color:red'>第十三节 计算列中<span
lang=EN-US>NULL</span>的数目<span lang=EN-US><o:p></o:p></span></span></b></pre><pre><span
class=GramE><span lang=EN-US>select</span></span><span lang=EN-US> count(*) as <span
class=SpellE>number_of_null</span></span></pre><pre><span class=GramE><span
lang=EN-US>from</span></span><span lang=EN-US> 1_employees</span></pre><pre><span
class=GramE><span lang=EN-US>where</span></span><span lang=EN-US> <span
class=SpellE>manager_id</span> is null;</span></pre><pre><b style='mso-bidi-font-weight:
normal'><i style='mso-bidi-font-style:normal'><u><span style='color:red'>第十四节 计算表中不同日期的数量<span
lang=EN-US><o:p></o:p></span></span></u></i></b></pre><pre><span class=GramE><span
lang=EN-US>select</span></span><span lang=EN-US> distinct format(<span
class=SpellE>date_entered,`yyyy</span>=<span class=SpellE>mmm`dd</span>`) as date_entered2</span></pre><pre><span
class=GramE><span lang=EN-US>into</span></span><span lang=EN-US> <span
class=SpellE>temp_date</span></span></pre><pre><span class=GramE><span
lang=EN-US>from</span></span><span lang=EN-US> 1_lunches;</span></pre><pre><span
class=GramE><span lang=EN-US>select</span></span><span lang=EN-US> count(date_emtered2)</span></pre><pre><span
class=GramE><span lang=EN-US>from</span></span><span lang=EN-US> <span
class=SpellE>temp_date</span>;</span></pre><pre><span lang=EN-US><o:p> </o:p></span></pre><pre><span
lang=EN-US><o:p> </o:p></span></pre><pre><span lang=EN-US><o:p> </o:p></span></pre></div>
<hr>
<a href="首页.html" ><font size=7>返回首页</font></a>

</body>

</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值