Oracle的总体回顾
1.多表查询:一张以上的表进行查询,称为多表查询,多表查询的时候可以为表指定别名的方式以简化查询列的编写,在多表查询中,会产生笛卡尔积,就是两张表的总数相乘得到的结果,如果要想消除笛卡尔积要通过关联条件。注意左连接和右连接
2.分组统计和统计函数
·统计函数:COUNT(),AVG(),SUM(),MAX(),MIN()
·统计函数必须出现在分组统计之中,所谓的分组就是指定列中存在重复的内容,使用GROUP BY 的方式进行分组统计。
·如果要加入分组条件,则编写HAVING字句,所有的统计函数作为条件的话只能在HAVING中出现,不能在WHERE之中使用。
·在使用分组的时候,一定要注意,查询的时候只能出现分组函数和分组条件。
·分组函数允许嵌套,但是嵌套之后不能在查询其他字段,包括分组字段。
3.子查询
·在一个查询中包含另外一个查询,称为子查询
·子查询可以出现在任意位置:SELECT、FROM、WHERE
·子查询可以结合多表关联,分组统计完成复杂的查询功能
4.数据库的更新操作
·复制表(Orcale) CREATE TABLE 表名称 AS(子查询);
·表的数据增加 INSERT INTO 表名称(字段) VALUES(值)
·更新 UPDATE 表名称 SET 字段=值....WHERE 条件
·数据删除 DELETE FROM 表名称 WHERE 删除条件
5.事务处理
·所有的操作要么全部成功,要么全部失败
·在Orcale之中每一个连接到数据库上的用户表示一个session,一个session所做的修改不会立刻真正的修改数据库,而是等待用户的提交,用户通过COMMIT 提交或者使用rollback 进行回滚操作
·在Orcale之中是会出现死锁的情况,互相等待对方的提交。
7.表的建立
·建立新表:自己制定需要的字段及类型
·复制表:复制已有表的结构或者数据,如果不需要数据,只需要再子查询写一个永远不可能成立的条件
8.可以使用DROP TABLE 删除一张表
9.截断表:TRUNCATE TABLE ,被阶段后的表,内容不可回滚,会立即释放所有的资源
10.约束,SQL 之中存在5种约束:
·单表上的约束:
|-主键约束:PRIMARY KEY
|-非空约束:NOT NULL
|-检查约束:CHECK
|-唯一约束: UNIQUE
·关联表的约束:
|-外键约束:FOREIGN KEY,表示子表的取值和父表中的取值有所关联
|-删除的时候应该先删除子表再删除父表
|-如果现在要想直接删除父表,可以采用Orcale的强制手段:
|-DROP TABLE 表名称 CASCADE CONSTRAINT
|-级联:ON DELETE CASCADE 当父表被删除后,子表对应内容也删除
·约束一般在表建立的时候就已经完成了,尽可能不要去修改表的约束。
·注意约束名称的命名规范
11.ROWNUM 是一个伪列,会自动存在,表示每一个查询的行数
·可以部分的取出数据表中的数据(分页)
12.集合操作 交(union/union all) 并(intersete) 差(minue)
13.表的修改:ALTER 指令
·增加列:ALTER TABLE 表名称 ADD(字段名称,字段类型[,DEFAULT 默认值])
·修改列:ALTER TABLE 表名称 MODIFY(字段名称,字段类型[,DEFAULT 默认值])
·增加约束:ALTER TABLE 表名称 ADD CONSTRAINT 约束名称 约束类型(字段);
·删除约束:ALTER TABLE 表名称 DROP CONSTRAINT 约束名称 约束类型(字段);
Oracle的总体回顾的更多相关文章
- mysql内容总体回顾
数据类型: 数值类型: 整形 浮点型 字符串: char(定长)\varchar(不定长) char(定长):插入数据或查询数据都快,因为char在磁盘上插入数据时的存储空间是固定的,简单粗暴,直接就 ...
- Oracle 基本知识回顾
1.查找数据库所用的字符集编码:SELECT USERENV('language') FROM DUAL;2.将一个表中的字段,插入到这个表:INSERT INTO TABLE SELECT * FR ...
- Oracle从入门到精通(笔记)
一.Oracle11g概述 1.6 启动与关闭数据库实例 1.6.1 启动数据库实例 Oracle数据库实例启动分3个步骤:启动实例,加载数据库,打开数据库: 命令格式:startup [nomoun ...
- 装服务器,测试数据库,简单的maven命令
[说明]今天总体回顾一下:大概是早上装服务器,下午测试数据库,晚上了解简单的maven命令 一:今日完成 1)在远程服务器的tomcat 设置好管理员的登录账号 2)登录tomcat 的项目管理 查看 ...
- Java——泛型
前言 一般的类和方法,使用的都是具体的类型:基本类型或者自定义的类.如果我们要编写出适用于多种类型的通用代码,那么肯定就不能使用具体的类型.前面我们介绍过多态,多态算是一种泛化机制,但是也会拘泥于继承 ...
- MVVM在WPF中应用(1)
在软件行业浸润了这么多年,第一次在MES的工厂里从事软件开发. 在这里的感觉就是安静.宽松,比在那些专门以软件为主的企业中轻松自在.在这里的第一个项目是关于数据的导入和导出,还有数据的比较这些功能. ...
- day4python学习
2.3.1.字符串的索引与切片. 字符串是不可变类型,所有对他的操作(如切片split)都是生成的新的字符串, 索引即下标,就是字符串组成的元素从第一个开始,初始索引为0以此类推,从右往左数的话是从- ...
- 2018软件工程W班助教小结博客
一.总体回顾 我是汪老师实验室的研二的一名研究生,在研一的课程中就上过老师带的高级软件工程(采取的模式是一样的,亲身经历了一学期所以对整体流程比较清楚).实验室的学生当老师实践课的助教是这几年流传下来 ...
- [jvm]java内存模型
一.java内存模型 Java虚拟机规范中试图定义一种Java内存模型(Java Memory Model,JMM)来屏蔽掉各种硬件和操作系统的内存访问差异,以实现让Java程序在各种平台下都能达到一 ...
随机推荐
- ios ViewController present不同的方向
First ViewController CATransition *transition = [CATransition animation]; transition.duration = 0.3; ...
- eclipse/myeclipse使用技巧
热键篇: Template:Alt + / 修改处:Window->Preference->Workbench->Keys->Command->Edit->Cont ...
- 有用的HTML+CSS片段
HTML5页面模板 现在国外很多制作新网站直接使用了HTML5代码,当然我们也得跟上,下面是一个常用的HTML5默认模板,就像你用Dreamweaver新建一个HTML文件时的代码,只不过现在这个是H ...
- jvm莫名退出问题解决
当jvm莫名退出,没有留下任何任何信息的时候,在centos的 /var/log/dmesg文件中,或许可以找到一些端倪
- C# DropDownList绑定文件夹
首先创建一个类,类名称为FileControl, /// <summary> /// 获取制定文件夹下面的文件夹 /// </summary> /// <param na ...
- 从头开始-07.Foundation框架常用结构体
一.Foundation框架常用结构体NSRange\CGRange.NSPoint\CGPoint.NSSize\CGSize. NSRect\CGRect 的使用 1. 基本使用: //NSRa ...
- Vim 扩展工具 vim-ide (转)
通过简单的配置文件将 vim 打造成专业 ide,支持 mac linux cygwin.看过数篇 vim 配置文件,必要时去定制vim 的插件,将 vim 的 ide 用户体验尽量做到极致. 使用范 ...
- sfs
http://tieba.baidu.com/p/3397811202 http://mooc.guokr.com/post/610664/ http://home.ustc.edu.cn/~boj/ ...
- 设计模式之UML类图
在学设计模式的过程中经常碰到各式各样的UML类图.那些眼花缭乱的符号有什么含义呢? 类图含义 类图中的关系 从网上找来一张图作为实例 依赖关系:比如动物依赖氧气和水,这里如学生要依赖自行车.用虚线箭头 ...
- php中的一些编程例子
#一到一百不能被三整除的数 for($i=1;$i<=100;$i++){ if($i%3 != 0){ $arr[] = $i; }} var_dump($arr); #水仙花数for($i= ...