热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

深进浅出SQL教程之嵌套SELECT语句

嵌套SELECT语句也叫子查询,形如:SELECTnameFROMbbcWHEREregion=(SELECTregionFROMbbcWHEREname='Brazil')一个SELECT语句的查询成果可以作为另一个语句的输进值。上面的SQL语句作用为获得和

嵌套SELECT语句也叫子查询,形如:

SELECT name FROM bbc WHERE region = (SELECT region FROM bbc WHERE name = 'Brazil')

一个 SELECT 语句的查询成果可以作为另一个语句的输进值。

上面的SQL语句作用为获得和'Brazil'(巴西)同属一个地区的所有国家。

子查询不但可以呈现在Where子句中,也可以呈现在from子句中,作为一个临时表应用,也可以呈现在select list中,作为一个字段值来返回。本节我们仅先容的Where子句中的子查询。

在Where子句中应用子查询,有一个在实际应用中轻易犯的错在这里阐明一下。

通常,就像上面的例子一样,嵌套的语句总是和一个值进行比拟。

语句 (SELECT region FROM bbc WHERE name = 'Brazil') 应当仅返回一个地区,即 'Americas'. 但假如我们在表中再插进一条地区为欧洲,国家名称为Brazil的记录,那会产生什么情况?

这将会导致语句的运行时错误.由于这个SQL语句的语法是准确的,所以数据库引擎就开端履行,但当履行到外部的语句时就出错了。

由于这时的外部语句就像似乎是 SELECT name FROM bbc WHERE region = ('Americas', 'Europe'),这个语句当然报错了。

那么有没有措施解决这个标题呢,当然有。有一些SQL查询条件答应对列表值(即多个值)进行把持。

例如"IN" 把持符,可以测试某个值是否在一个列表中。

下面的语句就可以安全的履行而不出错,不管表中有多少条包含Brazils的记录

以下为引用的内容:
SELECT name FROM bbc WHERE region IN
(SELECT region FROM bbc WHERE name = 'Brazil')

让我们再看看一些具体的实例

一、给出人口多于Russia(***)的国家名称

以下为引用的内容:
SELECT name FROM bbc
WHERE population>
(SELECT population FROM bbc
WHERE name='Russia')

二、给出'India'(印度), 'Iran'(伊朗)所在地区的所有国家的所有信息

以下为引用的内容:
SELECT * FROM bbc
WHERE region IN
(SELECT region FROM bbc
WHERE name IN ('India','Iran'))

三、给出人均GDP超过'United Kingdom'(英国)的欧洲国家。

以下为引用的内容:

SELECT name FROM bbc
WHERE region='Europe' AND gdp/population >
(SELECT gdp/population FROM bbc
WHERE name='United Kingdom')




推荐阅读
  • 应用程序配置详解
    本文介绍了配置文件的关键特性及其在不同场景下的应用,重点探讨了Machine.Config和Web.Config两种主要配置文件的用途和配置方法。文章还详细解释了如何利用XML格式的配置文件来调整应用程序的行为,包括自定义配置、错误处理、身份验证和授权设置。 ... [详细]
  • Web安全入门:MySQL基础操作与SQL注入防范
    本文详细介绍了MySQL数据库的基础操作命令,包括数据库和表的基本管理,以及数据的增删查改等常用操作。同时,针对Web安全领域常见的SQL注入问题,提供了初步的理解和防范措施。 ... [详细]
  • mysql 分库分表策略_【数据库】分库分表策略
    关系型数据库本身比较容易成为系统瓶颈,单机存储容量、连接数、处理能力都有限。当单表的数据量达到1000W或100G以后,由于查询维度较多, ... [详细]
  • 解析程序员与软件工程师的角色差异
    本文深入探讨了程序员与软件工程师之间的主要区别,包括它们的职业定位、技能要求以及工作内容等方面的不同,旨在帮助读者更好地理解这两个角色的特点。 ... [详细]
  • 尝试从 MySQL 转向 SQL Server 2008 时遇到了安装错误,提示“系统配置未能初始化”,错误代码为 0x84B10001。怀疑可能是由于之前的 MySQL 安装残留导致的注册表问题。寻求专家建议。 ... [详细]
  • 解决getallheaders函数导致的500错误及8种服务器性能优化策略
    本文探讨了解决getallheaders函数引起的服务器500错误的方法,并介绍八种有效的服务器性能优化技术,包括内存数据库的应用、Spark RDD的使用、缓存策略的实施、SSD的引入、数据库优化、IO模型的选择、多核处理策略以及分布式部署方案。 ... [详细]
  • 本文是网络安全自学系列的一部分,旨在分享网络安全工具的使用技巧和实际操作案例。继之前讨论了XSS跨站脚本攻击的各个方面后,本文将重点介绍Powershell的基础知识及其在网络安全领域的应用。 ... [详细]
  • 一人有限公司的风险与应对策略
    创业者在选择公司形式时,往往对一人有限公司存在误解。虽然表面上看似简单易操作,但实际上,这种公司形式隐藏着较大的法律风险,尤其是在股东责任方面。本文将深入探讨为何应谨慎考虑注册一人有限公司,并提供相应的风险管理建议。 ... [详细]
  • 本文针对公司项目中普遍存在的IE浏览器兼容性问题,特别是IE9及以下版本,提出了具体的解决方案,确保用户在这些旧版浏览器中也能顺利实现图片上传预览功能。 ... [详细]
  • 本文提供了一套详细的步骤,指导用户如何通过科学上网方法注册一个美国地区的Apple ID,包括设置地区、语言及完成注册的具体操作。 ... [详细]
  • 在现代多线程编程中,Lock接口提供的灵活性和控制力超越了传统的synchronized关键字。Lock接口不仅使锁成为一个独立的对象,还提供了更细粒度的锁定机制,例如读写锁(ReadWriteLock)。本文将探讨如何利用ReentrantReadWriteLock提高并发性能。 ... [详细]
  • 项目管理可细分为九个层次,每个层次都代表着不同的能力和视角。本文将详细介绍这九个层次的内容,帮助读者评估自身所处的阶段,并提供进一步学习和发展的方向。 ... [详细]
  • java锁策略
    文章目录锁的分类一、乐观锁VS悲观锁二、读写锁三、可重入锁VS不可重入锁四、重量级锁VS轻量级锁五、公平锁VS非公平锁六、自旋锁VS挂起等待锁七、锁升级策略1、无锁: ... [详细]
  • 本文详细探讨了当前主流的两种系统架构——C/S(客户端/服务器)与B/S(浏览器/服务器)架构的特点、优缺点及未来的发展趋势。 ... [详细]
  • 解决Win10播放设备故障的有效步骤
    当用户尝试播放媒体文件时,有时会遇到播放设备无法正常工作的错误提示。这种情况可能由多种原因引起,包括驱动程序问题或系统更新后的兼容性问题等。本文将提供一系列解决方案,帮助用户快速解决问题。 ... [详细]
author-avatar
不想与你见面_637
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有