SQL的六种约束——数据库的约束

2024-06-22 11:48

本文主要是介绍SQL的六种约束——数据库的约束,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

/*数据库的约束*/
/*
1.not null  非空约束
    ①强制列不接受空值
    ②例:创建表时,name varchar(6) not null,
2.unique 唯一性约束
    ①约束唯一标识数据库表中的每条记录
    ②unique和primary key都为数据提供了唯一性约束
    ③primary key 拥有自动定义的Unique约束
    ④注意:每个表中只能有一个primary key约束,但是可以有多个Unique约束
    ⑤语法:
        1.name int unique
        2.unique(column_name)
        3.CONSTRAINT uc_PersonID UNIQUE (Id_P,LastName)    添加多个约束
        4.alter table table_name add unique(column_name)   增加表中的约束
        5.ALTER TABLE table_name DROP CONSTRAINT 主键名    删除约束   
3.primary key约束 
    ①约束唯一标识数据库表中的每条记录
    ②主键必须包含唯一的值
    ③主键列不能为空
    ④每个表都应该有个主键,但只能有一个主键
    ⑤语法:
        1.StudentID int not null primary key        创建学生编号为主键
        2.primary key(Students)                     创建学生编号为主键
        3.primary key(StudentID,Email)              创建学生ID和Email为联合主键
    ⑥为已存在的列创建主键
        1.alter table table_name add primary key(column_name)
    ⑦删除主键约束
        1.alter table table_name drop primary key
    ⑧删除主键约束
        1.alter table table_name drop constraint 主键约束名   主键约束名可以使用sp_help查询
4.foreign key约束
    ①一个表中的foreign key 指向另一个表的primary key
    ②foreign key约束用于预防破坏表之间连接的动作
    ③foreign key约束也能防止非法数据插入外键列,因为它必须是指向的那个表的值之一
    ④语法:
        1.foreign key (column_name) references 主表名(主键列名)     创建column_name为主表名的外键
        2.column_name int foreign key references 主表名(主键列名)   创建column_name为主表名的外键
        3.alter table table_name 
                  add foreign key (列名) references 主表名(主键列名)         为已存在的列创建外键
        4.alter table table_name drop constraint 外键约束名          删除外键约束(SQL Server oracle)
        5.alter table table_name drop foreign key  外键约束名         删除外键约束(Mysql)
5.check 约束
    ①check约束用于限制列中的值的范围
    ②如果对个单个列做check约束,那么该列只可以输入特定数值
    ③如果一个表定义check约束,那么此约束会在特定的列对值进行限制
    ④语法:
        1.StudentID int not null check (StudentID>0)          限制StudentID输入的值要大于0  (SQL Server  oracle)
        2.StudentID int not null,                             限制StudentID输入的值要大于0   (Mysql)
          check (StudentID>0)                                 
        3.sex varchar(2) not null check(sex='男' or sex='女') 限制sex的性别只能是男或者女
        4.alter table table_name add check(列名>0)           向已有的列加入check约束
        5.alter table table_name drop constraint check约束名  删除约束       约束名可以用 sp_help table_name查看
6.default约束
    ①default约束用于向列中插入默认值
    ②如果没有规定其他的值,那么会将默认值添加到所有的新记录中
    ③语法:
        1.name varchar(10) default '张三'                       name默认插入张三的名字
        2.systime date default gatedate()                       插入时间的默认值   getetime()函数为时间的默认值
        3.alter table table_name add 列名 set default '数值'     向已有列名中插入默认值
        4.alter table table_name drop constraint 约束名          删除默认约束
*/
 

这篇关于SQL的六种约束——数据库的约束的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1084210

相关文章

mysql索引四(组合索引)

单列索引,即一个索引只包含单个列,一个表可以有多个单列索引,但这不是组合索引;组合索引,即一个索引包含多个列。 因为有事,下面内容全部转自:https://www.cnblogs.com/farmer-cabbage/p/5793589.html 为了形象地对比单列索引和组合索引,为表添加多个字段:    CREATE TABLE mytable( ID INT NOT NULL, use

mysql索引三(全文索引)

前面分别介绍了mysql索引一(普通索引)、mysql索引二(唯一索引)。 本文学习mysql全文索引。 全文索引(也称全文检索)是目前搜索引擎使用的一种关键技术。它能够利用【分词技术】等多种算法智能分析出文本文字中关键词的频率和重要性,然后按照一定的算法规则智能地筛选出我们想要的搜索结果。 在MySql中,创建全文索引相对比较简单。例如:我们有一个文章表(article),其中有主键ID(

mysql索引二(唯一索引)

前文中介绍了MySQL中普通索引用法,和没有索引的区别。mysql索引一(普通索引) 下面学习一下唯一索引。 创建唯一索引的目的不是为了提高访问速度,而只是为了避免数据出现重复。唯一索引可以有多个但索引列的值必须唯一,索引列的值允许有空值。如果能确定某个数据列将只包含彼此各不相同的值,在为这个数据列创建索引的时候就应该使用关键字UNIQUE,把它定义为一个唯一索引。 添加数据库唯一索引的几种

mysql索引一(普通索引)

mysql的索引分为两大类,聚簇索引、非聚簇索引。聚簇索引是按照数据存放的物理位置为顺序的,而非聚簇索引则不同。聚簇索引能够提高多行检索的速度、非聚簇索引则对单行检索的速度很快。         在这两大类的索引类型下,还可以降索引分为4个小类型:         1,普通索引:最基本的索引,没有任何限制,是我们经常使用到的索引。         2,唯一索引:与普通索引

关于如何更好管理好数据库的一点思考

本文尝试从数据库设计理论、ER图简介、性能优化、避免过度设计及权限管理方面进行思考阐述。 一、数据库范式 以下通过详细的示例说明数据库范式的概念,将逐步规范化一个例子,逐级说明每个范式的要求和变换过程。 示例:学生课程登记系统 初始表格如下: 学生ID学生姓名课程ID课程名称教师教师办公室1张三101数学王老师101室2李四102英语李老师102室3王五101数学王老师101室4赵六103物理陈

数据库期末复习知识点

A卷 1. 选择题(30') 2. 判断范式(10') 判断到第三范式 3. 程序填空(20') 4. 分析填空(15') 5. 写SQL(25') 5'一题 恶性 B卷 1. 单选(30') 2. 填空 (20') 3. 程序填空(20') 4. 写SQL(30') 知识点 第一章 数据库管理系统(DBMS)  主要功能 数据定义功能 (DDL, 数据定义语

【服务器运维】MySQL数据存储至数据盘

查看磁盘及分区 [root@MySQL tmp]# fdisk -lDisk /dev/sda: 21.5 GB, 21474836480 bytes255 heads, 63 sectors/track, 2610 cylindersUnits = cylinders of 16065 * 512 = 8225280 bytesSector size (logical/physical)

给数据库的表添加字段

周五有一个需求是这样的: 原来数据库有一个表B,现在需要添加一个字段C,我把代码中增删改查部分进行了修改, 比如insert中也添入了字段C。 但没有考虑到一个问题,数据库的兼容性。因为之前的版本已经投入使用了,再升级的话,需要进行兼容处理,当时脑子都蒙了,转不过来,后来同事解决了这个问题。 现在想想,思路就是,把数据库的表结构存入文件中,如xxx.sql 实时更新该文件: CREAT

SQL Server中,查询数据库中有多少个表,以及数据库其余类型数据统计查询

sqlserver查询数据库中有多少个表 sql server 数表:select count(1) from sysobjects where xtype='U'数视图:select count(1) from sysobjects where xtype='V'数存储过程select count(1) from sysobjects where xtype='P' SE

SQL Server中,always on服务器的相关操作

在SQL Server中,建立了always on服务,可用于数据库的同步备份,当数据库出现问题后,always on服务会自动切换主从服务器。 例如192.168.1.10为主服务器,12为从服务器,当主服务器出现问题后,always on自动将主服务器切换为12,保证数据库正常访问。 对于always on服务器有如下操作: 1、切换主从服务器:假如需要手动切换主从服务器时(如果两个服务