约束(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 约束,索引的更多相关文章

  1. SQL 约束 索引

    --约束constraint--not null 非空约束create table demo01(empno number(4),ename varchar2(10) not null,job var ...

  2. SQLServer与MySQL约束/索引命名的一些差异总结

    约束是数据库完整性的保证,主要分为:主键/外键/唯一键/默认值/check等类别,约束是一个逻辑概念,表示数据的某些特性(不能为空,唯一,必须满足某些条件等等),索引是一个逻辑与物理概念的结合,逻辑上 ...

  3. 总结: MySQL(基础,字段约束,索引,外键,存储过程,事务)操作语法

    1. 显示数据库列表 show databases; # 查看当前所有数据库 show databases \G   #以行的方式显示 2. 在命令行中,执行sql语句 mysql -e 'show ...

  4. 2-16 MySQL字段约束-索引-外键

    一:字段修饰符 1:null和not null修饰符 我们通过这个例子来看看 mysql> create table worker(id int not null,name varchar(8) ...

  5. Oracle 表管理 约束 索引

    表的约束与完整性: 1.实体完整性 主键唯一性 2.域完整性 不能向number中插入varchar 3.参照完整性 外键 以别的表的字段作为外键,再插入该表时所插入外键的值必须在被参照表中该字段有那 ...

  6. mysql字段约束-索引-外键---3

    本节所讲内容: 字段修饰符 清空表记录 索引 外键 视图 一:字段修饰符 (约束) 1:null和not null修饰符   我们通过这个例子来看看 mysql> create table wo ...

  7. SQL基础-约束&索引

    一.约束 1.约束简介 约束(constraint): 表中数据的限制条件. 完整性 有效性 约束的种类: 主键约束 外键约束 唯一约束 检查约束 非空约束 2.主键约束 主键约束: 唯一标识表中每一 ...

  8. day38:MySQL数据库之约束&索引&外键&存储引擎

    目录 part1:数据类型 part2:约束 part3:主键索引 PRI &唯一索引 UNI &普通索引 MUL part4:外键:foreign key part5:在外键中设置联 ...

  9. 循环TRUNCATE表,再ENABLE约束索引等

    CREATE OR REPLACE PROCEDURE STG.FP_REMOVE_MST_OLD_DATA (EXITCODE OUT NUMBER) IS /******************* ...

随机推荐

  1. selenium——键盘操作

    很多键盘操作实际是没有意义的.

  2. jarvis level6_x64堆溢出unlink拾遗

    level6 32位的我没有调出来,貌似32位的堆结构和64位不太一样,嘤嘤嘤?,所以做了一下这个64位的,题目地址,level6_x64 首先看一下程序的结构体 struct list //0x18 ...

  3. Nginx中if语句中的判断条件

    一.if语句中的判断条件(nginx) 1.正则表达式匹配: ==:等值比较; ~:与指定正则表达式模式匹配时返回“真”,判断匹配与否时区分字符大小写: ~*:与指定正则表达式模式匹配时返回“真”,判 ...

  4. 关于简单的安卓APP状态栏设置(类似沉浸式状态栏)

    1.设置为全屏模式: 在所需设置为全屏模式的逻辑的onCreat()方法中加入以下代码即可: if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.K ...

  5. linux 乌班图 lnmp环境搭建

    1.#安装Apache2,目前163的源是2.2.22版本02.sudo apt-get install apache203. 04.#安装MySQL,目前163的源是5.5.24版本05.apt-g ...

  6. 通过语法设置DNS解析

    通过语法设置DNS解析 # 来自 https://dns.he.net/?action=logout # 语法 http://[你的域名]:[你的密码]@dyn.dns.he.net/nic/upda ...

  7. koa

    koa 链接: 官网: https://koa.bootcss.com/# 入门: http://www.ruanyifeng.com/blog/2017/08/koa.html 进阶: https: ...

  8. net core 获取配置文件

    IConfiguration服务是net core 默认依懒注入的一个对象 直接注入(推荐使用) 新建控制器 然后构造函数直接注入 [Route("api/[controller]" ...

  9. aspnet mvc 中 跨域请求的处理方法

    ASP.NET 处理跨域的两种方式    方式1,后端程序处理.原理:给响应头加上允许的域即可,*表示允许所有的域                 定义一个cors的过滤器 加在在action或者co ...

  10. Python线性表——单链表

    1. 线性表简介 线性表是一种线性结构,它是由零个或多个数据元素构成的有限序列.线性表的特征是在一个序列中,除了头尾元素,每个元素都有且只有一个直接前驱,有且只有一个直接后继,而序列头元素没有直接前驱 ...