首页 SQL虚拟表应用三例

SQL虚拟表应用三例

举报
开通vip

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,...

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, '伍' UNION SELECT 6, '陆' UNION SELECT 7, '柒' UNION SELECT 8, '捌' UNION SELECT 9, '玖' UNION SELECT 10, '拾') AS RMBDX ORDER BY CODE ASC; 查询结果: CODE NAME -------------- 0 零 1 壹 2 贰 3 叁 4 肆 5 伍 6 陆 7 柒 8 捌 9 玖 10 拾 2、产生0~999之间的数字。 SELECT CAST(CONCAT(CONCAT(N1, N2), N3) AS UNSIGNED 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 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 ORDER BY NUMS ASC; 查询结果: NUMS --------- 0 1 2 3 4 ... 998 999 3、求0~999之间整数的二次方根(平方根)。 SELECT NUMS AS SQUARE, ROUND(SQRT(NUMS)) AS BASIS FROM (SELECT CAST(CONCAT(CONCAT(N1, N2), N3) AS UNSIGNED 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 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_TAB WHERE SQRT(NUMS) = ROUND(SQRT(NUMS)) ORDER BY SQUARE ASC; 查询结果: 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 - 程序资料 CREATE VIEW titleview AS SELECT title, au_ord, au_lname, price, ytd_sales, pub_id FROM 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 一个视图可以引用另一个视图。例如,titleview 显示的信息对管理人员很有用,但公司通常只在季度或年度财务报表中才公布本年度截止到现在的财政数字。可以建立一个视图,在其中包含除 au_ord 和 ytd_sales 外的所有 titleview 列。使用这个新视图,客户可以获得已上市的 关于书的成语关于读书的排比句社区图书漂流公约怎么写关于读书的小报汉书pdf 籍列表而不会看到财务信息: CREATE VIEW Cust_titleview AS SELECT title, au_lname, price, pub_id FROM titleview 视图可用于在多个数据库或 Microsoft® SQL Server? 2000 实例间对数据进行分区。分区视图可用于在整个服务器组内分布数据库处理。服务器组具有与服务器聚集相同的性能优点,并可用于支持最大的 Web 站点或公司数据中心的处理需求。原始表被细分为多个成员表,每个成员表包含原始表的行子集。每个成员表可放置在不同服务器的数据库中。每个服务器也可得到分区视图。分区视图使用 Transact-SQL UNION 运算符,将在所有成员表上选择的结果合并为单个结果集,该结果集的行为与整个原始表的复本完全一样。例如在三个服务器间进行表分区。在第一个服务器上定义如下的分区视图: CREATE VIEW PartitionedView AS SELECT * FROM MyDatabase.dbo.PartitionTable1 UNION ALL SELECT * FROM Server2.MyDatabase.dbo.PartitionTable2 UNION ALL SELECT * FROM Server3.MyDatabase.dbo.PartitionTable3 在其它两个服务器上定义类似的分区视图。利用这三个视图,三个服务器上任何引用 PartitionedView 的 Transact-SQL 语句都将看到与原始表中相同的行为。似乎每个服务器上都存在原始表的复本一样,而实际上每个表只有一个成员表和分区视图。有关更多信息,请参见视图使用 方案 气瓶 现场处置方案 .pdf气瓶 现场处置方案 .doc见习基地管理方案.doc关于群访事件的化解方案建筑工地扬尘治理专项方案下载 。 只要所做的修改只影响视图所引用的其中一个基表,就可以更新所有 SQL Server 版本内的视图(可以对其执行 UPDATE、DELETE 或 INSERT 语句)。 -- Increase the prices for publisher '0736' by 10%. UPDATE titleview SET price = price * 1.10 WHERE pub_id = '0736' GO SQL Server 2000 支持可引用视图的更复杂的 INSERT、UPDATE 和 DELETE 语句。可在视图上定义 INSTEAD OF 触发器,指定必须对基表执行的个别更新以支持 INSERT、UPDATE 或 DELETE 语句。另外,分区视图还支持 INSERT、UDPATE 和 DELETE 语句修改视图所引用的多个成员表。 索引视图是 SQL Server 2000 具有的功能,可显著提高复杂视图类型的性能,这些视图类型通常在数据仓库或其它决策支持系统中出现。 视图的结果集通常不保存在数据库中,因此视图也称为虚拟表。视图的结果集动态包含在语句逻辑中并在运行时动态生成。有关更多信息,请参见视图解析。 复杂的查询(如决策支持系统中的查询)可引用基表中的大量行,并将大量信息聚积在相对较简洁的聚合中,如总和或平均值。SQL Server 2000 支持在执行此类复杂查询的视图上创建聚集索引。当执行 CREATE INDEX 语句时,视图 SELECT 的结果集将永久存储在数据库中。SQL 语句此后若引用该视图,响应时间将会显著缩短。对基本数据的修改将自动反映在视图中。 SQL Server 2000 CREATE VIEW 语句支持 SCHEMABINDING 选项,以防止视图所引用的表在视图未被调整的情况下发生改变。必须为任何创建索引的视图指定 SCHEMABINDING。 请参见 CREATE INDEX CREATE TRIGGER CREATE VIEW 设计 领导形象设计圆作业设计ao工艺污水处理厂设计附属工程施工组织设计清扫机器人结构设计 索引视图
本文档为【SQL虚拟表应用三例】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
该文档来自用户分享,如有侵权行为请发邮件ishare@vip.sina.com联系网站客服,我们会及时删除。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。
本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。
网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
下载需要: 免费 已有0 人下载
最新资料
资料动态
专题动态
is_614050
暂无简介~
格式:doc
大小:27KB
软件:Word
页数:0
分类:生活休闲
上传时间:2018-02-17
浏览量:8