oracle从入门到精通第四篇(伪表|伪列|Rownum|联合关键字|序列)
admin
2024-02-08 04:15:01
0

文章目录

    • 伪表(DUAL 表)
    • 伪列(RowID)
    • 行号(Rownum)
    • 联合关键字:
      • union:结果唯一
      • union all:结果不唯一
      • intersect:求交集
      • minus:从第一个查询结果集中减去第二个查询结果中重复的数据
      • in:表示符合查询结果中的任意一个值
      • not in:表示条件不能是查询结果中的任意一个值
      • some/any:这个和in用法相同
      • all:表示比所有值都大,比所有值都小
    • 序列:sequence
      • 查看序列的下一个值:
      • 查看序列的当前值:
      • 查看当前用户下有哪些序列:
      • 如何修改序列:
      • 如何删除序列:

伪表(DUAL 表)

该表主要目的是为了保证在使用SELECT语句中的语句的完整性而提供的。

一般用于验证函数。例如:

select sysdate,to_char(sysdate,'yyyy-mm-dd HH24:mm:ss') from dual

伪列(RowID)

rowid = 是映射数据库中每一条数据物理地址的唯一标识

适用于删除完全重复的数据

delete from lyric where rowid not in (select min(rowid) from lyric group by content);

行号(Rownum)

这是Oracle根据查询结果动态的编号,用来实现分页查询
1)有序的整数列,每多一条自动加1
2)不能和order by在同一个查询语句中,order by会打乱查询的顺序
3)不能使用表名.rownum的写法
4)如果rownum用在where之后,rownum >= 1 rownum<= 任意值

1.实现第一页数据,编号1-10

SELECTrownum,substr( content, 1, 10 ) || '...' 
FROMlyric 
WHERErownum BETWEEN 1 AND 10;
select rownum,content from lyric where rownum between 1 and 10;

2.实现第二页数据,编号11-20

SELECT* 
FROM( SELECT rownum rn, content FROM lyric WHERE rownum <= 20 ) a 
WHEREa.rn >= 11;

3.实现第三页数据,编号21-30

SELECT* 
FROM( SELECT rownum rn, content FROM lyric WHERE rownum <= 30 ) a 
WHEREa.rn >= 21;

4.实现带有排序效果的分页

SELECT* 
FROM( SELECT rownum rn, content FROM ( SELECT * FROM lyric ORDER BY content ) WHERE rownum <= 20 ) a 
WHEREa.rn >= 11;

5.我们常见的分页是如何实现的:
curpage:当前页 2 3
pagesize:每页行数 10 25
当前页的开始数:(curpage -1) * pagesize +1 11 51
当前页的截止数:curpage * pagesize 20 75

联合关键字:

union:结果唯一

select name from school where name like '%大'
union
select name from school where name like '山%';

union all:结果不唯一

select name from school where name like '%大'
union all
select name from school where name like '山%';

intersect:求交集

select * from school where name like '%大'
intersect
select * from school where name like '山%';

minus:从第一个查询结果集中减去第二个查询结果中重复的数据

select * from school where name like '%大'
minus
select * from school where name like '山%';

in:表示符合查询结果中的任意一个值

条件 in (值1,值2…)
相当于:条件 = 值1 or 条件 = 值2 or …

select * from school where id in (select sid from student);

not in:表示条件不能是查询结果中的任意一个值

条件 not in (值1,值2…)
相当于:条件 <> 值1 and 条件 <> 值2 and …

select * from school where id not in (select sid from student);

some/any:这个和in用法相同

in用在无符号的情况
some/any用在有符号的情况

 select * from school where id = some (select sid from student);select * from school where id < any (select sid from student);

all:表示比所有值都大,比所有值都小

select * from school where id > all (select sid from student);

***:

any >min

练习
查询工资高于20号部门某个员工工资的员工的信息

*:因为in的效率较低,所以用exists代替
exists:存在

select * from school where exists (select sid from student where student.sid = school.id);

not exists:不存在

select * from school where not exists (select sid from student where student.sid = school.id);

序列:sequence

一个单独的数据对象,每多一条自动加一
*:Oracle通过调用序列来实现主键自增
*:在一个新的会话中,必须调用下一个值才能查看当前值
*:序列调用下一个值,会作为下次调用的初始值

创建序列:

create sequence seq_test – 序列名
increment by 1 – 一次增长1
start with 1 – 从1开始
minvalue 1 – 最小值
maxvalue 100 – 最大值
cycle – 循环 默认不循环
nocache; --不缓存 默认缓存20

查看序列的下一个值:

select seq_test.nextval from dual;

查看序列的当前值:

select seq_test.currval from dual;

1.消除延迟段创建特性

alter system set deferred_segment_creation = false;

2.创建表

create table test2(id number(3),name varchar2(20));

3.创建序列

create sequence seq_test2;

4.新增数据

insert into test2 values(seq_test2.nextval,'橘子');
insert into test2 values(seq_test2.nextval,'苹果');

5.查询数据

select * from test2;

查看当前用户下有哪些序列:

select * from user_sequences;

如何修改序列:

alter sequence seq_test increment by 50;

如何删除序列:

drop sequence seq_test;

相关内容

热门资讯

原创 油... 2026年1月24日蛋价:蛋价“火箭”上涨,破3入4! 近日,国内鸡蛋市场,蛋价迎来了“春天”,受春...
原创 得... 特朗普上台不久,就将目光锁定在格陵兰岛——对他而言,这不仅仅是一块冰封的土地,而是一枚战略棋子,足以...
面临裁员无可奈何,亚马逊员工内... 来源:市场资讯 (来源:IT之家) IT之家 1 月 24 日消息,据《商业内幕》(Business...
2026投资指南,嘉实基金投策... 来源:时代周报-时代在线 2026年是“十五五”规划的开局之年,也是布局中国经济高质量发展红利的关键...
2026年首家!又一具身智能企... 1月23日,记者获悉,星海图(北京)人工智能科技有限公司已于2026年1月完成工商变更,正式更名为“...
原创 历... 在历经千年战争的漫长历史中,有一种特殊的战斗形式至今依旧困扰着军事指挥官们,那就是攻城战。从古至今,...
宁德时代钠电池量产上车,“钠锂... 1月22日,宁德时代正式推出行业首款量产钠离子电池(以下简称“钠电池”),这款适配小微卡、中小VAN...
“十四五”营收利润显著增长,宜... 来源:市场资讯 (来源:云酒头条) 在全国白酒行业普遍承压的背景下,作为川酒核心产区的宜宾,其...
白银价格持续上涨 工厂加班赶制... 本文转自【央视财经】; 国际银价创出历史新高的同时,国内银价也持续飙升,2025年至今以来,同比上涨...
芯片巨头,暴跌超17%! 周五(1月23日),美股三大股指收盘涨跌不一。 截至收盘,道琼斯工业指数跌0.58%报49098.7...
原创 从... 小时候读《范进中举》,总觉得那个故事荒诞可笑、夸张至极。范进那时候几乎废寝忘食地读书,却依旧困窘潦倒...
证监会1号罚单!余韩,被罚没超... 1月23日,证监会发布了2026年的1号罚单。 罚单显示,2019年6月至2024年8月期间,余韩控...
柯尼卡美能达智慧医疗自助打印解... (1月23日,上海) 在国家“互联网+医疗健康”政策的大力推动下,中国各级医院的数字化转型步入快车道...
新董事长操盘,中国移动新成立两... 通信老柳2026-01-24 10:29:00 据悉,中国移动新董事长上任后对内部进行了一系列管理创...
再现13.08%反对票!村镇银... 来源:每日经济新闻 13.08%的反对票比例,近日在苏州农商行2026年第一次临时股东会上,吸收合并...
币安考虑重启美股代币 全球加密... 来源:滚动播报 全球多家大型加密货币交易所正竞相推出可追踪美股走势的加密代币交易服务,打造出一个不受...
男子用SIM卡炼出近200克黄... 1月20日,广东一男子用170多公斤的手机SIM卡芯片废料,经过一系列复杂工序后,成功炼出191.7...
全国共有395家网约车平台公司... 据网约车监管信息交互系统监测,截至2025年12月31日,全国共有395家网约车平台公司取得网约车平...
原创 俄... 买岛惹争议,关税当杠杆 这事儿的起点,其实很“特朗普”:把地缘政治当成一笔能谈的交易。 特朗普在20...
原创 黄... 以前,苹果一直是台积电的最大客户,其贡献的营收占台积电的总营收,超过20%,妥妥的最大金主。 所以对...