怎么利用sql语句把几个表合为一个虚拟表?~! 怎么把SQL多个表关联合并成一个表

作者&投稿:柳友 (若有异议请与网页底部的电邮联系)
使用视图呀

参见别人说法
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怎么用语句将三个表合成一个表~

用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如何把查询出来的多个表创建成一个临时表(sql如何根据现有的表创建一...
答:1、sqlserver使用selectinto会自动生成临时表,不需要事先创建。select*into#tempfromsysobjects 2、sql要把多个表合并成一个要用到union或unionall的关键字。3、union或unionall的区别是:union会自动压缩多个结果集合中的重复结果,而unionall则将所有的结果全部显示出来。

如何合并表 SQL
答:1. 新建一个临时表 CREATE TABLE tmp AS SELECT * FROM youtable GROUP BY name(name为不希望有重复的列)2. 清空原来的表 TRUNCATE TABLE youtable 3. 把临时表插入到youtable INSERT INTO tablename SELECT * FROM temp 4. 删除临时表 DROP TABLE temp 方法3:delete 表 where ID ...

求sql语句,三表A\B\C合并,共有字段a,b,求:将B和C表与A表中a,b字段一致...
答:insert D表(a, b, c1,c2,c3, e1,e2,e3)select A表.a, A表.b, c1,c2,c3, e1,e2,e3 from A表, C表 where A表.a=C表.a and A表.b=C表.b and (A表.a, A表.b) not in (select ,a,b from B表);

SQL怎么合并表?
答:这个语句可以实现将合并的数据追加到一个新表中。不合并重复数据 select * from T1 union all select * from T2 合并重复数据 select * from T1 union select * from T2 两个表,表1 表2 如果要将 表1的数据并入表2用以下语句即可 insert into 表2(字段1,字段2) select 字段1,字段2 from ...

SQL 两张表合并 (两张表的列都相同)
答:可以参考下面的方法:1、第一种,用一张临时表,把所有数据都放在一张表里 INSERT INTO QunList SELECT * FROM QunList89,90,91,92;再在QunList中查询 2、第二种,用 UNION ALL方式查询 SELECT * FROM QunList89 UNION ALL SELECT * FROM QunList90;...

sql怎么把两张表合并成一张
答:sql把两张表合并成一张步骤如下:1、我们首先将以A为基准用left join 以B为基准用right,都要就用full join 。2、full join会多出一行数,select * from a full join b on a.id=b.id,刚才测了,a一行数据,b两行数据,这样查询成了三行数据,我要这样的数所,a两行.一行是数据,一行全是空...

SQL两张表如何合并为一张表
答:sql:create table tablename1 as select t2.filename1, t3.filename2 from tablename2 t2,tablename3 t3 where t2.id =t3.id;解释:从tablename2表中读取出filename1字段,从tablename3表中读取出filename2字段插入到新建的tablename1表中。后面的where条件是通过id字段,将查询的两张表关联起来确定依赖关系...

sql一个库里面有一百张表 怎么合并在一张表里面呢?大神求助。。。我...
答:最简单的回答:这一百张表的表名,一般你是得老老实实一个一个将它们码出来,按SQL语句的规则编写语句。1、分横和联接和纵向联接,两种方式。2、横向联接情况下,每个表中的记录都要有一个特定的其它表中有的记录,以保证它们的信息能对位串在一起。比如每个表中的记录都有一个学生证编号,而且...

sql server 语句如何将3个表合并成一个表?
答:但是在执行合并的时候,需要对每一个待合并的数据,打上一个标签,代表这个是哪个表中来的数据,这个标签最后用于区分同一个人的不同的成绩是分别是多少,不能因为合并在一起后,就把同一个人的三项成绩给搞混了。合并后的数据进行行转列的操作。具体的SQL语句如下图所示:...

sql把两个表合并成一个新表的语句应该怎么写
答:SQL SERVER:select into 表3 from (select 字段列表1 from 表1 union all select 字段列表2 from 表2 ) a 说明:字段列表1与字段列表1要数目相同、类型兼容 其它数据库自己参考。