数据库学习笔记day04
select ename,sal,deptno,row_number() over(partition by deptno order by sal desc)rn_num from emp;
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;
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;
--与表同级 只是select语句的结果集
create view emp_10 as
select * from emp where deptno=10;
drop view 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了
--不能更改视图中没有的数据
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;
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的更多相关文章
- MySQL数据库学习笔记(十二)----开源工具DbUtils的使用(数据库的增删改查)
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- MySQL数据库学习笔记(十)----JDBC事务处理、封装JDBC工具类
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- MySQL数据库学习笔记(九)----JDBC的ResultSet接口(查询操作)、PreparedStatement接口重构增删改查(含SQL注入的解释)
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- Mysql数据库学习笔记之数据库索引(index)
什么是索引: SQL索引有两种,聚集索引和非聚集索引,索引主要目的是提高了SQL Server系统的性能,加快数据的查询速度与减少系统的响应时间. 聚集索引:该索引中键值的逻辑顺序决定了表中相应行的物 ...
- MYSQL数据库学习笔记1
MYSQL数据库学习笔记1 数据库概念 关系数据库 常见数据库软件 SQL SQL的概念 SQL语言分类 数据库操作 创建数据库 查看数据库的定义 删除数据库 修改数据库 创建表 数据类型 约束 ...
- [转]mnesia数据库学习笔记
mnesia数据库学习笔记一 mnesia数据库学习笔记二 mnesia数据库学习笔记三 mnesia数据库学习笔记四
- 数据库学习笔记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 ...
- Caché数据库学习笔记(5)
目录 Cache数据库方法的RESTful封装 ================================================================ 因为对web serv ...
- MySQL数据库学习笔记(八)----JDBC入门及简单增删改数据库的操作
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
随机推荐
- openstack网络(二)
连接物理服务器 单网卡 多网卡 跨主机安装网络服务 使用单个控制节点安装 使用专用网络节点安装 连接物理服务器 每个物理主机所需的网卡数量取决于云平台使用领域,组织的安全性和性能要求以及硬件的可用性. ...
- Thymeleaf的语法详解
字符串操作,日期转换 <span th:text="hello"></span><hr/> <span th:text="${m ...
- [TimLinux] JavaScript querySelectorAll返回对象无法使用indexOf问题
1. querySelectorAll 该函数返回的对象类型为NodeList,这个类型并没有indexOf方法,如果需要使用indexOf方法,需要先将该对象每一项转存入Array对象中,然后就可以 ...
- [TimLinux] myblog 数据表格显示
1. 设计 2. 数据 创建数据库用户: CREATE USER IF NOT EXISTS 'user1'@'MyBlogPwd123'; GRANT ALL ON d1.* TO 'user1'@ ...
- I_want_all 2019训练记录
Team members StarHai binarycopycode Fly_White Caution 读题 数组第一维的访问速度比其他维速度快. 清空数组 乘法运算取模里面涉及到减法注意变为负数 ...
- 洛谷 题解 P5015 【标题统计】 NOIP2018 普及组 T1
没有人用 scanf("%c", &ch) != EOF 吗? scanf 和 EOF 会伤心的. 思路:逐个读入字符,遇到EOF中止,对于每个读入的字符进行判断. 附上考 ...
- 使用flink实现一个topN的程序
topN功能是一个非常常见的功能,比如查看最近几分钟的阅读最高数,购买最高数. flink实现topN的功能也非常方便,下面就开始构建一个flink topN的程序. 还是像上篇博客一样,从kafka ...
- unity3d 随机添加树木
开放世界随机地图才是最重要的.. 随机生成树木 Terrain.terrainData //获取地形设置 terrainData.treePrototypes {get;set;} //获取或设置树木 ...
- webpack学习_webpack-dev-server自动编译代码
之前每次修改完之后都要执行npm run build来编译,下面有三种方式可以实现代码变化后自动编译代码,下面只重点说webpack-dev-server,其他的请看webpack开发文档 1.web ...
- CCF-CSP题解 201809-4 再卖菜
碎碎念..近视加老花,还以为第二天除了第二家范围在100以内别的都不确定,于是x**算的记搜复杂度超时了.还鼓捣着什么差分区间最长路,虽然有大神用差分区间做出来了,然而自己并没有看懂. 其实就是一个记 ...