SQL点滴23—T-SQL中的除法

简介:    在T-SQL中没有除法运算,但是在T-SQL中可以实现类似除法的操作Divide。一般除法操作的结果一个列来自于被除关系表,剩下的来自除关系表。这里举一个例子来说明。假设如下有三个表:客户Customers,销售人员Employees,订单Orders,查询返回一些客户,要求这些客户和所有美国雇员都至少有一次交易记录。

  

在T-SQL中没有除法运算,但是在T-SQL中可以实现类似除法的操作Divide。一般除法操作的结果一个列来自于被除关系表,剩下的来自除关系表。这里举一个例子来说明。假设如下有三个表:客户Customers,销售人员Employees,订单Orders,查询返回一些客户,要求这些客户和所有美国雇员都至少有一次交易记录。来看下面一个语句:

select custid from Sales.Customers as C
where not exists
(
select * from HR.Employees as E
where country='USA'
and not exists
(
select * from Sales.Orders as O
where O.custid = C.custid
and O.empid = E.empid))

  

语句返回23行,标明有23名客户,这些客户至少和每个美国雇员有一次交易记录。现在我们如果修改一下条件,问题要求还是一样的,我们把销售人员的国家修改成以色列Israel,看看以色列的销售人员是否能像美国雇员一样的强悍。

  

select custid from Sales.Customers as C
where not exists
(
select * from HR.Employees as E
where country='Israel'
and not exists
(
select * from Sales.Orders as O
where O.custid = C.custid
and O.empid = E.empid))

  

修改国家条件,这次我们查询得到的结果是91条记录,我们看看Customers这个表总共也就91条记录,很明显这个结果不对。我们使用语句来看看select * from Sales.Customers where country like '%Israel%',查询得到0条记录,就是说根本就没有以色列的雇员。因为没有来自以色列的雇员,所有雇员和该客户拥有至少一项交易记录这个条件对每个雇员都满足,这个是代数里面的空真现象。换句话说每个客户都和这个不存在的以色列雇员至少有一项交易记录。这个很像除法运算的一个规则:除数是0,商就是无限大

  
写上面的语句的时候,我们没有考虑如果Employee表中没有如果没有以色列的雇员怎么办。如果我们在问题中加上确实存在来自以色列的雇员就可以避免这个错误,只需要在条件中限定至少有一个以色列雇员存在于表Employee中就可以了。这个就像除法中的非0限定:除数不为0。语句如下:

  

select custid from Sales.Customers as C
where not exists
(
select * from HR.Employees as E
where country='Israel'
and not exists
(
select * from Sales.Orders as O
where O.custid = C.custid
and O.empid = E.empid))
and exists (select * from HR.Employees as E where country='Israel')

现在查询得到0条结果,这才是我们想要的。

  
在这个除法操作中有三个关系,a Divide by b Per c,a是被除数,b是除数,c是中介关系。假设a有属性A,b有属性B。在上面的语句中被除关系是Customers,除数关系是满足一定关系的Employee,中介关系是Orders。这里为了避免除数是0 的问题,使用第四个临时关系(select * from HR.Employees as E where country='Israel')。也可以使用另外一种方法来限定至少有一名以色列的销售人员和所有顾客至少有一次交易记录。如下:
a,找到美国雇员的id:select empid from HR.Employees where country='USA',这个语句找到的是(1,2,3,4,8)。
b,找到美国雇员的数量:select COUNT(*) from HR.Employees where country='USA',很明显这个找到的结果是5。
c,根据雇员id查找交易记录表中的客户id,并按客户id分组,在分组中查找不重复的empid数目等于5的。

  

select custid
from Sales.Orders
where empid in (1,2,3,4,8) group by custid having count(distinct empid)=5

  

我们把上面两个查询还原上去,由于没有以色列的雇员,还是使用美国雇员:

select custid
from Sales.Orders
where empid in
(
select empid from HR.Employees where country = N'USA')
group by custid
having count(distinct empid) = (select count(*) from HR.Employees where country = N'USA')

查询得到的结果是23条记录,符合我们的要求。


 

作者:Tyler Ning
出处:http://www.cnblogs.com/tylerdonet/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,如有问题,可以通过以下邮箱地址williamningdong@gmail.com  联系我,非常感谢。

目录
相关文章
|
4月前
|
SQL 存储 运维
Windows server 2016——SQL server T-SQL查询语句
Windows server 2016——SQL server T-SQL查询语句
69 0
Windows server 2016——SQL server T-SQL查询语句
|
4月前
|
SQL 存储 数据库
SQL 算术运算符:加法、减法、乘法、除法和取模的用法
存储过程是一段预先编写好的 SQL 代码,可以保存在数据库中以供反复使用。它允许将一系列 SQL 语句组合成一个逻辑单元,并为其分配一个名称,以便在需要时调用执行。存储过程可以接受参数,使其更加灵活和通用。
101 0
|
SQL 运维 Cloud Native
【SQL Server】数据库开发指南(五)T-SQL 高级查询综合应用与实战
T-SQL 是 SQL Server 的专用版本,提供了一组强大的高级查询功能,包括聚合函数、子查询、连接、视图、窗口函数、共享表达式、递归查询等。这些功能使得 T-SQL 可以轻松处理大量数据,并支持各种复杂的查询和数据操作。本文将介绍 T-SQL 的一些常见高级查询功能和语法,以及如何使用这些功能来优化 SQL Server 数据库的性能和效率。
233 1
【SQL Server】数据库开发指南(五)T-SQL 高级查询综合应用与实战
|
SQL 存储 数据挖掘
【SQL Server】数据库开发指南(三)面向数据分析的 T-SQL 编程技巧与实践
T-SQL 指的是 Transact-SQL,是一种针对 Microsoft SQL Server 数据库系统的 SQL 方言。T-SQL 扩展了标准 SQL 语言,提供了更多的功能和特性,包括事务处理、错误处理、游标处理、动态 SQL、存储过程、触发器、用户定义函数等等。
152 0
【SQL Server】数据库开发指南(三)面向数据分析的 T-SQL 编程技巧与实践
|
SQL 存储 数据库
数据库SQL Server 8 章(T-SQL)
数据库SQL Server 8 章(T-SQL)
103 0
|
SQL 数据库 索引
【T-SQL基础】01.单表查询-几道sql查询题
【T-SQL基础】01.单表查询-几道sql查询题
184 0
【T-SQL基础】01.单表查询-几道sql查询题
|
SQL 数据库
SQL Server——T-SQL基础技术
SQL Server——T-SQL基础技术
275 0
SQL Server——T-SQL基础技术
|
存储 SQL .NET
SQL Server 2012 T-SQL 新特性
原文:SQL Server 2012 T-SQL 新特性 序列 Sequence SQL Server 现在将序列当成一个对象来实现,创建一个序列的例子语法如下: CREATE SEQUENCE DemoSequence START WITH 1 INCREMENT BY 1; 使用序列的方法如下所表达的: SELECT VALUE FOR DemoSequence 序列与以前的种子列(identity)的区别很明显,种子列只限于当前列,而序列是一个对象层面的实现,则可以在多个表之间共享。
1111 0
|
SQL
SQL点滴20—T-SQL中的排名函数
  提到排名函数我们首先可能想到的是order by,这个是排序,不是排名,排名需要在前面加个名次序号的,order by是没有这个功能的。还可能会想到identity(1,1),它也给了一个序号,但是不能保证给出的序号是连续升序的。
889 0
|
SQL
SQL点滴19—T-SQL中的透视和逆透视
   透视 今天抽一点时间来看看透视和逆透视语句,简单的说就是行列转换。假设一个销售表中存放着产品号,产品折扣,产品价格三个列,每一种产品号可能有多种折扣,每一种折扣只对应一个产品价格。下面贴出建表语句和插入数据语句。
832 0