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.losal select * 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 join select * 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.deptno select * 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.分析跟踪语句 === ...
随机推荐
- 浅入不深出--vuex的简单使用
什么是vuex,官网的描述是:Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.状态管理模式包含3个部分: 1.state,驱动应用的数据源: 2.view,以声明方式将state映射到 ...
- 2019.12.09 java循环(do……while)
class Demo05{ public static void main(String[] args) { int sum=0; int i=1; do{ sum+=i; i++; }while(i ...
- _purecall函数
默认纯虚拟函数调用错误处理程序. 当调用纯虚拟成员函数时,编译器生成调用此函数的代码. 原型: extern "C" int __cdecl _purecall(); _Purec ...
- 使用jmx-exporter&&jmxtrans && nexus jmx 暴露nexus 系统指标信息
以下演示一个简单的使用jmxexporter 暴露nexus jmx 指标为prometheus metrics,同时也集成了一个简单的jmxtrans 输出数据到 graphite 环境准备 doc ...
- 利用 PHP CURL zip压缩文件上传
$postData['file'] = "@".getcwd()."/../attachment/qianbao/{$customer_id}.zip"; $t ...
- JavaScript高级程序编程(一)
第一章 JavaScript简史 20170510 JavaScript 组成部分: 核心(ECMAScript) 文档对象模型(DOM)浏览器对象模型(BOM) Netscape Navigat ...
- chown与chmod的区别
chown 修改文件和文件夹的用户和用户组属性 1.要修改文件hh.c的所有者.修改为sakia的这个用户所有 chown sakia hh.c 这样就把hh.c的用户访问权限应用到sakia作为所有 ...
- ASP.NET MVC5+EF6+EasyUI 后台管理系统-代码生成器用法
新的代码生成器比老的更加容易使用,要生成什么形式就选择什么形式,新的代码生成器采用的是WCF界面开发,同样采用开源的模式,根据自己使用习惯容易扩展 1.单列表模式 2.树形列表模式 3.左右列表模式 ...
- 微信小程序之确认框实现
效果图如下: 核心代码如下: delType:function(e){ var typeId = e.currentTarget.dataset['id']; console.log("de ...
- Server concepts 详解
server status 是由 vm_state和task_state 计算出来的,vm_state是虚机当前的稳定状态(例如Active, Error),task_state是虚机当前的瞬间状态( ...