--row_number()over(partition by xxx order by xxx)分组排序函数 特点:组内连续且唯一
select ename,sal,deptno,row_number() over(partition by deptno order by sal desc)rn_num from emp;
--rank()over(partition by xxx order by xxx)分组排序函数  特点 组内不连续且不唯一
select ename,sal,deptno,rank()over(partition by deptno order by sal desc)rn_num2 from emp;
--dense_rank()over(partition by xxx order by xxx)分组排序函数 特点:组内连续不唯一
select ename,sal,deptno,dense_rank()over(partition by deptno order by sal desc)rn_num3 from emp;
--并集 union:去掉重复的部分
select ename,job,sal,deptno from emp where sal>2500
union
select ename,job,sal,deptno from emp where deptno=20;
--union all:不会去掉重复的部分
select ename,job,sal,deptno from emp where sal>2500
union all
select ename,job,sal,deptno from emp where deptno=20;
--交集 intersect
select ename,job,sal,deptno from emp where sal>2500
intersect
select ename,job,sal,deptno from emp where deptno=20;
--差集minus:我有你没有
select ename,job,sal,deptno from emp where sal>2500
minus
select ename,job,sal,deptno from emp where deptno=20;
--创建视图  create table name xxx as
--与表同级      只是select语句的结果集
create view emp_10 as
  select * from emp where deptno=10;
select * from emp_10;
drop view emp_10;
--将emp表中的miller的薪资改为1500,视图emp_10的薪资会不会发生变化
update emp set sal=1500 where ename='miller';             --都为1500了
commit;
--将emp_10 clark的薪资改为2500,看表emp中clark的薪资有无变化
update emp_10 set sal=2500 where ename='clark';
select * from emp where ename='clark';                    --都为2500了
--通过视图将james的薪资改为6000
--不能更改视图中没有的数据
create view emp_james as
  select * from emp where ename='james';
select * from emp_james;
update emp_james set sal=6000 where ename='james';
--连接视图
create view name_loc as
  select ename,loc from emp join dept on emp.deptno=dept.deptno;
select * from name_loc;
--数据污染:通过视图插入影响到了基表(视图无影响)
insert into emp_10 values(1000,'tom','player','7934',to_date('2008-08-08','yyyy-mm-dd'),8000,1,10);  
--查看视图时会显示这条信息,emp表也有∧
insert into emp_10 values(1001,'jerry','player','7934',to_date('2007-12-31','yyyy-mm-dd'),7000,1,20); 
--查看视图时无这条,但emp表中会有,这是数据污染∧
--避免数据污染
drop view emp_10;
create view emp_10 as
  select * from emp where deptno=10 WITH CHECK OPTION;   
  insert into emp_10 values(1000,'tom','player','7934',to_date('2008-08-08','yyyy-mm-dd'),8000,1,10);
  insert into emp_10 values(1001,'jerry','player','7934',to_date('2007-12-31','yyyy-mm-dd'),7000,1,20); -- (这行会报错)
 
--创建序列开始位置为1,步幅为1
--创建序列后要先执行一次nextval
--序列是数据库内部维护的一个对象,可以自增自减得一个值
create sequence emp_seq  start with 1 increment by   1;        --给emp添加序列
select emp_seq.nextval from dual;
select emp_seq.currval from dual;
create table asd(
id number(4),
name varchar2(20),
age number(2),
adress varchar2(100)
);
insert into asd values(emp_seq.nextval,'cdd',20,'2#101');
insert into asd values(emp_seq.nextval,'cmm',20,'2#102');
select * from asd;
--索引 为了提高查询效率而创建,它是独立于表的结构,一旦创建则由oracle自动维护。
create index emp_ename on emp(ename);
drop index emp_ename;
select ename from emp;
--复合索引
create index emp_ename_sal on emp(ename,sal);
drop index emp_ename_sal;
select ename,sal from emp;
--重建索引
alter index emp_ename_sal rebuild;
--非空约束创建表
create table emp_nn(
id number(4) not null,
name varchar2(20) unique,               ---唯一约束①
tel varchar2(20) constraint nn not null,
name2 varchar2(20),
CONSTRAINT emp_nn_name2_uk UNIQUE(name2)--唯一约束②
);
insert into emp_nn values(emp_seq.nextval,'卢法斯','13233333333','Li');
--insert into emp_nn values(emp_seq.nextval,'龙马','13233333333','Li');     错误实例
select * from emp_nn;
drop table emp_nn;
--主键
create table mainkey(
id number(2,0),
name varchar2(14 byte),
loc varchar2(13)
);

数据库学习笔记day04的更多相关文章

  1. MySQL数据库学习笔记(十二)----开源工具DbUtils的使用(数据库的增删改查)

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  2. MySQL数据库学习笔记(十)----JDBC事务处理、封装JDBC工具类

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  3. MySQL数据库学习笔记(九)----JDBC的ResultSet接口(查询操作)、PreparedStatement接口重构增删改查(含SQL注入的解释)

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  4. Mysql数据库学习笔记之数据库索引(index)

    什么是索引: SQL索引有两种,聚集索引和非聚集索引,索引主要目的是提高了SQL Server系统的性能,加快数据的查询速度与减少系统的响应时间. 聚集索引:该索引中键值的逻辑顺序决定了表中相应行的物 ...

  5. MYSQL数据库学习笔记1

      MYSQL数据库学习笔记1 数据库概念 关系数据库 常见数据库软件 SQL SQL的概念 SQL语言分类 数据库操作 创建数据库 查看数据库的定义 删除数据库 修改数据库 创建表 数据类型 约束 ...

  6. [转]mnesia数据库学习笔记

    mnesia数据库学习笔记一 mnesia数据库学习笔记二 mnesia数据库学习笔记三 mnesia数据库学习笔记四

  7. 数据库学习笔记3 基本的查询流 2 select lastname+','+firstname as fullname order by lastname+','+firstname len() left() stuff() percent , select top(3) with ties

    数据库学习笔记3 基本的查询流 2   order by子句对查询结果集进行排序 多列和拼接 多列的方式就很简单了 select firstname,lastname from person.pers ...

  8. Caché数据库学习笔记(5)

    目录 Cache数据库方法的RESTful封装 ================================================================ 因为对web serv ...

  9. MySQL数据库学习笔记(八)----JDBC入门及简单增删改数据库的操作

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

随机推荐

  1. vs2017/vs2019 去掉 单击aspx文件预览页面

    初次安装vs2017或者vs2019,新建的项目中,每次单击项目文件时,文件自动打开了 然后 打开 工具->选项->环境->选项卡和窗口->预览选项卡->勾掉" ...

  2. Dubbo加权轮询负载均衡的源码和Bug,了解一下?

    本文是对于Dubbo负载均衡策略之一的加权随机算法的详细分析.从2.6.4版本聊起,该版本在某些情况下存在着比较严重的性能问题.由问题入手,层层深入,了解该算法在Dubbo中的演变过程,读懂它的前世今 ...

  3. iSensor APP 之 摄像头调试 OV5642 续集2

    参考上一篇博客 作为续集,主要测试 RAW格式下的 不同分辨率效果 iSensor APP 之 摄像头调试 OV5642 直接上图吧 720p 拍照效果

  4. 【Eureka】集群搭建

    [Eureka]集群搭建 转载============================================== ====================================== ...

  5. 这道面试必问的JVM面试题70%的Java程序员会做错

    前言 聊聊JVM,一个熟悉又陌生的名词,从认识Java的第一天起,我们就会听到这个名字,在参加工作的前一两年,面试的时候还会经常被问到JDK,JRE,JVM这三者的区别. JVM可以说和我们是老朋友了 ...

  6. 手动SQL注入原理分析与实践

    代码仓库 本文所用代码的代码库地址: 点击这里前往Github仓库 了解SQL注入 定义 SQL注入攻击(SQL Injection),简称注入攻击,是Web开发中最常见的一种安全漏洞.可以用它来从数 ...

  7. 你不知道的JavaScript(中)读书笔记(二)

    第三章 原生函数 常用的原生函数(内建函数)有: String() Number() Boolean Array() Object() Function() RegExp() Date() Erroe ...

  8. pt-online-schema-change工具使用教程(在线修改大表结构)

    percona-toolkit中pt-online-schema-change工具安装和使用 pt-online-schema-change介绍 使用场景:在线修改大表结构 在线数据库的维护中,总会涉 ...

  9. Git详细教程之创建本地仓库和连接Github仓库

    首先要知道不只有代码,任何类型的文件都可以进行版本控制,版本控制很重要的一个特性就是你可以随时修改,比如git会记录你的任何操作,如果你想要回退到任何一个历史操作,你可以通过git轻松达到. 本地仓库 ...

  10. HttpRunner学习11--指定用例运行次数

    前言 在HttpRunner中,一般情况下,我们写的用例脚本都是每次运行一次,如果我们想要指定用例运行的次数,可以通过 times 关键字来实现. 测试场景 在这里,我们以访问 TesterHome ...