1、SQL虚拟表应用三例SQL虚拟表应用三例SQL虚拟表是一种通过SELECT语句查询常量表达式形成的一个结果集,和数据库的视图、物理表、临时表都差不多。一旦这个虚拟表构造出来,就可以当作实际的表来查询。环境:Windows XP Professional 简体中文版mysql-5.0.45-win32应用三例:1、求数字对会计大写的对应表。SELECT * FROM (SELECT 0 AS CODE, 零 AS NAME UNION SELECT 1, 壹 UNION SELECT 2, 贰 UNION SELECT 3, 叁 UNION SELECT 4, 肆 UNION SELECT 5,
2、 伍 UNION SELECT 6, 陆 UNION SELECT 7, 柒 UNION SELECT 8, 捌 UNION SELECT 9, 玖 UNION SELECT 10, 拾) AS RMBDXORDER BY CODE ASC;查询结果:CODE NAME-0 零1 壹2 贰3 叁4 肆5 伍6 陆7 柒8 捌9 玖10 拾2、产生0999之间的数字。SELECT CAST(CONCAT(CONCAT(N1, N2), N3) AS UNSIGNED INTEGER) AS NUMS FROM (SELECT 0 AS N1 UNION SELECT 1 UNION SELECT
3、 2 UNION SELECT 3 UNION SELECT 4 UNION SELECT 5 UNION SELECT 6 UNION SELECT 7 UNION SELECT 8 UNION SELECT 9) AS NUM1, (SELECT 0 AS N2 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) AS NUM2, (SELECT 0 AS N3 UNION
4、 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) AS NUM3ORDER BY NUMS ASC;查询结果:NUMS-01234.9989993、求0999之间整数的二次方根(平方根)。SELECT NUMS AS SQUARE, ROUND(SQRT(NUMS) AS BASIS FROM (SELECT CAST(CONCAT(CONCAT(N1, N2), N3) AS UNS
5、IGNED INTEGER) AS NUMS FROM (SELECT 0 AS N1 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) AS NUM1, (SELECT 0 AS N2 UNION SELECT 1 UNION SELECT 2 UNION SELECT 3 UNION SELECT 4 UNION SELECT 5 UNION SELECT 6 UNION
6、 SELECT 7 UNION SELECT 8 UNION SELECT 9) AS NUM2, (SELECT 0 AS N3 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) AS NUM3) AS TMP_TABWHERE SQRT(NUMS) = ROUND(SQRT(NUMS)ORDER BY SQUARE ASC;查询结果:SQUARE BASIS-0 01 1
7、4 29 316 425 536 649 764 881 9100 10121 11144 12169 13196 14225 15256 16289 17324 18361 19400 20441 21484 22529 23576 24625 25676 26729 27784 28841 29900 30961 31视图sql - 概述SQL 视图视图可以被看成是虚拟表或存储查询。可通过视图访问的数据不作为独特的对象存储在数据库内。数据库内存储的是 SELECT 语句。SELECT 语句的结果集构成视图所返回的虚拟表。用户可以用引用表时所使用的方法,在 Transact-SQL 语句中通
8、过引用视图名称来使用虚拟表。使用视图可以实现下列任一或所有功能: 将用户限定在表中的特定行上。 例如,只允许雇员看见工作跟踪表内记录其工作的行。将用户限定在特定列上。 例如,对于那些不负责处理工资单的雇员,只允许他们看见雇员表中的姓名列、办公室列、工作电话列和部门列,而不能看见任何包含工资信息或个人信息的列。将多个表中的列联接起来,使它们看起来象一个表。聚合信息而非提供详细信息。 例如,显示一个列的和,或列的最大值和最小值。通过定义 SELECT 语句以检索将在视图中显示的数据来创建视图。SELECT 语句引用的数据表称为视图的基表。在下例中,pubs 数据库中的 titleview 是一个视
9、图,该视图选择三个基表中的数据来显示包含常用数据的虚拟表:视图sql - 程序资料CREATE VIEW titleviewASSELECT title, au_ord, au_lname, price, ytd_sales, pub_idFROM authors AS a JOIN titleauthor AS ta ON (a.au_id = ta.au_id) JOIN titles AS t ON (t.title_id = ta.title_id)之后,可以用引用表时所使用的方法在语句中引用 titleview。SELECT *FROM titleview一个视图可以引用另一个视图。
10、例如,titleview 显示的信息对管理人员很有用,但公司通常只在季度或年度财务报表中才公布本年度截止到现在的财政数字。可以建立一个视图,在其中包含除 au_ord 和 ytd_sales 外的所有 titleview 列。使用这个新视图,客户可以获得已上市的书籍列表而不会看到财务信息:CREATE VIEW Cust_titleviewASSELECT title, au_lname, price, pub_idFROM titleview视图可用于在多个数据库或 Microsoft® SQL Server 2000 实例间对数据进行分区。分区视图可用于在整个服务器组内分布数据库处
11、理。服务器组具有与服务器聚集相同的性能优点,并可用于支持最大的 Web 站点或公司数据中心的处理需求。原始表被细分为多个成员表,每个成员表包含原始表的行子集。每个成员表可放置在不同服务器的数据库中。每个服务器也可得到分区视图。分区视图使用 Transact-SQL UNION 运算符,将在所有成员表上选择的结果合并为单个结果集,该结果集的行为与整个原始表的复本完全一样。例如在三个服务器间进行表分区。在第一个服务器上定义如下的分区视图:CREATE VIEW PartitionedView ASSELECT * FROM MyDatabase.dbo.PartitionTable1UNION A
12、LLSELECT * FROM Server2.MyDatabase.dbo.PartitionTable2UNION ALLSELECT * FROM Server3.MyDatabase.dbo.PartitionTable3在其它两个服务器上定义类似的分区视图。利用这三个视图,三个服务器上任何引用 PartitionedView 的 Transact-SQL 语句都将看到与原始表中相同的行为。似乎每个服务器上都存在原始表的复本一样,而实际上每个表只有一个成员表和分区视图。有关更多信息,请参见视图使用方案。只要所做的修改只影响视图所引用的其中一个基表,就可以更新所有 SQL Server
13、版本内的视图(可以对其执行 UPDATE、DELETE 或 INSERT 语句)。- Increase the prices for publisher 0736 by 10%.UPDATE titleviewSET price = price * 1.10WHERE pub_id = 0736GOSQL Server 2000 支持可引用视图的更复杂的 INSERT、UPDATE 和 DELETE 语句。可在视图上定义 INSTEAD OF 触发器,指定必须对基表执行的个别更新以支持 INSERT、UPDATE 或 DELETE 语句。另外,分区视图还支持 INSERT、UDPATE 和 D
14、ELETE 语句修改视图所引用的多个成员表。索引视图是 SQL Server 2000 具有的功能,可显著提高复杂视图类型的性能,这些视图类型通常在数据仓库或其它决策支持系统中出现。视图的结果集通常不保存在数据库中,因此视图也称为虚拟表。视图的结果集动态包含在语句逻辑中并在运行时动态生成。有关更多信息,请参见视图解析。复杂的查询(如决策支持系统中的查询)可引用基表中的大量行,并将大量信息聚积在相对较简洁的聚合中,如总和或平均值。SQL Server 2000 支持在执行此类复杂查询的视图上创建聚集索引。当执行 CREATE INDEX 语句时,视图 SELECT 的结果集将永久存储在数据库中。SQL 语句此后若引用该视图,响应时间将会显著缩短。对基本数据的修改将自动反映在视图中。SQL Server 2000 CREATE VIEW 语句支持 SCHEMABINDING 选项,以防止视图所引用的表在视图未被调整的情况下发生改变。必须为任何创建索引的视图指定 SCHEMABINDING。请参见CREATE INDEXCREATE TRIGGERCREATE VIEW设计索引视图
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1