oracle04 约束,索引
约束(constraint)
一、定义
为表的列添加一些约束,以满足用户的需求。在之后的DML(select,insert,update)
数据时,若不满足约束条件,则语句不能执行
注:可以为约束起别名
二、约束的分类
1)非空约束 not null
2)唯一约束 unique
注:可以有多个空值
3)自定义检查约束 check
4)主键约束 primary key
表中能够唯一确定一个行数据的字段 ,列中只能有一个主键约束实际约束效果与(not null unique)一致。
注:主键联合,可以用表级约束联合几个列为主键
5)外键约束 reference
外键用来描述两张表之间的关系,必须保证外键列的值必须为参考列的值中具有唯一约束的一个
三、添加约束
1)建表时为某一列后添加约束(也可在所有列之后再添加)
2)建表后通过alter... add...或alter...drop...修改
代码演示:
create table tempt(
tname varchar2(15) not null,--非空约束,值非空
tid number(4) unique,--唯一约束,值唯一
age varchar2(3) constraint ck_age check(age between 0 and 150)--自定义检查约束
)
create table classer(
cid number(2) primary key, --主键约束
cname varchar2(15) not null
)
create table student(
cid number(3) references classer(cid),--外键约束
stuname varchar2(15) not null unique
)
索引
一、作用:
在数据库中用来加速对表的查询,通过使用快速路径访问方法快速定位数据,减少了磁盘的I/O
二、创建:
1)自动: 当在表上定义一个PRIMARY KEY 或者UNIQUE 约束条件 时,Oracle数据库自动创建一个对应的唯 一索引.
2)手动: 用户可以创建索引以加速查询
三、语法格式:
CREATE INDEX index ON table ( column [, column ]...);
Oracle分页
- Oracle下select语句每个结果集中都有一个伪字段存在,这个字段的名 字叫做rownum.用来标识每条记录的行号,行号从1开始,每次递增1
- 只能使用:<,<=
- 注意:Oracle中的rownum的是在取数据的时候产生的序号 。当 rownum和order by一起使用时,会首先选出符合rownum条件的记 录,然后再进行排序,这会给我们的查询带来难度。
rowid
- rowid 是oracle实际存在的值,是唯一的值
- rownum 是一个虚拟的顺序值 ,前提是一定要排序 select emp.*,rowid from emp;
oracle04 约束,索引的更多相关文章
- SQL 约束 索引
--约束constraint--not null 非空约束create table demo01(empno number(4),ename varchar2(10) not null,job var ...
- SQLServer与MySQL约束/索引命名的一些差异总结
约束是数据库完整性的保证,主要分为:主键/外键/唯一键/默认值/check等类别,约束是一个逻辑概念,表示数据的某些特性(不能为空,唯一,必须满足某些条件等等),索引是一个逻辑与物理概念的结合,逻辑上 ...
- 总结: MySQL(基础,字段约束,索引,外键,存储过程,事务)操作语法
1. 显示数据库列表 show databases; # 查看当前所有数据库 show databases \G #以行的方式显示 2. 在命令行中,执行sql语句 mysql -e 'show ...
- 2-16 MySQL字段约束-索引-外键
一:字段修饰符 1:null和not null修饰符 我们通过这个例子来看看 mysql> create table worker(id int not null,name varchar(8) ...
- Oracle 表管理 约束 索引
表的约束与完整性: 1.实体完整性 主键唯一性 2.域完整性 不能向number中插入varchar 3.参照完整性 外键 以别的表的字段作为外键,再插入该表时所插入外键的值必须在被参照表中该字段有那 ...
- mysql字段约束-索引-外键---3
本节所讲内容: 字段修饰符 清空表记录 索引 外键 视图 一:字段修饰符 (约束) 1:null和not null修饰符 我们通过这个例子来看看 mysql> create table wo ...
- SQL基础-约束&索引
一.约束 1.约束简介 约束(constraint): 表中数据的限制条件. 完整性 有效性 约束的种类: 主键约束 外键约束 唯一约束 检查约束 非空约束 2.主键约束 主键约束: 唯一标识表中每一 ...
- day38:MySQL数据库之约束&索引&外键&存储引擎
目录 part1:数据类型 part2:约束 part3:主键索引 PRI &唯一索引 UNI &普通索引 MUL part4:外键:foreign key part5:在外键中设置联 ...
- 循环TRUNCATE表,再ENABLE约束索引等
CREATE OR REPLACE PROCEDURE STG.FP_REMOVE_MST_OLD_DATA (EXITCODE OUT NUMBER) IS /******************* ...
随机推荐
- JdbcTemplate中queryForObject方法返回空结果或不正确结果数量的解决方法
在使用Spirng提供的JdbcTemplate中名为queryForObject API进行数据库查询时有时会抛出如下异常: org.springframework.dao.EmptyResultD ...
- JVM虚拟机
一.JAVA虚拟机内存模型: 1.程序计数器:非常小的内存,用于存放下一条运行的指令: 每一个线程都必须有一个独立的程序计数器,用于记录下一条要运行的指令,是一块线程私有的内存空间,CPU时间切片 2 ...
- nginx问题相关记录
nginx目前主要用来做反向代理和负载均衡,其实它也可以是一个web服务器: 1.反向代理: location /api/ { proxy_next_upstream error timeout ht ...
- 【原创】大数据基础之Hive(2)Hive SQL执行过程之SQL解析过程
Hive SQL解析过程 SQL->AST(Abstract Syntax Tree)->Task(MapRedTask,FetchTask)->QueryPlan(Task集合)- ...
- Visual Studio 2015中 没有“安装和部署”的解决方法
使用Visual Studio 2015 Community新建项目,在已安装模板中的“其它项目类型”下未找到“安装和部署”选项.在微软官网下载 Microsoft Visual Studio 201 ...
- selenium之 webdriver与三大浏览器版本映射表(更新至v2.29)
1.chrome浏览器 chromedriver版本 支持的Chrome版本 v2.29 v56-58 v2.28 v55-57 v2.27 v54-56 v2.26 v53-55 v2.25 v53 ...
- ajax与后台交互案例
BBS项目 //BBS项目,注册页面ajax请求 // 1.实现照片预览 $("#up_myhead").change(function () { // 获取input选择的文件 ...
- php获取两个时间戳之间相隔多少天多少小时多少分多少秒
/** * 返回两个时间的相距时间,*年*月*日*时*分*秒 * @param int $one_time 时间一 * @param int $two_time 时间二 * @param int $r ...
- 咸鱼入门到放弃4——Http协议
一.什么是HTTP协议 HTTP是hypertext transfer protocol(超文本传输协议)的简写,它是TCP/IP协议的一个应用层协议,用于定义WEB浏览器与WEB服务器之间交换数据的 ...
- 辅助排序和Mapreduce整体流程
一.辅助排序 需求:先有一个订单数据文件,包含了订单id.商品id.商品价格,要求将订单id正序,商品价格倒序,且生成结果文件个数为订单id的数量,每个结果文件中只要一条该订单最贵商品的数据. 思路: ...