`
java-mans
  • 浏览: 11981716 次
文章分类
社区版块
存档分类
最新评论

sql连接查询中,where关键字的位置

 
阅读更多

最近一直在忙,也没有太多时间停留下来写博客。晚上遇到一个觉得很有趣的sql题,可能对初学者和我这种菜鸟会有帮助,所以决定分享给大家。

由于笔者天生笨拙,且思维不严谨,也实在不擅长写sql语句,高手请勿见笑,就请直接跳过本文吧。


背景就不多介绍了,先建表,插入测试数据吧。字段那些都有注释

--医生表
CREATE TABLE doctor
    (
      id INT IDENTITY(1, 1) , --ID 自增长
      docNumber NVARCHAR(50) NOT NULL , --医生编码
      NAME NVARCHAR(50) NOT NULL   --医生姓名
    )
go

--插入测试数据
INSERT  INTO doctor
VALUES  ( '007', 'Tom' )
INSERT  INTO doctor
VALUES  ( '008', 'John' )
INSERT  INTO doctor
VALUES  ( '009', 'Jim' )


--号源表(挂号表)
CREATE TABLE Nosource
    (
      id INT IDENTITY(1, 1) ,
      docNumber NVARCHAR(50) NOT NULL , --和医生表中的医生编码对应
      workTime DATETIME NOT NULL
    )

go
--插入测试数据
INSERT  INTO Nosource
VALUES  ( '007', '20120819' )
INSERT  INTO Nosource
VALUES  ( '007', '20120820' )
INSERT  INTO Nosource
VALUES  ( '007', '20120821' )
INSERT  INTO Nosource
VALUES  ( '008', '20120821' )

表建好之后,测试数据也OK。下面开始说需求啦。

1.查出每位医生的相关信息,以及该医生所拥有的号源数量。

这简直太简单了,可能连刚学会helloWorld和一点点数据库基础的朋友都会严重真心BS。不过代码还是写出来。

--简单的分组查询即可搞定
SELECT  COUNT(nos.id) AS PersonNumSounceCOUNT , --总数
        dct.ID AS docID ,
        dct.NAME ,
        dct.docNumber ,
        nos.workTime
FROM    doctor AS dct
        LEFT JOIN Nosource AS nos ON dct.docNumber = nos.docNumber
GROUP BY dct.ID ,
        dct.NAME ,
        dct.docNumber ,
        nos.workTime

确实简单啊。一个小小的分组就能搞定的。还卖什么关子呢。

那现在需求改变,需要按条件去匹配:要求号源表的workTime大于当前日期才算有效的,否则就不匹配。
如果workTime条件不匹配的医生,对应的PersonNumSounceCOUNT字段的值应为0 ;例如:Jim医生没有匹配和符合条件的号源,其PersonNumSounceCOUNT字段值应为0。抬头仰望天空40度,想想能够用where关键字过滤,然后一次性查询出来吗?试试吧。

SELECT  COUNT(nos.id) AS PersonNumSounceCOUNT , --总数
        dct.ID ,
        dct.NAME ,
        dct.docNumber ,
        nos.workTime
FROM    doctor AS dct
        LEFT JOIN Nosource AS nos ON dct.docNumber = nos.docNumber
WHERE   DATEDIFF(day, GETDATE(), nos.workTime) > 0
GROUP BY dct.ID ,
        dct.NAME ,
        dct.docNumber ,
        nos.workTime

相信有人会写出上面的代码来。可是执行查询后,发现完全不符合要求啊。连Jim医生的基本信息和表记录也都被过滤掉了,不见了。咋回事啊?

原因很简单嘛。在连接查询的后面使用"where"关键字,会过滤连接查询的结果集中的数据。由于右表(号源表)的条件不匹配,也会导致左表(医生表)的数据被过滤掉。

所以,会出现以上的现象(Jim医生的信息和记录都不见了)。要想一次性查出来可能吗?到底该如何去实现呢?


其实,正确的写法应该是这样的:

SELECT  COUNT(nos.id) AS PersonNumSounceCOUNT , --总数
        dct.ID ,
        dct.NAME ,
        dct.docNumber ,
        nos.workTime
FROM    doctor AS dct
        LEFT JOIN ( SELECT  *
                    FROM    Nosource
                    WHERE   DATEDIFF(day, GETDATE(), workTime) > 0
                  ) AS nos ON dct.docNumber = nos.docNumber
GROUP BY dct.ID ,
        dct.NAME ,
        dct.docNumber ,
        nos.workTime

再执行一下,果然OK,是满足要求的结果。思路就是:只需要过滤右表,就将(使用子查询)过滤后的结果集作为连接查询的右表,然后再去连接,分组......


这样去解释,不知道大家是否能够理解,反正大致意思就是这样的。笔者的表达能力和水平确实有限,难免有偏差,望读者谅解!



本文出自http://blog.csdn.net/dinglang_2009,转载请注明出处。





分享到:
评论

相关推荐

    sql连接查询中,where关键字的位置讲解

    在SQL查询中,`WHERE`关键字是用来在查询结果中筛选满足特定条件的行。在连接查询(JOIN)中,`WHERE`子句的位置和用法是至关重要的,因为它直接影响到查询的结果。本篇文章将深入讲解`WHERE`在连接查询中的作用,并...

    sql关键字字典大全

    虽然J系列关键字在提供的内容中未提及,但可以推测**JOIN**关键字的存在,用于连接多个表的数据,是SQL中最复杂的操作之一。 #### K系列关键字 - **KEY**:虽然未具体列出,但通常与索引和外键约束相关联,用于...

    SQL常用的关键字

    SQL语言中包含了多种关键字,掌握这些关键字是编写高效SQL语句的基础。下面将详细介绍常用的SQL关键字。 1. 查询语句关键字:SELECT SELECT语句用于从数据库中查询数据。基本语法为:SELECT 字段名 FROM 表名 ...

    经典sql语句笔记(sql 关键字)

    SQL语句通常由一系列关键字组成,比如`SELECT`、`FROM`、`WHERE`、`ORDER BY`等。基本查询语法通常为: ```sql SELECT column1, column2, ... FROM table_name WHERE condition; ``` 其中,`SELECT`用来指定要查询的...

    SQL查询相关技术(常用SQL查询技术、比较逻辑运算符查询、SQL关键字查询、表结构与性能、时间与谓词、聚合函数、子查询与连接查询、交叉表、常用数据操作高级应用、试图存储过程和触发器的使用)

    3. **SQL关键字查询**:SQL的关键字如WHERE、GROUP BY、HAVING、ORDER BY、JOIN等用于构建查询结构。WHERE用于设置查询条件,GROUP BY用于数据分组,HAVING用于对分组后的数据进行筛选,ORDER BY用于排序结果,JOIN...

    sql注入关键字大全

    假设`TestDB`是当前连接的数据库名,此命令用于查询临时表中的数据。 **17. 猜解所有数据库名称** ```sql and (select count(*) from master.dbo.sysdatabases where name > 1 and dbid = 6) <> 0 dbid = 6, 7, 8 ...

    SQL 常用关键字解析

    `DISTINCT` 是一个非常实用的关键字,它可以帮助我们在查询结果中去除重复的记录,只保留唯一的值。例如: ``` SELECT DISTINCT column_name FROM table_name; ``` 此命令将返回表 `table_name` 中 `column_name` 列...

    SQL连接查询语句实例

    总之,SQL连接查询是数据处理的核心部分,它使我们能够从多个表中获取复杂的数据组合。理解并熟练运用内连接、外连接和交叉连接对于任何数据库开发者来说都是至关重要的。通过实践和实验,你可以更好地掌握这些概念...

    数据库sqlserver关键字

    SQL Server 关键字及语法 数据库管理系统(DBMS)中的 SQL Server 是一种关系型数据库管理系统,用于存储、管理和检索数据。为了高效地管理和操作数据库,SQL Server 提供了一系列关键字和语法,以下是 SQL Server ...

    sql查询左连接on与where的区别(2).pdf

    where关键字则用于过滤已经连接之后的结果集,它在连接操作完成后执行,用于进一步筛选满足特定条件的记录。它们的主要区别在于执行顺序和使用场景。 on的运行顺序在join之前,这意味着在连接两张表之前,系统会先...

    SQL SERVER 关键字

    SQL Server关键字是数据库管理系统SQL Server中的重要组成部分,它们在构建SQL查询、定义数据结构和管理数据库操作时起到关键作用。SQL(Structured Query Language)是一种用于处理关系数据库的标准语言,包括了...

    简单的关键字查询

    例如,Python中的`sqlite3`库或`pymysql`库可以用来连接和操作MySQL数据库,执行SQL查询。以下是一个简单的Python示例: ```python import sqlite3 # 连接数据库 conn = sqlite3.connect('database.db') cursor = ...

    SQL WHERE 条件解析器

    `WHERE`子句是SQL查询中的关键部分,用于过滤出满足特定条件的记录。在处理复杂的查询逻辑时,理解和解析`WHERE`条件变得尤为重要。本文将深入探讨`SQL WHERE 条件解析器`这一工具,它在开发列表控件时被广泛使用。 ...

    oracle实现多字段匹配一个关键字查询

    在Oracle中实现多字段匹配一个关键字查询主要有两种方法:一是使用管道符号(||)连接字段;二是使用CONCAT函数连接字段。这两种方法各有优缺点,在实际应用中应根据具体情况选择最适合的方案。为了提高查询效率和准确...

    SQL各种查询方法

    6. **子查询**:在SQL中,一个查询可以嵌套在另一个查询的`WHERE`或`FROM`子句中,这样的查询称为子查询。例如,`SELECT * FROM 表1 WHERE 列1 IN (SELECT 列2 FROM 表2)`。 7. **连接查询**:当需要从两个或更多表...

    仿sqlserver连接查询视图、存储过程等功能

    标题中的“仿sqlserver连接查询视图、存储过程等功能”是指开发的一款软件或应用程序,它模仿了Microsoft SQL Server的一些核心特性,以便用户可以进行数据库管理、查询和操作。这款工具可能提供了与SQL Server类似...

    sql子查询说明

    ### SQL子查询详解 #### 一、子查询概念与应用场景 **子查询**是指在一个查询语句中嵌套另一个查询语句,被...然而,在实际开发过程中,合理选择使用子查询还是连接查询,对于提升查询性能和代码可读性具有重要意义。

    部分普通sql查询在hive中的实现方式

    - **背景**:Hive不支持直接使用`HAVING`关键字,但可以通过嵌套子查询并在外层查询中使用`WHERE`条件来实现类似的功能。 - **示例**:如果想实现如下标准SQL的`HAVING`查询: ```sql SELECT gender, COUNT(*) as...

    Editplus编辑Sql高亮显示关键字

    在空格分隔的文本框中,输入SQL的常用关键字,例如"SELECT", "FROM", "WHERE", "JOIN", "GROUP BY", "HAVING", "ORDER BY"等。确保每个关键字前后都有空格,以便EditPlus正确识别它们。 除了关键字,我们还可以设置...

Global site tag (gtag.js) - Google Analytics