SQL虚拟表应用三例.docx

上传人:b****4 文档编号:24119265 上传时间:2023-05-24 格式:DOCX 页数:13 大小:17.65KB
下载 相关 举报
SQL虚拟表应用三例.docx_第1页
第1页 / 共13页
SQL虚拟表应用三例.docx_第2页
第2页 / 共13页
SQL虚拟表应用三例.docx_第3页
第3页 / 共13页
SQL虚拟表应用三例.docx_第4页
第4页 / 共13页
SQL虚拟表应用三例.docx_第5页
第5页 / 共13页
点击查看更多>>
下载资源
资源描述

SQL虚拟表应用三例.docx

《SQL虚拟表应用三例.docx》由会员分享,可在线阅读,更多相关《SQL虚拟表应用三例.docx(13页珍藏版)》请在冰豆网上搜索。

SQL虚拟表应用三例.docx

SQL虚拟表应用三例

SQL虚拟表应用三例

 

SQL虚拟表是一种通过SELECT语句查询常量表达式形成的一个结果集,和数据库的视图、物理表、临时表都差不多。

一旦这个虚拟表构造出来,就可以当作实际的表来查询。

 

环境:

WindowsXPProfessional简体中文版

mysql-5.0.45-win32

 

应用三例:

 

1、求数字对会计大写的对应表。

SELECT*

 FROM(SELECT0ASCODE,'零'ASNAME

       UNION

       SELECT1,'壹'

       UNION

       SELECT2,'贰'

       UNION

       SELECT3,'叁'

       UNION

       SELECT4,'肆'

       UNION

       SELECT5,'伍'

       UNION

       SELECT6,'陆'

       UNION

       SELECT7,'柒'

       UNION

       SELECT8,'捌'

       UNION

       SELECT9,'玖'

       UNION

       SELECT10,'拾')ASRMBDX

 ORDERBYCODEASC;

 

查询结果:

CODE   NAME

--------------

0      零

1      壹

2      贰

3      叁

4      肆

5      伍

6      陆

7      柒

8      捌

9      玖

10     拾

 

 

2、产生0~999之间的数字。

SELECTCAST(CONCAT(CONCAT(N1,N2),N3)ASUNSIGNEDINTEGER)ASNUMS

 FROM(SELECT'0'ASN1

       UNION

       SELECT'1'

       UNION

       SELECT'2'

       UNION

       SELECT'3'

       UNION

       SELECT'4'

       UNION

       SELECT'5'

       UNION

       SELECT'6'

       UNION

       SELECT'7'

       UNION

       SELECT'8'

       UNION

       SELECT'9')ASNUM1,

      (SELECT'0'ASN2

       UNION

       SELECT'1'

       UNION

       SELECT'2'

       UNION

       SELECT'3'

       UNION

       SELECT'4'

       UNION

       SELECT'5'

       UNION

       SELECT'6'

       UNION

       SELECT'7'

       UNION

       SELECT'8'

       UNION

       SELECT'9')ASNUM2,

      (SELECT'0'ASN3

       UNION

       SELECT'1'

       UNION

       SELECT'2'

       UNION

       SELECT'3'

       UNION

       SELECT'4'

       UNION

       SELECT'5'

       UNION

       SELECT'6'

       UNION

       SELECT'7'

       UNION

       SELECT'8'

       UNION

       SELECT'9')ASNUM3

 ORDERBYNUMSASC;

 

查询结果:

NUMS

---------

0

1

2

3

4

...

998

999

 

 

 

3、求0~999之间整数的二次方根(平方根)。

 SELECTNUMSASSQUARE,ROUND(SQRT(NUMS))ASBASIS

 FROM(SELECTCAST(CONCAT(CONCAT(N1,N2),N3)ASUNSIGNEDINTEGER)ASNUMS

         FROM(SELECT'0'ASN1

               UNION

               SELECT'1'

               UNION

               SELECT'2'

               UNION

               SELECT'3'

               UNION

               SELECT'4'

               UNION

               SELECT'5'

               UNION

               SELECT'6'

               UNION

               SELECT'7'

               UNION

               SELECT'8'

               UNION

               SELECT'9')ASNUM1,

              (SELECT'0'ASN2

               UNION

               SELECT'1'

               UNION

               SELECT'2'

               UNION

               SELECT'3'

               UNION

               SELECT'4'

               UNION

               SELECT'5'

               UNION

               SELECT'6'

               UNION

               SELECT'7'

               UNION

               SELECT'8'

               UNION

               SELECT'9')ASNUM2,

              (SELECT'0'ASN3

               UNION

               SELECT'1'

               UNION

               SELECT'2'

               UNION

               SELECT'3'

               UNION

               SELECT'4'

               UNION

               SELECT'5'

               UNION

               SELECT'6'

               UNION

               SELECT'7'

               UNION

               SELECT'8'

               UNION

               SELECT'9')ASNUM3)ASTMP_TAB

 WHERESQRT(NUMS)=ROUND(SQRT(NUMS))

 ORDERBYSQUAREASC;

 

查询结果:

 

SQUARE BASIS

------------------

0      0

1      1

4      2

9      3

16     4

25     5

36     6

49     7

64     8

81     9

100    10

121    11

144    12

169    13

196    14

225    15

256    16

289    17

324    18

361    19

400    20

441    21

484    22

529    23

576    24

625    25

676    26

729    27

784    28

841    29

900    30

961    31

 

视图sql-概述

SQL视图视图可以被看成是虚拟表或存储查询。

可通过视图访问的数据不作为独特的对象存储在数据库内。

数据库内存储的是SELECT语句。

SELECT语句的结果集构成视图所返回的虚拟表。

用户可以用引用表时所使用的方法,在Transact-SQL语句中通过引用视图名称来使用虚拟表。

使用视图可以实现下列任一或所有功能:

将用户限定在表中的特定行上。

例如,只允许雇员看见工作跟踪表内记录其工作的行。

将用户限定在特定列上。

例如,对于那些不负责处理工资单的雇员,只允许他们看见雇员表中的姓名列、办公室列、工作电话列和部门列,而不能看见任何包含工资信息或个人信息的列。

将多个表中的列联接起来,使它们看起来象一个表。

聚合信息而非提供详细信息。

例如,显示一个列的和,或列的最大值和最小值。

通过定义SELECT语句以检索将在视图中显示的数据来创建视图。

SELECT语句引用的数据表称为视图的基表。

在下例中,pubs数据库中的titleview是一个视图,该视图选择三个基表中的数据来显示包含常用数据的虚拟表:

视图sql-程序资料

CREATEVIEWtitleview

AS

SELECTtitle,au_ord,au_lname,price,ytd_sales,pub_id

FROMauthorsASa

    JOINtitleauthorAStaON(a.au_id=ta.au_id)

    JOINtitlesAStON(t.title_id=ta.title_id)

之后,可以用引用表时所使用的方法在语句中引用titleview。

SELECT*

FROMtitleview

一个视图可以引用另一个视图。

例如,titleview显示的信息对管理人员很有用,但公司通常只在季度或年度财务报表中才公布本年度截止到现在的财政数字。

可以建立一个视图,在其中包含除au_ord和ytd_sales外的所有titleview列。

使用这个新视图,客户可以获得已上市的书籍列表而不会看到财务信息:

CREATEVIEWCust_titleview

AS

SELECTtitle,au_lname,price,pub_id

FROMtitleview

视图可用于在多个数据库或Microsoft®SQLServer™2000实例间对数据进行分区。

分区视图可用于在整个服务器组内分布数据库处理。

服务器组具有与服务器聚集相同的性能优点,并可用于支持最大的Web站点或公司数据中心的处理需求。

原始表被细分为多个成员表,每个成员表包含原始表的行子集。

每个成员表可放置在不同服务器的数据库中。

每个服务器也可得到分区视图。

分区视图使用Transact-SQLUNION运算符,将在所有成员表上选择的结果合并为单个结果集,该结果集的行为与整个原始表的复本完全一样。

例如在三个服务器间进行表分区。

在第一个服务器上定义如下的分区视图:

CREATEVIEWPartitionedViewAS

SELECT*

  FROMMyDatabase.dbo.PartitionTable1

UNIONALL

SELECT*

  FROMServer2.MyDatabase.dbo.PartitionTable2

UNIONALL

SELECT*

  FROMServer3.MyDatabase.dbo.PartitionTable3

在其它两个服务器上定义类似的分区视图。

利用这三个视图,三个服务器上任何引用PartitionedView的Transact-SQL语句都将看到与原始表中相同的行为。

似乎每个服务器上都存在原始表的复本一样,而实际上每个表只有一个成员表和分区视图。

有关更多信息,请参见视图使用方案。

只要所做的修改只影响视图所引用的其中一个基表,就可以更新所有SQLServer版本内的视图(可以对其执行UPDATE、DELETE或INSERT语句)。

--Increasethepricesforpublisher'0736'by10%.

UPDATEtitleview

SETprice=price*1.10

WHEREpub_id='0736'

GO

SQLServer2000支持可引用视图的更复杂的INSERT、UPDATE和DELETE语句。

可在视图上定义INSTEADOF触发器,指定必须对基表执行的个别更新以支持INSERT、UPDATE或DELETE语句。

另外,分区视图还支持INSERT、UDPATE和DELETE语句修改视图所引用的多个成员表。

索引视图是SQLServer2000具有的功能,可显著提高复杂视图类型的性能,这些视图类型通常在数据仓库或其它决策支持系统中出现。

视图的结果集通常不保存在数据库中,因此视图也称为虚拟表。

视图的结果集动态包含在语句逻辑中并在运行时动态生成。

有关更多信息,请参见视图解析。

复杂的查询(如决策支持系统中的查询)可引用基表中的大量行,并将大量信息聚积在相对较简洁的聚合中,如总和或平均值。

SQLServer2000支持在执行此类复杂查询的视图上创建聚集索引。

当执行CREATEINDEX语句时,视图SELECT的结果集将永久存储在数据库中。

SQL语句此后若引用该视图,响应时间将会显著缩短。

对基本数据的修改将自动反映在视图中。

SQLServer2000CREATEVIEW语句支持SCHEMABINDING选项,以防止视图所引用的表在视图未被调整的情况下发生改变。

必须为任何创建索引的视图指定SCHEMABINDING。

请参见

CREATEINDEX

CREATETRIGGER

CREATEVIEW

设计索引视图

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 高中教育 > 其它课程

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1