返回顶部
首页 > 资讯 > 数据库 >Oracle入门学习四
  • 923
分享到

Oracle入门学习四

Oracle入门学习四 2017-05-24 10:05:48 923人浏览 绘本
摘要

上一篇:oracle入门学习三 学习视频:https://www.bilibili.com/video/BV1tJ411r7EC?p=35 Oracle表连接:内连接、外连接。外连接分左连接、右连接。 多表查询时,如果表之间没有条

Oracle入门学习四

上一篇:oracle入门学习

学习视频:https://www.bilibili.com/video/BV1tJ411r7EC?p=35

Oracle表连接:内连接、外连接。外连接分左连接、右连接。

多表查询时,如果表之间没有条件关联,则会把所有匹配的结果查找出来,例如A表6条数据,B表7条数据,查出来就是42条。

--笛卡尔积:返回两张表中所有匹配的结果,没有意义。所以多表查询,必须写关联条件。
select * from staff,department where staff.id=department.staff_id;
View Code

内连接的表如果多于两个,则每个表必须要直接或者间接的关联。例如查A、B、C表,条件A.某列=B.某列 and A.某列=C.某列,则B表和C表有间接的关联。

多表关联时,其中某列必须唯一,例如查表A、B、C,A.Column1 = B.Column2 and A.Column3=C.Column4,其中Column1和Column2至少有一列在自己的表里是唯一值,

Column3和Column4至少有一列在自己的表里是唯一值。

非等值表连接:

select ename,sal from emp e,salgrade g
where e.sal between g.losal and g.hisal 
--这个losal到hisal的区间范围是唯一的
grade losal hisal 1 700 1200 2 1201 1400 3 1401 2000 4 2001 3000 5 3001 9999

 自连接:自己关联自己,但是作为不同表的定义,自连接一般可以使用子查询替代,使用子查询会更加清晰。

--自连接,将emp看做是两张不同的表,e是员工表,m是领导表
select distinct m.empno, m.ename, m.sal
  from emp e, emp m
 where e.mgr = m.empno
--自连接用的情况不多,可以使用子查询实现
  select * from emp m where m.empno in (select distinct mgr from emp)

外连接:主表中的数据全部选出,从表只选匹配的数据,不匹配的数据会用null替代。

外连接中的左外连接,左边是主表,右边是从表。外连接中的右外连接,右边是主表,左边是从表。

create table testa(
id number(3),
name varchar2(10),
age number(2)
);

insert into testa values(1,"a",23);
insert into testa values(2,"b",24);
insert into testa values(3,"c",25);
insert into testa values(4,"d",26);

create table testb(
id number(3),
salary number(8,2)
);

insert into testb values(1,9000);
insert into testb values(2,9000);
insert into testb values(3,9000);

select * from testa left join testb on testa.id=testb.id;
select * from testa right join testb on testa.id=testb.id;

分页查询:借助“rownum”伪列进行分页查询。

--分页查询,每页五条,查询第二页数据6-10
--使用伪列,不真正的存在表里
select rownum from emp ;
select a.*,rownum from emp a;
select * from (select a.*,rownum r from emp a) x where x.r>5 and x.r<=10;
View Code
最内层:即将被分页的全部数据,可能会被排序,定义成x表。
select * from emp;
中间层:启动行编号伪列,定义成y表
select x.*,rownum r from x;
最外层:数据过滤,分页开始
select * from y where y.r >0 and r<=10

 

日期添加与转换:

--查询系统日期
select sysdate from dual;
--向前走一天 明天
select sysdate+1 from dual;
--向后走一天 昨天
select sysdate-1 from dual;
--下个月的今天
select add_months(sysdate,1) from dual;
--上个月的今天
select add_months(sysdate,-1) from dual;
-- 加1小时,1分,1秒
select sysdate+1/24+1/(24*60) + 1/(24*60*60) from dual

 日期截取:

select trunc(sysdate) from dual; --默认精确到天
select trunc(sysdate,"dd") from dual; --精确到天
select trunc(sysdate,"mm") from dual;--精确到月
select trunc(sysdate,"yyyy") from dual;--精确到年
select trunc(sysdate,"hh") from dual;--精确到时
select trunc(sysdate,"mi") from dual;--精确到分

 

 



您可能感兴趣的文档:

--结束END--

本文标题: Oracle入门学习四

本文链接: https://lsjlt.com/news/5842.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Oracle入门学习四
    上一篇:Oracle入门学习三 学习视频:https://www.bilibili.com/video/BV1tJ411r7ECp=35 Oracle表连接:内连接、外连接。外连接分左连接、右连接。 多表查询时,如果表之间没有条件...
    99+
    2017-05-24
    Oracle入门学习四
  • Oracle入门学习五
    学习视频: https://www.bilibili.com/video/BV1tJ411r7ECp=35 数据的完整性:保证插入表格的数据必须正确。包括实体完整性、区域完整性、引用完整性、自定义完整性。 约束:约束的作用是为了保...
    99+
    2022-04-01
    Oracle入门学习五
  • Oracle入门学习六
    事务:把一组操作看做一个工作单元,要么都执行,要么都不执行。dml操作才有事务,查询没有事务。 开始事务:从上一次的事务结束之后,从第一次dml操作,就自动开启了事务 提交事务:commit 回滚事务:rollback cr...
    99+
    2021-12-10
    Oracle入门学习六
  • Oracle入门学习一
    oracle的安装,用户授权,表格操作,数据类型,ddl表格,dml数据。 下一篇:Oracle入门学习二 学习视频:https://www.bilibili.com/video/BV1tJ411r7ECp=15 安装教程附带...
    99+
    2018-09-30
    Oracle入门学习一
  • Oracle入门学习二
    上一篇:Oracle入门学习一 学习视频:https://www.bilibili.com/video/BV1tJ411r7ECp=15 算术运算符:+ - * / 逻辑运算符:and or not 比较运算符:“=”、“”、“=...
    99+
    2014-07-13
    Oracle入门学习二
  • Oracle入门学习三
    上一篇:Oracle入门学习二 学习视频:https://www.bilibili.com/video/BV1tJ411r7ECp=26 字符串函数:length、upper、lower、initcap、 concat、instr...
    99+
    2021-08-20
    Oracle入门学习三
  • Oracle(PLSQL)入门学习七
    学习视频:https://www.bilibili.com/video/BV1tJ411r7ECp=74 设计数据库步骤: 良好的数据库设计:节省空间,数据完整,方便开发。 步骤:1、收集信息 2、标识实体 3、标识实体属性 4、...
    99+
    2017-10-20
    Oracle(PLSQL)入门学习七
  • Oracle学习(一) --- 入门安装
    1.2、特点: 1.2.1、完整的数据管理功能 1)数据的大量性 2)数据的保存的持久性 3)数据的共享性 4)数据的可靠性 1.2.2、完备关系的产品 1)信息准则---关系型DBMS的所有信息都应在逻辑上用一种方法,即表中的值显式地表示...
    99+
    2019-05-09
    Oracle学习(一) --- 入门安装
  • MySQL入门学习
    ...
    99+
    2015-02-25
    MySQL入门学习
  • Node.js学习入门
    开始之前,安利一本正在看的书《站在两个世界的边缘》,作者程浩,上帝丢给他太多理想,却忘了给他完成理想的时间。OK,有兴趣的可以看一看。 node.js如标题一样,我也是刚开始接触,大家一起学习,有不当的地方...
    99+
    2022-06-04
    入门 Node js
  • python入门学习
    首先在官网下载好python3.6及以上的版本,根据自己的系统选择:没有显示64位的就是32位的安装包,选择蓝线的能够直接打开 在控制台输入python,配置成功的图片如下: 从IDLE打开python输入指令 print("I lo...
    99+
    2023-01-31
    入门 python
  • Oracle(PLSQL)入门学习八(完结篇)
    学习视频:https://www.bilibili.com/video/BV1tJ411r7ECp=75 游标cursor:用于存放多条数据的容器。需要开始open和关闭close。游标下移使用“fetch...into...”。...
    99+
    2022-04-06
    Oracle(PLSQL)入门学习八(完结篇)
  • Python机器学习入门(四)之Python选择模型
    目录1.数据分离与验证1.1分离训练数据集和评估数据集1.2K折交叉验证分离1.3弃一交叉验证分离1.4重复随机分离评估数据集与训练数据集2.算法评估2.1分类算法评估2.1.1分类...
    99+
    2024-04-02
  • Oracle学习(四) --- DQL语法
    标准DQL语法 select distinct * | 列名 as 别名, 列表2 as 别名2... | 聚合函数 from 表名 as 别名, 表名2 as 别名2 ,.... where 查询条件 group by...
    99+
    2017-09-05
    Oracle学习(四) --- DQL语法
  • 学习Oracle的历程 (四)
         前面,我们学习了在Oracle中学习了DML操作,可以我们添加数据、修改数据、删除数据,当我说到这里难免有大部分人觉得有点别扭,感觉缺少了点什么 没错,作为编程的根本四要素之一,我们怎么只能去修改、添加、删除、而不去查看数据呢 ...
    99+
    2019-06-08
    学习Oracle的历程 (四)
  • Python入门学习(六)
    在熟悉了Python中常用的一些内置函数, 那接下来我们定义一个自己的函数吧 def add(x, y): return x + y 函数 函数语法 def functonname(parameters): ... ...
    99+
    2023-01-31
    入门 Python
  • Django 入门学习(3)
    在例4的基础上,我希望直接保存数据到数据库中。 Django自带了一个sqlite的数据库,已经配置好了 可以直接使用。使用方式和sqlalchemy类似,相当于一个内置的ORM框架。settings.py 默认已经绑定了sqlite3DA...
    99+
    2023-01-31
    入门 Django
  • java入门学习之路
    java是面向对象的编程,个人觉得记忆比较重要。第一阶段java基础部分unix开发环境熟练掌握开发中常用的操作系统linux的安装及使用:掌握文件系统、网络、用户管理方法:能熟练使用vi和vim进行文件编...
    99+
    2024-04-02
  • PyTorch 深度学习入门
    💂 个人网站:【 海拥】【萌怪大冒险】【2048】🤟 风趣幽默的前端学习课程:👉28个案例趣学前端💅 想寻找共同学习交流、摸鱼划水的...
    99+
    2023-09-25
    pytorch 深度学习 python
  • menuconfig与Kconfig入门学习
    概述 menuconfig是Linux平台用于管理代码工程、模块及功能的实用工具。 menuconfig的使用方式通常是在编译系统之前在系统源代码根目录下执行make menuconfig命令从而打开...
    99+
    2023-09-13
    学习 linux 服务器
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作