怎么利用sql语句把几个表合为一个虚拟表?~!

作者&投稿:召娣 (若有异议请与网页底部的电邮联系)
sql怎么用语句将三个表合成一个表~

用UNION,如:
SELECT ID, USER_NAME FROM TB_USERSUNIONSELECT ID, ADMIN_NAME FROM TB_ADMINSUNIONSELECT ID, MEMBER_NAME FROM TB_MEMBERS

用union all+group by。多少ID都没关系吧,除非你说的是有上千个表。。。
select ID,sum(qty1) qty1,sum(qty2) qty2,sum(qty3) qty3 (select ID,qty1,0 qty2,0 qty3 from 表1 union allselect ID,0 qty1,qty2,0 qty3 from 表2 union allselect ID,0 qty1,0 qty2,qty3 from 表3 ) as t1group by ID

使用视图呀

参见别人说法
SQL视图

视图可以被看成是虚拟表或存储查询。可通过视图访问的数据不作为独特的对象存储在数据库内。数据库内存储的是 SELECT 语句。SELECT 语句的结果集构成视图所返回的虚拟表。用户可以用引用表时所使用的方法,在 Transact-SQL 语句中通过引用视图名称来使用虚拟表。使用视图可以实现下列任一或所有功能:

将用户限定在表中的特定行上。
例如,只允许雇员看见工作跟踪表内记录其工作的行。

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

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

聚合信息而非提供详细信息。
例如,显示一个列的和,或列的最大值和最小值。

通过定义 SELECT 语句以检索将在视图中显示的数据来创建视图。SELECT 语句引用的数据表称为视图的基表。在下例中,pubs 数据库中的 titleview 是一个视图,该视图选择三个基表中的数据来显示包含常用数据的虚拟表:

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 列。使用这个新视图,客户可以获得已上市的书籍列表而不会看到财务信息:

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 语句都将看到与原始表中相同的行为。似乎每个服务器上都存在原始表的复本一样,而实际上每个表只有一个成员表和分区视图。有关更多信息,请参见视图使用方案。

只要所做的修改只影响视图所引用的其中一个基表,就可以更新所有 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 View TitleView
AS
Select ID,Title,PostTime,Hits From [List]
然后引用Select Top 100 * From TitleView
用循环输出数据与直接Select Top 100 * From [List]相比速度提高将近30毫秒!
当然我这里只是举例子,一般情况下对单个表没必要去用视图

建立一个视图,视图专门用来做这个功能的。

建立视图不同系统的语法有区别,一般是下面这样的:

CREATE VIEW view_name AS SELECT 语句

例如:

CREATE VIEW view_name AS SELECT * FROM table1 UNIION SELECT * FROM table2

创建视图,


sql 语句 急!!! 数据将英文和数字去掉,只保留汉字的sql语句
2、插入测试数据;insert into test_replace_str values('abc12历史');insert into test_replace_str values('ABC3试试dc');insert into test_replace_str values('ZZZ11100');commit;3、查询表中全量数据;select t.*, rowid from test_replace_str t;4、编写语句,将英文和数字去掉,只保留汉字...

SQL语句在数据库中是如何执行的
第一步:应用程序把查询SQL语句发给服务器端执行我们在数据层执行SQL语句时,应用程序会连接到相应的数据库服务器,把SQL语句发送给服务器处理。第二步:服务器解析请求的SQL语句SQL计划缓存,经常用查询分析器的朋友大概都知道这样一个事实,往往一个查询语句在第一次运行的时候需要执行特别长的时间,但是...

有SQL数据库名fll , 现要清空里面的数据(保留30天以内),的语句是什 ...
使用SQL语句清空数据库所有表的数据 近来发现数据库过大,空间不足,因此打算将数据库的数据进行全面的清理,但表非常多,一张一张的清空,实在麻烦,因此就想利用SQL语句一次清空所有数据.找到了三种方法进行清空.使用的数据库为MS SQL SERVER.1.搜索出所有表名,构造为一条SQL语句 declare @trun_name ...

sql中如何把现查询的值通过添加语句放入数据库中,
insert into 目标表(字段集合,用逗号分开) seletct (字段集合,用逗号分开) from 来源表或者查询集合

利用sql统计“学生”表中学生的总人数
统计“学生”表中学生的总人数的sql语句是:select count(*) from student;其中select代表查询,count(*)是统计行数量,student是学生表,使用上述语句可以统计学生表中的所有行记录也就是学生的总人数。

sql中怎么样把一个时间字段全部替换为一个时间段内的随机时间
2008-12-22 23:12:30转换为float是:39802.967013888891 2009-12-22 23:12:30转换为float是:40167.967013888891 然后用rand()函数可以获得一个小于1的随机,只括号里的int型种子不一样,得到的也是一个随机的数,楼主可以想到怎么用这个函数获得随机时间了吧 ...

怎样通过SQL语句修改ASP数据库内的一个号码,比如要把123456789这段改为2...
ASP 数据库,目前ASP WEB常用的数据库有ACCESS和SQL,一般的虚拟主机用户或者是小站点用户都使用ACCESS作为自己的站点数据库,因为它的方便性(其他性能请搜索相关的资料),大型的站点一般都用SQL(MSSQL).1.你先要知道是用的哪种数据库,不过一般SQL语句大多可通用的 2.你说要把123456789这段改为2500448688...

如何利用SQl语句比较两个同一个号码时间的前后?
你是想干什么?比较大小后显示什么还是什么意思?比如A比B大显示A,B比A大显示B,一样大显示空,是类似这个意思么?时间可以直接比较的。select case when A.Date_Time>B.Date_Time then A, when A.Date_Time>B.Date_Time then B else null end date_time from A,B where A.Serial_Number=...

SQL语句执行流程与顺序原理解析
当服务器进程的优化器确定这条查询语句的最佳执行计划后, 就会将这条SQL语句与执行计划保存到数据高速缓存(library cache)。如此,等以后还有这个查询时,就会省略以上的语法、语义与权限检查的步骤,而直接执行SQL语句,提高SQL语句处理效率。第三步:绑定变量赋值如果SQL语句中使用了绑定变量,扫描绑定变量的声明,给绑定...

如何利用sql语句创建access数据库放在D盘的文件夹下
为什么要把图片放在特定位置呢?既然你要用这个图片资源就应该把这个资源放到工程里面吧 放到工程里面后 在数据库img字段就可以保存相对路径(相对与工程根目录)了,sql语句就是直接一般的查法查询出来,然后在页面上拼上你域名,把这个拼接好的字符(其实就是一个图片资源的url)直接放到页面上的img标签下...

东乡县19840813505: 用SQL语句将2张表合并 -
阮绿英太: select 表1.名字,表2.总缴费,表1.缴费, 表1.地点 from 表1 left join 表2 on 表1.名字 = 表2.名字需要用left join才能防止表1有数据,而表2没有对应的纪录

东乡县19840813505: SQL怎么合并表? -
阮绿英太: select * into 新表名 from (select * from T1 union all select * from T2)这个语句可以实现将合并的数据追加到一个新表中.不合并重复数据 select * from T1 union all select * from T2合并重复数据 select * from T1 union select * from T2两个表,...

东乡县19840813505: 如何将sql数据库多个表的数据整合到一个表里 -
阮绿英太: 从某个具体的应用角度看,例如医院管理系统、财务管理系统等,SQL Server又可以属于系统软件,或者至少可以被归到支撑软件里.

东乡县19840813505: 怎样将结构完全一样的两个表的内容合并到一个表中,SQL语句 -
阮绿英太: 1、查询的话 select * from 表1 union all select * from 表22、新建表的话(包含数据) create table 表3 as select * from 表1 union all select * from 表22、新建表的话(不包含数据) create table 表3 as select * from 表1 union all select * from 表2 where 1=2

东乡县19840813505: 如何用SQL语句实现将两个不同结构的表合并到一个新表中??? -
阮绿英太: 说说具体的需求.表结构不同,也可以有逻辑条件有相关联性的拼接,或者fileds字段的拼接等.

东乡县19840813505: sql 语句,如何将数个相同表中的数据合并到一张表中 -
阮绿英太: 这个问题首先必须基于table1,table2,table3这3张表各自的time字段无重复值,否则每个有重复的时间,都可能会组合成N多种组合(假如这3张表每一张都有两条时间为2012...

东乡县19840813505: SQL怎么把两个表的数据整合起来 -
阮绿英太: 先将两张表联合在一起,然后再对联合后的表进行查询.例如: select sum(t.quantity) as totalQty from (select * from t1 union all select * from t2)t;

东乡县19840813505: 如何用sql语句将三张表合并为一张表 -
阮绿英太: select 编号,姓名,工资,奖金,加班费,工资+奖金+加班费 as 合计 from (select * from 表1 a FULL OUTER JOIN 表2 b on a.编号=b.编号) ab FULL OUTER JOIN 表3 c on ab.编号=c.编号

东乡县19840813505: 请问怎么用sql合并同一个数据库中的不同的表 -
阮绿英太: 用union select * from enterprise1 union select * from enterprise2 前提是表结构要一样

东乡县19840813505: 怎么利用sql语句把几个表合为一个虚拟表?~! -
阮绿英太: 使用视图呀 参见别人说法 SQL视图 视图可以被看成是虚拟表或存储查询.可通过视图访问的数据不作为独特的对象存储在数据库内.数据库内存储的是 SELECT 语句.SELECT 语句的结果集构成视图所返回的虚拟表.用户可以用引用表时所...

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网