高级查询
随机返回5条记录
select * from (select ename,job from emp order by dbms_random.value())where rownum<=5;
处理空值排序
select * from emp order by comm desc nulls last(first);
查询跳过表中的偶数行
select ename from (select row_number() over (order by name) rn,ename from emp) x where mod(rn,2)=1;
查询员工信息与其中工资最高最低员工
select enmae,sal,max(sal) over(),min(sal) over() from emp;
连续求和
select ename,sal,sum(sal) over(),sum(sal) over(order by name) from emp;//sum(sal) over(order by ename)指的是连续求和,以ename排序的。若有两个这样的窗口函数,以后面的排序为主
分部门连续求和
select deptno,sal,sum(sal) over(partition by deptno order by ename) s from emp;
得到当前行上一行或者下一行的数据
select enamel,sal,lead(sal) over(order by sal) aaa,lag(sal) over (order by sal) bbb from emp;
根据子串分组
select to_char(hiredate,'yyyy'),avg(sal) from emp group by to_char(hiredate,'yyyy');
确定一年内的天数
select add_months(trunc(sysdate,'y'),12)-trunc(sysdate,'y') from dual;
trunc(sysdate,'X')时间截取函数,X表示参数
dd--截取今天
d-截取本周第一天
mm-截取本月第一天
y-年
hh-小时
mi-分钟
查询EMP员工表下每个部门工资前两名的员工信息
select deptno,ename,sal from emp e1 where (select count(*) from emp e2 where e2.deptno=e1.deptno and e1.ename!=e2.ename and e2.sal>e1.sal)<2 order by deptno,sal desc;
select * from (select deptno,ename,sal,row_number() over (partition by deptno order by sal desc)rn from emp)where rn<3;
rownum 是伪列
一个表中的ID有多个记录,把所有这个ID的记录查出来,并显示共有多少条记录数。(华为面试题)
select id ,count (*) from tb group by id having count(*)>1;
数据字典
查询某用户下所有表
select table_name fom all_tables where owner='scott'
查询EMP表中所有字段(列)
select * from all_tab_columns where table_name='emp'
列出表的索引列
select * from sys.all_ind_columns where table_name='EMP';
列出表中约束
select * from all_comstraints where table_name='EMP';
在oracle中描述数据字典视图
select table_name ,comments from dictionary where table_name like '%TABLE%';
Oracle 数据类型
由于char是固定长度的,所以它的速度会比varchar2快得多!但程序处理起来麻烦一点,要用trim之类的函数把两边的空格去掉
varchar2一般适用于英文和数字,Nvarchar2适用于中文和其他字符,其中N表示Unicode常量,可以解决多语言字符集之间的转换问题
Number(4,2)指的是整数占两位,小数占2位
Number默认为38位
数据类型
number(p[,s])p表示有效数据位数,s表示小数位
varchar2()在oracle有更好的兼容性,基本不用varchar
date to_date('2015-01-01 13:14:15','yyyy-mm-dd hh24:mi:ss')分钟为mi因为sql中不区分大小写
Oracle 体系结构
DDL(改变表结构)
建表
create table test
(
ID number(5) primary key,--主键
name varchar2(10) not null,--非空
birthday date,
email varchar2(25) unique,--唯一
age number check(age between 0 and 150),--check约束
deptno number references emp(id) on delete cascade --外键 级联删除
)
create table emp3 as select * from emp where sal >1000;
显示表结构:describe test
删除表:drop table test
修改表名称:rename test to testing
--------------------对字段操作-----------------------------------
增加列 alter table test add address varchar2(40);
删除列 alter table test drop column address;
修改列名称 alter table test address
插入数据 insert into test values(1,'ling',3000,1)
insert into test (eno,salary) values(3,3000)
修改数据 update test set ename='zhangsan' where eno=3;
删除数据 delete test (无条件删除所有数据,逐条删除)
truncate test (不产生回退信息,速度快)
delete from test where eno=3;
删除一张表重复记录,age,name相同即为重复记录,id是自增唯一的
delete from test where id not in (select min(id) from test group by name,age);
DML(改变数据结构)
表间数据拷贝 insert into dept(id,name) select deptno,dnamem from dept;
update myemp set (job,mgr)=(select job mgr from myemp where empno=7556)where empno=7779;
merge into test2
using test1
on(test1.eid=test2.eid)
when matched then update set name=test1.name,birth=test1.birth,sal=test1.sal
when not matched then insert (eid,name,birth,sal) values(test1.eid,test1.name,test1.birth,test1.sal);
约束
not null--非空约束
primary key--主键约束(不能重复,不能为空)
unique--唯一约束,值不能重复(空值除外)
check--条件约束,插入的数据必须满足某些条件
foreign key--外键
添加主键 alter table person add constraint person_pid_pk PRIMARY KEY(pid)
添加唯一约束 alter table person add constraint person_tel_uk UNIQUE(tel)
添加检查约束 alter table person add constraint person _age_ck CHECK(age between 0 and 150)
添加主-外键约束,要求带级联删除 alter table book add constraint person_book_pid_fk FOREIGN KEY(pid) REFERENCES person(pid) ON DELETE CASCADE;
删除约束
alter table student drop unique(tel)
alter table book drop CONSTRAINT person_book_pid_fk
启用约束 ALTER TABLE book enable CONSTRAINT person_book_pid_fk;
禁用约束 ALTER TABLE book disable CONSTRAINT person_book_pid_fk;
视图
创建视图 CREATE VIEW 视图名字(字段) AS 子查询
CREATE VIEW empv20 (empno,ename,sal) AS select empno,ename,sal from emp where deptno=20;
高级视图
create or replace view empv20 (deptno,msal) as (select deptno,min(sal) from emp group by deptno having min(sal)>(select min(sal) from emp where deptno=20)) with check option constraint empv20_ck;
SQL优化
1.尽量少用IN操作符
2.尽量用NOT EXISTS 或者外连接替代NOT IN操作符
3.尽量不用“<>”或者“!=”操作符
4.在设计表时,把索引列设置为NOT NULL
5.尽量不用通配符“%”或者“_”作为查询字符串的第一个字符
6.Where 字句中避免在索引列上使用计算
7.用“>=”替代“>”
8.利用SGA共享池,避开parse阶段
9.where后面的条件顺序要求
10.使用表别名,并将之作为每列的前缀
11.进行了显式或隐式的运算字段不能进行索引
12.UNION all代替union
13.其他操作
尽量使用packages
尽量使用cached sequence 来生成 primary key
很好的利用空间:如用varchar2数据类型代理char等
利用SQL优化工具:如SQLexpert,toad,explain-table,PL/SQL;OEM
14.通过改变oracle的SGA(数据库的系统全局区)的大小
笔试题
设有关系EMP(ENO,ENAME,SALARY,DNO)其中各属性的含义依次为职工号、姓名、工资、所在部门号, 以及关系DEPT(DNO,DNAME,MANAGER)其中各含义依次为部门号、部门名称、部门经理的职工号
1.请通过SQL语句创建表EMP、DEPT。
create table emp(eno number(5) primary key ,ename varchar2(5),salary number(8),dno number(3));
create table dept(dno number(3) primary key,dname varchar2(10),manager number(5));
2.试用SQL语句完成以下查询:列出各部门中工资不低于600元的职工的平均工资。
select avg(salary) from emp where salary>=600;
3.写出“查询001号职工所在部门名称”的关系代数表达式
select dname from dept where dno in (select dno from emp where eno='001')
4.请用SQL语句将”销售部“的那些工资低于600元的职工工资上调10%。
update emp set salary=salary*1.1 where sal<600 and dno=(select dno from dept where dname='销售部')
5.请用SQL语句查询”销售部“员工数量
select count (*) from emp group by dno where dno in (select dno from dept where dname="销售部")
- oracle从零开始学习笔记
查询现有数据库:select name from V$database; 解锁用户scott:alter user scott account unlock; 普通用户连接:conn scott 默认 ...
- oracle从零开始学习笔记 二
多表查询 等值连接(Equijoin) select ename,empno,sal,emp.deptno from emp,dept where dept.deptno=emp.deptno; 非等 ...
- Oracle学习笔记三 SQL命令
SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)
- Oracle RAC学习笔记:基本概念及入门
Oracle RAC学习笔记:基本概念及入门 2010年04月19日 10:39 来源:书童的博客 作者:书童 编辑:晓熊 [技术开发 技术文章] oracle 10g real applica ...
- Oracle RAC学习笔记01-集群理论
Oracle RAC学习笔记01-集群理论 1.集群相关理论概述 2.Oracle Clusterware 3.Oracle RAC 原理 写在前面: 最近一直在看张晓明的大话Oracle RAC,真 ...
- Oracle基础学习笔记
Oracle基础学习笔记 最近找到一份实习工作,有点头疼的是,有阶段性考核,这...,实际想想看,大学期间只学过数据库原理,并没有针对某一数据库管理系统而系统的学习,这正好是一个机会,于是乎用了三天时 ...
- 从零开始学习jQuery (三) 管理jQuery包装集
本系列文章导航 从零开始学习jQuery (三) 管理jQuery包装集 一.摘要 在使用jQuery选择器获取到jQuery包装集后, 我们需要对其进行操作. 本章首先讲解如何动态的创建元素, 接着 ...
- [Firefly引擎][学习笔记三][已完结]所需模块封装
原地址:http://www.9miao.com/question-15-54671.html 学习笔记一传送门学习笔记二传送门 学习笔记三导读: 笔记三主要就是各个模块的封装了,这里贴 ...
- JSP学习笔记(三):简单的Tomcat Web服务器
注意:每次对Tomcat配置文件进行修改后,必须重启Tomcat 在E盘的DATA文件夹中创建TomcatDemo文件夹,并将Tomcat安装路径下的webapps/ROOT中的WEB-INF文件夹复 ...
随机推荐
- hadoop2的思想架构
mapreduce 2 思想架构 mr2解决了mr1的jobTracker的单点颈瓶问题,这个问题会影响hadoop的扩展性,集群的可靠性,mr1中jobTracker负责集群作业的分发,管理,调度, ...
- Android Studio增加NDK代码编译支持--Mac环境
Android的APP开发基本都是使用Java或者跨平台框架进行开发的,对于很多APP来说已经足够了,但是,对于提供功能给外部使用或者性能要求很高的需求下,如图像处理等,可能会需要C/C++库的支持, ...
- Git TortoiseGit SSH设置
Git TortoiseGit SSH设置 http://www.cnblogs.com/ChenRihe/p/Git_TortoiseGit_SSH.html TortoiseGit默认的SSH客户 ...
- [译]:Orchard入门——Orchard控制面板概览
原文链接:Getting Around the Dashboard 文章内容基于Orchard 1.8版本 Orchard控制面板用于管理网站.改变外观.添加内容以及控制Orchard功能可用性.成功 ...
- Python学习笔记(二)——HelloWorld
一.交互式化环境下书写代码 二.使用文本编辑器编辑.py文件 1.建议,使用Nodepad++,好看,免费,度娘直接搜素即可. 2.编写代码 3.保存为.py结尾的文件 4.使用cmd,打开到文件所在 ...
- oj Rapid Typing
import bs4 import requests import urllib2 import time import base64 session=requests.Session() respo ...
- Nagios配置文件详解
首先要看看目前Nagios的主配置路径下有哪些文件.[root@nagios etc]# ll总用量 152-rwxrwxr-x. 1 nagios nagios 1825 9月 24 14:40 ...
- java IO流 Zip文件操作
一.简介 压缩流操作主要的三个类 ZipOutputStream.ZipFile.ZipInputStream ,经常可以看到各种压缩文件:zip.jar.GZ格式的压缩文件 二.ZipEntry ...
- Spark 自定义累加变量(Accmulator)AccumulatorParam
1.创建一个累加变量 public <T> Accumulator<T> accumulator(T initialValue, AccumulatorParam<T&g ...
- NOIP2015D1
好像来的有点晚,但我的确现在刚做这套题 T1神奇的幻方 题目描述 幻方是一种很神奇的N*N矩阵:它由数字1,2,3,……,N*N构成,且每行.每列及两条对角线上的数字之和都相同. 当N为奇数时,我们可 ...