oracle v¥bh,【oracle笔记2】约束

约束

*约束是添加在列上的,用来约束列的。

1. 主键约束(唯一标识)

***非空***

***唯一***

***被引用***(外键时引用主键)

*当表的某一列被指定为主键后,该列就不能为空,不能有重复的出现。

*创建表时指定主键的两种方式:

>

create table stu(

sid      char(6) primary key,

sname     varchar(20),

age          int,

gender          varchar(10)

);

指定sid列为主键列,即为sid列添加主键约束。

>

create table stu(

sid      char(6),

sname    varchar(20),

age         int,

gender    varchar(10),

primary key (sid)

);

指定sid列为主键列,即为sid列添加主键约束。

*修改表时指定主键:alter table stu add constraint 主键名 primary key(sid);

*这里回忆一下学过的修改操作。前缀都是alter table 表名 :

add --->添加列

modify 列名 新列类型-->修改列类型

rename column 旧列名 to 新列名-->修改列名

drop column 列名--->删除列

rename to 新表名--->修改表名

*删除主键:alter table stu drop primary key;删除主键的时候,不用指定列名 ,因为主键的唯一性。

2.主键自增长

*因为主键的特性是:必须唯一、不能为空。所以我们通常会指定主键类为整数型,然后设置其自增长,这样可以保证在插入数据时主键列的唯一和非空特性。

oracle并没有mysql那样可以设置自增主键,需要自己创建序列才能实现自增。

这是从网上看来的一个例子:

/*创建自增序列*/

CREATE SEQUENCE CMB_CHINA_CITYS_ID

MINVALUE 1 --最小值

NOMAXVALUE --不设置最大值

START WITH 1 --从1开始计数

INCREMENT BY 1 --每次加1

NOCYCLE --一直累加,不循环

NOCACHE; --不建缓冲区

说明:CMB_CHINA_CITYS_ID:列名

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

以下是mysql设置主键自增的机制

*创建表时指定主键自增长:

create table stu(

sid     int primary key auto_increment,

sname   varchar(20),

age    int,

gender    varchar(10)

);

*修改表时设置主键自增长:alter table stu change sid sid int auto_increment;

*修改表时删除主键自增长:alter table stu change sid sid int;

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

3.非空约束

*因为某些列不能设置Null值,所以可以对列添加非空约束。

*例如:

create table stu(

sid     int primary key,

sname    varchar(20)not null,

age    int,

gender    varchar(10)

);对sname设置了非空约束。

4.唯一约束

*数据库某些列不能设置重复的值,所以可以对列添加唯一约束。

*例如:

create table stu(

sid     int primary key,

sname    varchar(20)not null unique,

age    int,

gender    varchar(10)

);对sname设置了非空约束。

https://blog.csdn.net/jssg_tzw/article/details/40981393这篇文章对唯一性约束讲的很清楚。

补充:(Duplicate重复,数据库报错时查的单词,原因是主键的唯一性,不可添加重复的数据。)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/543108.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

WAP端 touch事件触发顺序记录

IOS7.0 safari 滚动滚动条的时候, 最后手指放开 (scroll 总是在 touchend后面,所以要用 setTimeout)   touchstart touchmove(多个) touchend scroll(一个)IOS8.4 safari 滚动滚动条的时候   touchstart touchmove…

opencv入门_【OpenCV入门之十八】通过形态学操作提取水平与垂直线

小白导读学习计算机视觉最重要的能力应该就是编程了,为了帮助小伙伴尽快入门计算机视觉,小白准备了【OpenCV入门】系列。新的一年文章的内容进行了很大的完善,主要是借鉴了更多大神的文章,希望让小伙伴更加容易理解。如果小伙伴觉…

php strstr 从尾部,PHP strstr() 和 strrchr() 详解

strstr() 和 strrchr()有一定的相似性,所以放在一起。strstrstrstr ( string $haystack , mixed $needle [, bool $before_needle FALSE ] ) : stringneedle 可以为单个字符,也可以是个字符串。返回 needle 在 haystack 在第一次出现的位置到结束&#…

python计算结果传给spark_Spark入门:流计算简介(Python版)

数据总体上可以分为静态数据和流数据。对静态数据和流数据的处理,对应着两种截然不同的计算模式:批量计算和实时计算。批量计算以“静态数据”为对象,可以在很充裕的时间内对海量数据进行批量处理,计算得到有价值的信息。Hadoop就…

【译】NoClassDefFoundError和ClassNotFoundException的不同

本文翻译自:Difference between NoClassDefFoundError vs ClassNotFoundExcepiton in Java 如果JVM或者ClassLoader在加载类时找不到对应的类,就会引发NoClassDefFoundError和ClassNotFoundException,这两种错误都非常严重。由于不同的ClassL…

oracle怎么设置出蓝色边,Oracle 数据库入门之———————-,多行函数-蓝色留心...

2,多行函数SQL> –工资总额SQL> select sum(sal) from emp;SUM(SAL)29025SQL> –人数SQL> select count(*) from emp;COUNT(*)14SQL> –平均工资SQL> select sum(sal)/count(*) 一,avg(sal) 二 from emp;一 二2073.21429 2073.21429SQL> –平均…

python绘制剖面图_用python绘制剖面图

我自己为这个功能做了一个模块。在import pandas as pdfrom pandas import Series, DataFrameimport numpy as npimport matplotlib.pyplot as pltdef Profile(x,y,nbins,xmin,xmax,ax):df DataFrame({x : x , y : y})binedges xmin ((xmax-xmin)/nbins) * np.arange(nbins1…

Ubuntu上安装Robomongo及添加到启动器

到目前为止,Robomongo仍是MongoDB最好的客户端管理工具,如需在Ubuntu上安装Robomongo,可直接从官网下载.tar.gz压缩包进行解压,然后直接运行bin目录下的robomongo文件即可启动界面。例如我将下载下来的.tar.gz压缩包解压到/usr/lo…

python打开手机网页_Python3 Windows服务器简单实现 手机访问

设备1. PC with Win102. Python 3.5.1步骤打开CMD,cd 到e盘,mkdir pythonWebserver 建立文件夹//在E盘建立文件夹,作为服务器的根目录。如:e:\pythonWebserver直接输入命令:python -m http.server 8000//以默认的地址——本地ip&a…

oracle开归档服务器,ORACLE RAC 启用归档

ORACLE RAC 启用归档1、关闭所有节点数据库实例c:\>srvctl stop database -d apts2、修改服务器配置参数sql>startup mountsql>alter system set cluster_databasefalse scopespfile;sql>shutdown immediate3、调整归档日志路径sql>startup mountsql>alter s…

pagefile.sys and heberfil.sys

dub 删除heberfil.sys大文件的方法 方法1:Windows/system32中的cmd.exe 输入 powercfg -h off,即可关闭休眠功能,同时 Hiberfil.sys 文件也会自动删除。 方法2:运行命令gpedit.msc打开策略组 依次打开Computer Configuration——Administrative Template…

加密生成指定长度_3分钟短文 | PHP伪随机Token生成器,实地测试,效果感人!

引言我们经常可能会用到邀请码,邮件验证码,或者需要使用unique 字符串标记用户属性的情况。今天我们且不说高深的“全局唯一ID”的生成方案,我们说一个简单的,如何生成一个唯一的,随机的,数组字母组成的字符…

《Java高级程序设计》期末作业【2】-进度安排

计算器项目计划进度安排: 项目成员:潘世林 何青 柴晓光 张峰转载于:https://www.cnblogs.com/panshilin/p/5578496.html

python find不区分大小写_牛鹭学院:Python基础了解

本文来自牛鹭学院学员:田雨python初印象Python 是一种解释型语言: 这意味着开发过程中没有了编译这个环节。类似于PHP和Perl语言。Python 是交互式语言: 在一个 Python 提示符 >>> 后直接执行代码。Python 是面向对象语言: 这意味着…

linux内核升级写入不了,解决linux内核升级后不能重启系统的故障

1.闲来无事,想升级下centos的内核。升级方法就不多讲了。2.升级完后,重启系统,发现系统无法启动,具体原因是系统无法挂载文件系统。3.在网上找了下资料,原因出在了initrd是旧版本mkinitrd生成的。所以导致文件系统无法…

Spring+Quartz(一)

2019独角兽企业重金招聘Python工程师标准>>> Quartz是一个非常优秀的任务调度引擎,详情请见官网:http://www.quartz-scheduler.org/ 而Spring很好地集成了Quartz,为企业级的任务调度提供了方便。 下面先看一个实现了Job接口的任务HelloWorldJ…

python struct pack解析_Python struct 详解

最近在学习python网络编程这一块,在写简单的socket通信代码时,遇到了struct这个模块的使用,当时不太清楚这到底有和作用,后来查阅了相关资料大概了解了,在这里做一下简单的总结。了解c语言的人,一定会知道s…

linux sudo 版本,Linu下如何升级当前sudo版本

Sudo 的全称是“superuserdo”,它是Linux系统管理指令,允许用户在不需要切换环境的前提下以其它用户的权限运行应用程序或命令,通常是以 root 用户身份运行命令,以减少 root 用户的登录和管理时间,同时提高安全性。该漏…

LaTeX技巧205:使用split输入多行公式技巧

我们在输入多行公式的时候,split,array,multiline,align,aligned等等都是我们可以选用的环境,这里介绍split的使用方法。演示效果图:演示代码:\documentclass{article}\pagestyle{em…

python改变列的数据类型_python – Pandas:更改列的数据类型

您可以使用pd.to_numeric(在版本0.17中引入)将列或Series转换为数字类型。该函数还可以使用apply应用于DataFrame的多个列。重要的是,该函数还接受一个错误关键字参数,它允许您强制非数字值为NaN,或者简单地忽略包含这些值的列。示例使用如下…