sql数据库查询相关操作,SQL的应用——SQL多表连查、子查询、多行子查询
|
1
|
**SQL多表连查** |
|
1
2
3
4
5
6
7
8
|
--查询员工和部门信息select * from emp e,dept d where e.deptno=d.deptno--查询员工姓名,部门名称select e.ename,d.dname from emp e,dept d where e.deptno = d.deptno--查询所有员工姓名,部门名称select e.*, d.dname from emp e,dept d where e.deptno=d.deptno--查询工资大于3000的员工姓名,工资和部门名称select e.ename,e.sal,d.dname from emp e,dept d where e.deptno=d.deptno and e.sal>=3000 |
|
1
2
3
4
|
--非等值查询--查询公司工资等级select * from emp e,salgrands where e.sal<=s.hisal and e.sal>s.losalselect * from salagrade |
|
1
2
3
4
5
|
--外链接--左外连接select*from emp e,dept d where e.deptno=d.deptno(+)--右外连接select*from emp e,dept d where e.deptno(+)=d.deptno |
|
1
2
3
4
5
6
|
--自连接--查询员工姓名和经理姓名select e1.ename ,e2.ename from emp e1,emp e2 where e1.mgr=e2.deptno--查询员工姓名、经理姓名和其他经理姓名select e1.ename,e2.ename,e3.ename from emp e1,emp e2, emp e3 where e1.mgr=e2.empno and e2.empno=e3.empno |
|
1
|
**以上为92版仅在面试出现** |
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
--SQL99 表连接--交叉连接 cross joinselect *from emp e cross join dept d--自然连接 natural join select *from emp natural join dept--using select e.ename,deptno from emp e join dept d using(deptno)--on 自定义连接select *from emp e join dept d on e.deptno=d.deptnoselect *from emp e1 join emp e2 on e1.mgr=e2.empno--查询员工的姓名、经理及其经理的名字select e1.ename,e2.ename,e3.ename from emp e1 join emp e2 on e1.mgr=e2.empno join emp e3 on e2.mgr=e3.empno--SQL99 inner join 两边都合法的数据select*from emp e inner join dept d on e.deptno=d.deptno--left join 以左表为主select*from emp e left join dept d on e.deptno=d.deptno--right join 以右表为主select*from emp e right join dept d on e.deptno=d.deptno--full join 全连 取两个表的所有数据select*from emp e full join dept d on e.deptno=d.deptno----查询员工的姓名、经理及其经理的名字和部门名字select e1.ename, d.dname, e2.ename, d2.dname from emp e1 left join dept d on e1.deptno = d.deptno left join emp e2 on e2.mgr = e2.empno left join dept d2 on d2.deptno = d2.deptno |
|
1
|
**子查询** |
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
--比CLARK工资高的人select SAL from emp where ename='CLARK'select *from emp where sal>(select SAL from emp where ename='CLARK')--查询工资高于平均工资的雇员姓名和工资select avg(sal) from emp select ename,sal from emp where sal>(select avg(sal) from emp )--查询同SCOTT同部门的且工资比他低的员工的名字和工资select deptno from emp where ename='SCOTT'select sal from emp where ename='SCOTT'select ename, sal from emp where deptno = (select deptno from emp where ename = 'SCOTT') and sal < (select sal from emp where ename = 'SCOTT')--查询和'SMITH','SCOTT','CLARK'同一个部门的员工姓名select distinct deptno from emp where ename in('SMITH','SCOTT','CLARK')select * from emp where deptno in (select distinct deptno from emp where ename in ('SMITH', 'SCOTT', 'CLARK'))--查询和'SMITH', 'SCOTT', 'CLARK'同一个部门并不包含他们三个的员工姓名 and ename not in ('SMITH', 'SCOTT', 'CLARK')--查询工资最高的员工名字和工资select ename,sal from emp where sal=(select max(sal)from emp )--查询职务和'SCOTT'相同但是比'SCOTT'雇佣时间早的雇员信息select * from emp where job = (select job from emp where ename = 'SCOTT') and hiredate < (select hiredate from emp where ename = 'SCOTT')--查询工资比'SCOTT'高或者雇佣时间比'SCOTT'早的雇员编号和姓名select empno,ename from emp where job = (select job from emp where ename = 'SCOTT') and hiredate < (select hiredate from emp where ename = 'SCOTT') |
|
1
|
**多行子查询** |
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
--查询工资低于任何一个“CLERK”的工资的雇员信息select*from emp where sal all (select sal from emp where job = 'SALESMAN')--查询部门20中职务同部门10的雇员一样的雇员信息。select *from emp where job in (select job from emp where deptno=10)and deptno=20--查询在雇员中有哪些人是经理人select * from emp where empno in (select distinct mgr from emp where mgr is not null or mgr != '')--找出部门编号为20的所有员工中收入最高的职员select ename from emp where sal = (select max(sal) from emp where deptno = 20) and deptno = 20</any(select> |
sql数据库查询相关操作,SQL的应用——SQL多表连查、子查询、多行子查询的更多相关文章
- PHP对MySQL数据库的相关操作
一.Apache服务器的安装 <1>安装版(计算机相关专业所用软件---百度云链接下载)-直接install<2>非安装版(https://www.apachehaus.com ...
- SQL SERVER: 合并相关操作(Union,Except,Intersect)
SQL SERVER: 合并相关操作(Union,Except,Intersect) use tempdb create table tempTable1 (id int primary key id ...
- python操作mysql数据库的相关操作实例
python操作mysql数据库的相关操作实例 # -*- coding: utf-8 -*- #python operate mysql database import MySQLdb #数据库名称 ...
- SQL数据库的基础操作
一,认识SQL数据库 美国Microsoft公司推出的一种关系型数据库系统.SQLServer是一个可扩展的.高性能的.为分布式客户机/服务器计算所设计的数据库管理系统,实现了与WindowsNT的有 ...
- SQL数据库的一些操作
--以 MySQL为例 //登陆 mysql -u root -p //创建一个名为test_lib的数据库 CREATE DATABASE test_lib //删除一个名为test_lib的数据库 ...
- SQL数据库问题 解释一下下面的代码 sql 存储过程学习
SQL数据库问题 解释一下下面的代码 2008-08-13 11:30wssqyl2000 | 分类:数据库DB | 浏览1154次 use mastergocreate proc killspid( ...
- Android下的SQLite数据库的相关操作及AndroidTestCase测试
一:创建数据库 package com.itcode.mysqlite; import android.content.Context; import android.database.sqlite. ...
- MySql数据库的相关操作
SQL(Structred Query Language)结构化查询语言:和数据库交互的语言,进行数据库管理的语言. 一.数据库的操作: 1.查询所有数据库: show databases; 2.创建 ...
- 十、K3 WISE 开发插件《SQL Profiler跟踪单据操作时产生的SQL语句》
=================================== 目录: 1.查询帐套的数据库DBID 2.配置需要跟踪数据库的DBID 3.配置跟踪参数 4.跟踪进行 5.分析跟踪语句 === ...
随机推荐
- AnsiString
原文链接:https://blog.csdn.net/Li_Ning_/article/details/82981092 /* * 编号:Number 1 * 函数:substring * 说明:截取 ...
- 23-ESP8266 SDK开发基础入门篇--编写Android TCP客户端 , 加入消息处理
https://www.cnblogs.com/yangfengwu/p/11203546.html 先做接收消息 然后接着 public class MainActivity extends App ...
- [Gradle] 解决高德 jar 包打包到 aar 后 jar 包中的 assets 内容丢失
问题描述 将高德 SDK 的 jar 包放到 android library project libs 目录下,发布为 aar 包后,发现高德 jar 包中的 assets 目录下的内容不见了 原因见 ...
- Linux启动与停止Tomcat
停止Tomcat: cd 切换到Tomcat的bin目录下,关闭命令:[root@localhost bin]# ./shutdown.sh 检查tomcat是否已关闭,检查命令:[root@loca ...
- 【NOIP2017模拟测试(10-28)】平衡树
平衡树解题报告 Description 小D最近又在种树,可是他的种树技巧还是很差,种出的树都长的歪七扭八,为了让树变得平衡一些,小D决定从树上删掉一条边,然后再加上一条边,使得到的仍然是一棵树并且这 ...
- 排序---希尔排序Java
希尔排序 插入排序的一种又称“缩小增量排序”,是直接插入排序算法的一种更高效的改进版本.希尔排序是非稳定排序算法. 希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序:随着增量逐渐减 ...
- node省市区三级数据性能测评
闲来无事,测试下node和egg 首先是数据库,大概长这样 然后是代码 'use strict'; const Controller = require('egg').Controller; clas ...
- Mac php 装imagick扩展 菜鸟教程
1.2.直接brew install imagemagick@6完成安装 2.去http://pecl.php.net/package/imagick下载安装包 2.1.下载完后解压tar -xzvf ...
- Net core学习系列(一)——Net Core介绍
一.什么是Net Core .NET Core是适用于 windows.linux 和 macos 操作系统的免费.开源托管的计算机软件框架,是微软开发的第一个官方版本,具有跨平台 (Windows. ...
- 第06组 Alpha冲刺(5/6)
队名:拾光组 组长博客链接 作业博客链接 团队项目情况 燃尽图(组内共享) 组长:宋奕 过去两天完成了哪些任务 主要完成了个人中心模块的接口设计 完善后端的信息处理 GitHub签入记录 接下来的计划 ...