Oracle Day05 集合与数据处理
1.集合
--集合操作: 并集、交集、差。
select deptno,job,sum(sal) from emp group by deptno,job
union
select deptno,to_char(null),sum(sal) from emp group by deptno
union
select to_number(null),to_char(null),sum(sal) from emp;
select deptno,job,sum(sal)
from emp
group by rollup(deptno,job);
上述两种表达结果相同。
-- 集合操作需要注意的事项:
1). 集合的所有列应该数量相同,类型相同。
2). 集合操作的结果以第一条sql语句的表头为表头。
3).集合操作尽量少用。
2.数据处理
SQL 的类型:
1). DML : 数据操作语言 insert/update/delete/select
2). DDL : 数据定义语言 create/alter/drop/truncate
3). DCL : 数据控制语言 grant(授权) revoke(移除授权)
-- insert 向表里面添加一行记录
(1)出入一行里的某些数据
insert into emp(empno,job,sal) values(2016,'SAL',8000);
(2)按照表的顺序插入一行里的所有的数据
insert into emp values(2015,'zhangsan','MANAGER',2016,'18-3月-16',5000,3000,20);
-- 自定义日期的格式
alter session set NLS_DATE_FORMAT = 'yyyy-mm-dd';
-- create 创建一个表
-- 用模板快速的创建一个表
create table testemp as select * from emp where 1= 2;
-- 快速的插入数据
insert into testemp select * from emp; -- 批量操作的时候不要加关键字
-- 创建一个没有模板的表
create table testemp1(
id number(5),
name varchar(20),
weight number(5,2)
);
-- varchar 和varchar2 都可以用来表示字符串,但是在oracle中推荐用varchar2。varchar是每一个字段固定占N个字节,不管内容是否足够N个长度;varchar2 会根据内容自己调整他的长度。
--delete 删除数据
delete from emp where empno=2016 or empno=2015;
rollback:回滚,如果你删除错误以后可以用rollback来回滚数据。
可以创建一个回滚的节点:savepoint a;
然后再回滚:rollback to a;
-- dml 可以闪回,ddl不能。
-- 格式化表 truncate
truncate table testemp;
delete 和truncate 删除数据有什么差别?
(1). delete 是逐行删除,truncate是先删除表,在重新创建一个新表
(2). delete 能够闪回(flashback),而truncate不能闪回
(3). delete 不会释放内存空间,而truncate会
(4). delete 会产生碎片,而truncate不会
(5). delete 是DML语句,truncate是一个DDL语句
(6).delete 不会真正的将数据删除,它将所有的数据移到一个叫undo表空间里面。
-- drop 操作
drop table testemp; 删除表 testemp
-- 事物: 一连串的DML,形成的一个原子操作
事物什么时候开启:
(1). 显示的开启: start transaction
(2). 隐式开启: 执行的第一个DML语句
事物什么时候关闭:
(1). 显示关闭: commit,rollback;
(2). 隐式关闭
>> 正常关闭: 执行了一个DDL操作的时候
>> 非正常关闭: 断电断网....
--导入一个脚本里的sql语句
格式: @d:/testdelete.sql;
-- 打开sql执行的时间
set timing on
-- 关闭oracle的回调显示
set feedback off;
-- update 操作
-- 从emp表更新名字为KING的工资为20000
update emp set sal=10000 where ename='KING';
--alter 修改表
-- 在emp中追加一个列 photo,数据类型为varchar2(20)。
alter table emp add photo varchar2(20);
-- 修改photo的字符串长度为50
alter table emp modify photo varchar2(50);
-- 修改photo这个列的列名为photos
alter table testemp10 rename column photo to photos;
-- 删除photos列
alter table emp drop column photos;
-- 修改emp 表名称
rename emp to testemp;
-- 删除testemp;
drop table testemp;
Oracle Day05 集合与数据处理的更多相关文章
- Oracle的集合运算符
Oracle的集合运算符有并集union.union all,交集intersect,差集minus 先建表myemp,进行集合运算的测试 create table myemp as select * ...
- 【oracle】-集合运算:UNION,UNION ALL...
在Oracle中提供了三种类型的集合操作: 并(UNION).交(INTERSECT).差(MINUS) UNION:求并,重复记录只显示一次. UNION ALL:求并集,显示所有记录信息. INT ...
- 5.创建表,使用alter进行表信息的增删改,Oracle回收站,集合运算
1 Oracle基于用户的管理方案 2 DDL语句可以管理数据库的对象有:视图 索引 序列 同义词 约束 3 创建一个表,有2个条件(1 有权限:2有表空间) Oracle给你提 ...
- oracle之集合操作函数---minus、union、intersect
集合操作符专门用于合并多条select语句的结果,包括:UNION,UNION ALL,INTERSECT,MINUS.当使用集合操作函数时,需保证数据集的字段数据类型和数目一致. 使用集合操作符需要 ...
- Oracle day05 索引_数据去重
索引 自动:当在表上定义一个primary key或者unique 约束条件时,oracle数据库自动创建一个对应的唯一索引. 手动:用户可以创建索引以加速查询 在一列或者多列上创建索引: creat ...
- Oracle day05 建表_约束
表的创建 标准的建表语法 : CREATE TABLE [schema.] table (column datatype [DEFAULT expr], ... ); 使用子查询创建表的语法 CREA ...
- day05 集合
今日进度(数据类型) 集合 内存相关 深浅拷贝 1.集合表示 1.无序 2.不重复 3.hash查找 #问题:v={}表示? set: v1=set()#空集合 v1={1,2,3,4,5} dict ...
- 修改oracle字符集合
SQL> conn /as sysdbaSQL> shutdown immediate;SQL> startup mountSQL> ALTER SYSTEM ENABLE R ...
- 【转载】Jsp页面传Json数据到服务端,转对象或集合进行数据处理
需求:1.将页面数据带到服务端并转成对象,2.将页面的集合数据带到服务端转List实现:用ajax请求传递数据,数据格式为json JS方法: testJsonMethod = function(){ ...
随机推荐
- [Q]无矩形外框块参照图形的识别
该图纸的图框由块参照组成,其外侧图框不是矩形 使用默认设置无法正确识别,需要做以下修改:不勾选“块/外部参照”,勾选“块/外部参照边界”,勾选“制定块”并选择图框(块参照).
- CentOs + Nginx + php-fpm + MySql 依赖库安装
依赖库和开发工具 yum -y install gcc gcc-c++ autoconf libjpeg libjpeg-devel libpng libpng-devel freetype free ...
- (repost)在ARM Linux内核中增加一个新的系统调用
实验平台内核版本为4.0-rc1,增加一仅仅打印Hello World的syscall,最后我们在用户空间swi验证 实验平台内核版本为4.0-rc1,增加的系统调用仅仅是简单打印一个Hello Wo ...
- 从补丁到POC CVE-2015-0003(2015.3)
从补丁到POC CVE-2015-0003 1. 简介 该漏洞是由于Windows的win32k.sys模块存在对用户层参数验证不完全,导致存在空指针解引用(Null Pointer Derefere ...
- qemu毒液漏洞分析(2015.9)
0x00背景 安全娱乐圈媒体Freebuf对该漏洞的有关报道: 提供的POC没有触发崩溃,在MJ0011的博客给出了修改后可以使qemu崩溃的poc.详见: http://blogs.360.cn/b ...
- js中style的属性
下面这些属性都是通过js的style来设置css.只是整理了一部分,详细的可以参考相应的学习网站,不好的地方欢迎大家拍砖. alignContent :"" 属性在弹性容器内的各项 ...
- JavaScript DOM编程艺术-学习笔记(第八章、第九章)
第八章 1.小知识点: ①某些浏览器要根据DOCTYPE 来决定页面的呈现模式(标准模式 / 怪异模式--也称兼容模式): 兼容模式意味着浏览器要模仿老一辈的浏览器的怪异行为,来让老站点得到运行,并让 ...
- 微信支付服务商模式(受理机构模式)开发注意事项,jsapi支付
1.首先下载的demo,一般都是有些bug的,先要改一下. 2.微信貌似没有为服务商模式单独开发demo,下载的也都是普通商户的支付demo,其实这里没有必要单独写,因为他们区别就是几个参数的区别. ...
- 【c++】size_t 和 size_type的区别
为了使自己的程序有很好的移植性,c++程序员应该尽量使用size_t和size_type而不是int, unsigned 1. size_t是全局定义的类型:size_type是STL类中定义的类型属 ...
- 在eclipse中生成实体类
1.在eclipse的windows中选中preferences在查询框中输入driver definition 2.点击add在Name/type中选中mysql jdbc driver 5.1然后 ...