SQL虚拟表应用三例.docx
- 文档编号:24119265
- 上传时间:2023-05-24
- 格式:DOCX
- 页数:13
- 大小:17.65KB
SQL虚拟表应用三例.docx
《SQL虚拟表应用三例.docx》由会员分享,可在线阅读,更多相关《SQL虚拟表应用三例.docx(13页珍藏版)》请在冰豆网上搜索。
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
设计索引视图
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- SQL 虚拟 应用