怎样使数据库中的多表实现联合查询

怎样使数据库中的多表实现联合查询,第1张

连接可以在SELECT 语句的FROM子句或WHERE子句中建立,似是而非在FROM子句中指出连接时有助于将连接 *** 作与WHERE子句中的搜索条件区分开来。所以,在Transact-SQL中推荐使用这种方法。

SQL-92标准所定义的FROM子句的连接语法格式为:

FROM join_table join_type join_table

[ON (join_condition)]

其中join_table指出参与连接 *** 作的表名,连接可以对同一个表 *** 作,也可以对多表 *** 作,对同一个表 *** 作的连接又称做自连接。

join_type 指出连接类型,可分为三种:内连接、外连接和交叉连接。

内连接(INNER JOIN)使用比较运算符进行表间某(些)列数据的比较 *** 作,并列出这些表中与连接条件相匹配的数据行。根据所使用的比较方式不同,内连接又分为等值连接、自然连接和不等连接三种。

外连接分为左外连接(LEFT OUTER JOIN或LEFT JOIN)、右外连接(RIGHT OUTER JOIN或RIGHT JOIN)和全外连接(FULL OUTER JOIN或FULL JOIN)三种。与内连接不同的是,外连接不只列出与连接条件相匹配的行,而是列出左表(左外连接时)、右表(右外连接时)或两个表(全外连接时)中所有符合搜索条件的数据行。

交叉连接(CROSS JOIN)没有WHERE 子句,它返回连接表中所有数据行的笛卡尔积,其结果集合中的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。

连接 *** 作中的ON (join_condition) 子句指出连接条件,它由被连接表中的列和比较运算符、逻辑运算符等构成。

无论哪种连接都不能对text、ntext和image数据类型列进行直接连接,但可以对这三种列进行间接连接。例如:

SELECT p1pub_id,p2pub_id,p1pr_info

FROM pub_info AS p1 INNER JOIN pub_info AS p2

ON DATALENGTH(p1pr_info)=DATALENGTH(p2pr_info)

(一)内连接

内连接查询 *** 作列出与连接条件匹配的数据行,它使用比较运算符比较被连接列的列值。内连接分三种:

1、等值连接:在连接条件中使用等于号(=)运算符比较被连接列的列值,其查询结果中列出被连接表中的所有列,包括其中的重复列。

2、不等连接: 在连接条件使用除等于运算符以外的其它比较运算符比较被连接的列的列值。这些运算符包括>、>=、<=、<、!>、!<和<>。

3、自然连接:在连接条件中使用等于(=)运算符比较被连接列的列值,但它使用选择列表指出查询结果集合中所包括的列,并删除连接表中的重复列。

例,下面使用等值连接列出authors和publishers表中位于同一城市的作者和出版社:

SELECT

FROM authors AS a INNER JOIN publishers AS p

ON acity=pcity

又如使用自然连接,在选择列表中删除authors 和publishers 表中重复列(city和state):

SELECT a,ppub_id,ppub_name,pcountry

FROM authors AS a INNER JOIN publishers AS p

ON acity=pcity

(二)外连接

内连接时,返回查询结果集合中的仅是符合查询条件( WHERE 搜索条件或 HAVING 条件)和连接条件的行。而采用外连接时,它返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左外连接时)、右表(右外连接时)或两个边接表(全外连接)中的所有数据行。

如下面使用左外连接将论坛内容和作者信息连接起来:

SELECT a,b FROM luntan LEFT JOIN usertable as b

ON ausername=busername

下面使用全外连接将city表中的所有作者以及user表中的所有作者,以及他们所在的城市:

SELECT a,b

FROM city as a FULL OUTER JOIN user as b

ON ausername=busername

左连接:(也叫左外连接,给出两个表的配匹行,并且以左边的表为准,如果左边表有而右边表没有的行,则在右边表的相应行选择的列显示为NULL,允许左边的基准表对应右边表多条满足条件的记录)左连接就是返回左边的匹配行,不考虑右边的表是否有相应的行,如:select field1,field2 from table1 left join table2

on field1=field2(基准字段,可以多个)

where table1field3=table2field3

右连接:(也叫右外连接,给出两个表的配匹行,并且以右边的表为准,如果右边表有而左边表没有的行,则在右边表的相应行选择的列显示为NULL,允许右边的基准表对应左边表多条满足条件的记录)

(三)交叉连接

交叉连接不带WHERE 子句,它返回被连接的两个表所有数据行的笛卡尔积,返回到结果集合中的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。

例,titles表中有6类图书,而publishers表中有8家出版社,则下列交叉连接检索到的记录数将等于68=48行。

SELECT type,pub_name

FROM titles CROSS JOIN publishers

ORDER BY

分类: 电脑/网络 >> 程序设计 >> 其他编程语言

问题描述:

有两个数据库文件太大,分别超过12G 和 6G,快把分区挤满,无法进行数据备份和更新了,需要清一下表的内容。

一个数据库,有几十个表,不可能一个个地去count的,请问在查询分析器中,如何快速地找到数据量最大的几个表?

另外,如果我用truncate table命令,那么索引文件也会相应地缩小吗?

谢谢!

解析:

sql的每一个数据库中有一个名名为’sysobjects’的表,这个系统表中储存了当前数据库中所有对象(包括系统表,用户表、日志、存储过程)的信息,可以用这个表链获取数据库中表的数目和名称,之后向获得某个制定数据库的信息,可以使用带参数的 sp_helpbd过程

我想不管是什么db总是有相应的业务逻辑的,最大的那几个表,一定有她的特殊 的业务逻辑,从表名上应该能判断出来,一般存,歌曲或者其他资料的表象对比较大,但是存用户名 以及关联表 ,一般都不会太大,

关于数据库更新,如果是xp或者me 以上的系统看看先把系统还原暂时停止,这样可以节省出来一些空间,或者在挂一块硬盘看看

select td,open ,high ,low ,close from s1

union

select td,open ,high ,low ,close from s2

union

select td,open ,high ,low ,close from s3

union

select td,open ,high ,low ,close from sn

show

tables

可以显示当前数据库下的所有表。

但是如果你想要查找特定的表

可能不大容易实现。

如果前缀都为a

可以试试

show

table

like

'a%';

num 是我随便写的一个他们需要做条件的列名。具体按照你自己的列名来写。

test_Table 这个是给联合起来查询的表取的一个别名,随便你写什么名字都行。

select max(num)

from (

select num from TABLE_2010

union

select num fromTABLE_2011

union

select num from TABLE_2012

) as test_Table

给你个办法,但只能一个库一个库执行,每次执行完把语句用到下一个库里就可以

分几步 *** 作

第一部,建立一个存储你得到的结果的表

比如你表名都是以table开头的话

先建立结果表

select  into result from table_1 where 1=0 --这是建立一个空表

然后执行以下过程

DECLARE c_cursor CURSOR FOR  

Select name From sysobjects where name like 'table%' order by name  

DECLARE @tablename varchar(100)  

DECLARE @sql varchar(max)

OPEN c_cursor  

FETCH NEXT FROM c_cursor into @tablename

WHILE @@FETCH_STATUS = 0  

BEGIN  

   set @sql='insert into result select  from ' + @tablename + ' where col=''xx'''--xx就是你要查的名字,可自己替换,其他地方就不要改啦  

exec (@sql)  

   FETCH NEXT FROM c_cursor into @tablename  

END  

CLOSE c_cursor  

DEALLOCATE c_cursor

执行完后,查看结果

select  from result

以上就是关于怎样使数据库中的多表实现联合查询全部的内容,包括:怎样使数据库中的多表实现联合查询、sql数据库中,如何快速找数据量最大的几个表、如何高效查询多个具有相同结构的表(MySQL数据库)等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10204569.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-06
下一篇 2023-05-06

发表评论

登录后才能评论

评论列表(0条)

保存