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;

相关内容

热门资讯

不良率上升倒逼防线前移 银行收... 银行正在给个人信贷风控“上强度”。上海证券报记者近期自业内多方了解到,不少银行零售信贷业务从审批权限...
自媒体新手如何快速涨粉?这5个... 自媒体新手如何快速涨粉?这5个技巧让你少走弯路! 嗨,我是小融。 最近很多刚入门自媒体的朋友问我,怎...
乌兰察布市财政局关于黄金领域非... 乌兰察布市财政局关于黄金领域 非法金融活动风险提示 近期,黄金价格波动频繁,市场热度持续攀升,各类假...
一只鸡蛋架“直发”俄罗斯 无锡... (来源:无锡新传媒) 转自:无锡新传媒 一只3D打印塑料鸡蛋架,成为无锡国际邮件互换局正式开通运营后...
武汉楼市开启红五月 新房成交量... 原标题:武汉楼市开启红五月 数据爆表,新房成交量较去年同期翻番 武汉城建未来中心项目营销中心现场来...
一家精神病院竟现身A股公司前十... 5月8日,有投资者发现,盛通股份前十大股东名单中,竟出现了一家精神病院的身影。这家精神病院全称为“上...
真的老了!哈登心魔难除 骑士还... 哈登又拉胯了。 刚刚过去的两场东部半决赛,骑士都输的相当狼狈,而哈登的发挥更是灾难级的。 半决赛G1...
精神病院通报成上市公司前十大股... 近日,上市公司盛通股份发布一季报,披露了前十大股东名单。其中,一家名为“上饶市广丰区十五岭山精神病医...
天溯计量发布年报 上市首年检测... 转自:中国经营网 文 近日,计量检测机构天溯计量(301449.SZ)发布了2025年年度报告。年...
原创 全... 美伊真要停火了? 一页纸协议让全球油价闪崩! 就在今天,全球市场被一条消息炸开了锅。美国白宫觉得,他...
百信银行业绩:26Q1净利润大... 4月底,中信百信银行股份有限公司(下称“百信银行”)2025年财报及2026年一季度报接连披露—— ...
美光科技股价单周飙升38% 市... 【CNMO科技消息】受全球内存芯片短缺影响,美光科技股价本周大幅上涨。截至周五收盘,美光股价报746...
江西一精神病院炒股,炒成上市公... 近日,上市公司盛通股份(002599.SZ)发布一季报,披露了前十大股东名单,其中一家名为“上饶市广...
专访中国太保副总裁俞斌:从“+... 拥抱AI(人工智能),不再是保险行业的“选择题”,而是关乎企业生存与发展的“必答题”,更是企业决胜未...
多平台优化算法:美团取消超时扣... 图片来源:界面图库 5月8日,网信中国发布消息称,生活服务类平台算法治理已取得初步成效,美团、淘宝、...
原创 2... 2025年,国内系统重要性银行名单正式公布。这是我国金融体系的核心支柱,一共21家银行入选,它们是维...
东海县供销总社:“供销+龙头企... 近日,东海县供销合作总社鼎味泰直营店正式开业。作为东海县供销系统打造的新型社企便民服务网点,该门店的...
原创 阿... 深夜,一家零食店铺的客服后台弹出一条消息:“我上次买的芒果干,这次想换个不那么酸的口味,再帮我推荐几...
和平湾全新项目前瞻 负公摊、唯... 在沈阳,如果想在主城核心区域找一块容积率低于1.5的住宅用地,难度有多大? 过去三年,沈阳主城核心区...
精神病院与国际投行高盛同在 盛... 近日,盛通股份(002599.SZ)发布一季报,其前十大股东名单中,第九位为“上饶市广丰区十五岭山精...