oracle SQL语句之子查询

在一个查询语句包含另外一个查询语句
可以写在from后面当一个新表使用
可以写在where子句中,作为条件
可以写在update语句中
可以写delete语句中的where子句中
--子查询的分类
单行子查询:返回最多一行数据。 运算符 =,!=,>,>=,<,<=
多行子查询:返回最少一行  运算符:any,all (any,all 与=,!=,>,>=,<,<=  一起使用),in
--按列
单列子查询

多列子查询

-------------------单行子查询
--查询工资最高的员工信息(编号,姓名,职位,工资)
select empno,ename,job,sal
from emp
where sal =(select max(sal) from emp);
--查询高于平均工资的员工信息((编号,姓名,职位,工资)
select empno,ename,job,sal
from emp
where sal>(select avg(sal) from emp);

--------------------多行子查询
--查询工资高于 7788,7369,7900中任意一个员工工资的信息
select empno,ename,sal
from emp
where sal >any(select sal from emp
where empno in(7788,7369,7900))   --950 3000 800 >最小值
order by sal;
--查询领导的信息(编号,姓名,职位,工资)
select  empno,ename,sal
from emp
where empno in(select distinct mgr from emp);
--查询不是领导的信息
select  empno,ename,sal
from emp
where empno not in(select distinct mgr from emp where mgr is not null);
--多列子查询(子查询结果的列的个数为多个)
--查询与'SMITH'同一部门并且同一职位的员工信息
select empno ,ename,job,deptno
from emp
where deptno = (select deptno from emp where ename='SMITH')
and job =(select job from emp where ename='SMITH');

select empno ,ename,job,deptno
from emp
where (deptno,job)=(select deptno,job from emp where ename='SMITH');
--查询每个部门中最高工资的员工信息
select empno,ename ,sal,deptno
from emp
where (deptno,sal)in
(select deptno,max(sal)
from emp
group by deptno);

--查询10号部门 最高工资的员工信息
select empno,ename,sal
from emp
where deptno=10 and sal=(select max(sal) from emp where deptno=10);

--分页查询
/*
1、总页数:19
    select ceil(count(rowid)/pagecount) from emp;
    
2、当前页码 :pageindex
3、显示的数据的个数:  pagecount;  3
select *
from (
select rownum rn,empno,ename,job,sal from
(select empno,ename,job,sal from emp order by sal))
where rn>(pageindex-1)*pagecount and rn<=pageIndex*pagecount;
或:
select *
from (
select rownum rn,empno,ename,job,sal from
(select empno,ename,job,sal from emp order by sal) where rownum<pageindex*pagecount)
where rn>(pageindex-1)*pagecount ;

rownum:行号
*/
--按员工工资排序升序
--第一页的数据
select empno,ename,job,sal
from emp
where rownum<=3
order by sal;
----------
select *
from (
select rownum rn,empno,ename,job,sal from
(select empno,ename,job,sal from emp order by sal))
where rn>(pageindex-1)*pagecount and rn<=pageIndex*pagecount;
--第二页
select *
from (
select rownum rn,empno,ename,job,sal from
(select empno,ename,job,sal from emp order by sal))
where rn>3 and rn<=6;
--第三页
select *
from (
select rownum rn,empno,ename,job,sal from
(select empno,ename,job,sal from emp order by sal))
where rn>6 and rn<=9;

----------------------------
--要求,查询10号部门的员工信息(分页显示,每页显示两条数据,并按工资升序显示)
select * from(select rownum rn,empno,ename,job,sal from (
select empno,ename,job,sal from emp where deptno=10 order by sal))
where rn>0 and rn<=2;
--
select * from(select rownum rn,empno,ename,job,sal from (
select empno,ename,job,sal from emp where deptno=10 order by sal))
where rn>2 and rn<=4;

select e.empno,e.ename,e.job,e.sal,e.hiredate,d.dname
from emp e inner join dept d using(deptno)
where ename like '%A%';

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 要将Oracle SQL语句转化为MySQL SQL语句,需要注意以下几点: 1. 日期和间函数:MySQL和Oracle的日期和间函数有些差异,需要对部分函数进行调整。例如,将Oracle的sysdate函数替换为MySQL的current_date函数,将Oracle的to_char函数替换为MySQL的date_format函数。 2. 字符串函数:Oracle和MySQL的字符串函数用法有些不同。例如,将Oracle的substr函数替换为MySQL的substring函数,将Oracle的instr函数替换为MySQL的locate函数。 3. 数据类型:某些数据类型在Oracle和MySQL中的表示方式不同,需要将其进行转换。例如,将Oracle的number类型转换为MySQL的decimal类型,将Oracle的varchar2类型转换为MySQL的varchar类型。 4. 分页查询Oracle和MySQL分页查询的语法也有所差异。在Oracle中,可以使用rownum来进行分页,而在MySQL中,可以使用limit和offset来实现。因此,在转换查询语句,需要将Oracle的rownum替换为MySQL的limit和offset。 5. NULL值处理:Oracle和MySQL对NULL值的处理方式也有些差异。在Oracle中,可以使用is null和is not null来判断NULL值,而在MySQL中,可以使用is null和is not null,也可以使用isnull函数。 总之,将Oracle SQL语句转化为MySQL SQL语句需要注意这些差异,并根据具体情况进行适当调整和转换。实际操作中,可以参考MySQL的官方文档和手册,以便获得更详细和准确的转换规则和示例。 ### 回答2: 将Oracle SQL语句转化为MySQL SQL语句通常需要注意以下几个方面: 1. 数据类型:Oracle和MySQL的数据类型有所不同,需要根据情况进行转换。例如,将Oracle的NUMBER数据类型转换为MySQL的INT或FLOAT类型。 2. 函数和操作符:Oracle和MySQL支持的函数和操作符有所不同,需要根据需求进行调整和替换。例如,将Oracle的TO_CHAR函数转换为MySQL的DATE_FORMAT函数。 3. 子查询和连接:Oracle和MySQL的子查询和连接语法也有所差异,需要进行适当调整。例如,将Oracle子查询使用WITH语句转换为MySQL的内部子查询。 4. 约束和索引:Oracle和MySQL的约束和索引语法也有差异,需要进行相应修改。例如,将Oracle的UNIQUE约束转换为MySQL的UNIQUE关键字。 下面是一个具体的例子,将OracleSQL语句转换为MySQL的SQL语句Oracle SQL语句: SELECT emp_name, hire_date FROM employees WHERE emp_id = 100; MySQL SQL语句: SELECT emp_name, hire_date FROM employees WHERE emp_id = 100; 这是一个简单的例子,在实际转换过程中可能会遇到更多的复杂情况,需要根据具体需求进行相应的调整和修改。同需要注意两种数据库的差异,以免出现语法错误或逻辑错误。另外,还可以通过使用一些第三方工具来自动完成SQL语句的转换,可以节省间和精力。 ### 回答3: 要将Oracle SQL语句转化为MySQL SQL语句,需要注意一些Oracle特有的函数、关键字和语法在MySQL中可能没有或有不同的实现。下面是一些常见的转化技巧: 1. 字符串连接: Oracle中使用"||"作为字符串连接符,而MySQL使用"CONCAT"函数。例如: Oracle:SELECT firstname || ' ' || lastname FROM employees; MySQL:SELECT CONCAT(firstname, ' ', lastname) FROM employees; 2. 日期格式化: Oracle中使用"TO_CHAR"函数进行日期格式化,而MySQL使用"DATE_FORMAT"函数。例如: Oracle:SELECT TO_CHAR(hiredate, 'YYYY/MM/DD') FROM employees; MySQL:SELECT DATE_FORMAT(hiredate, '%Y/%m/%d') FROM employees; 3. 行号: 在Oracle中,可以使用"ROWNUM"来获取行号,而MySQL需要使用子查询和变量来实现类似的功能。例如: Oracle:SELECT * FROM employees WHERE ROWNUM <= 10; MySQL:SELECT * FROM employees WHERE id <= (SELECT id FROM employees ORDER BY id LIMIT 1 OFFSET 9); 4. 分页查询: 在Oracle中使用"ROWNUM"和"FETCH FIRST"实现分页查询,而MySQL使用"LIMIT"和"OFFSET"。例如: Oracle:SELECT * FROM employees WHERE ROWNUM > 10 AND ROWNUM <= 20; MySQL:SELECT * FROM employees LIMIT 10 OFFSET 10; 5. 自增主键列: 在Oracle中使用"SEQUENCE"和"TRIGGER"来生成自增主键值,而MySQL使用"AUTO_INCREMENT"关键字。例如: Oracle:CREATE SEQUENCE seq_emp_id START WITH 1 INCREMENT BY 1; CREATE TRIGGER tr_emp_id BEFORE INSERT ON employees FOR EACH ROW BEGIN SELECT seq_emp_id.nextval INTO :NEW.id FROM dual; END; MySQL:CREATE TABLE employees (id INT PRIMARY KEY AUTO_INCREMENT, firstname VARCHAR(50), lastname VARCHAR(50)); 需要注意的是,这只是一些常见的转化技巧,具体的转化还需要根据具体的SQL语句和数据库结构进行调整和适配。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值