数据库约束定义及分类

约束

约束定义及分类:

Constraint,对数据库中的数据做要求,以保证设计出来的数据库及其中的数据真实可用。

约束分为

  • 行完整性约束(三范式)
  • 列完整性约束。
  • 主键约束

Alter table 表名 add constraint PK_表名_列名 primary key(列名);

创建表时可以简写

Create table tt(ttid int primary key);

Create table tt(ttid int,primary key(ttid));

创建的主键名是PK_随机的十六进制代码

 

外键约束

外键约束是加在外键表中,外键表中也有主键。

Alter table 外键表 add constraint FK_外键表名_外键列 foreign key(外键列) references 主键表(主键列);

 

删除外键约束

alter table 表名 drop foreign key FK_表名_列名;

在创建表时还可以简写

Create table 表名(

T1id int primary key auto_increment,

Scid int,

Foreign key(scid) references 主表(主键列)

);

 

唯一约束

Alter table 表名 add constraint UQ_表名_列名 unique(列名);

在创建表时还可以简写

Create table 表名(

T1id int primary key auto_increment,

Scid int,

unique(列名)

);

 

默认值约束

Alter table 表名 alter 列名 set default 值;

  • 对于允许为空的列并且设置了默认值,插入时省略该列值为默认值;

Insert into 表名(主键[省略掉设置了默认值而且允许为空的列]) values(null);

  • 设置默认值,插入可以使用default关键字调用默认值;

Insert into 表名(主键,默认值列) values(null,default);

  • 插入时不要默认可以自由指定。

Insert into 表名(主键,默认值列) values(null,’其他值’);

创建表时又可以简写

Create table 表名(

默认值列 default 值

);

 

检查约束

Alter table 表名 add constraint CK_表名_列名 check(表达式);

ALTER table Student add constraint CK_Student_sname check(sname is not null);

 

创建表时可以简写

Create table Student(

Sname not null

);

 

Alter table Student add constraint CK_Student_sAge check(sAge>=18 and sAge<=60);

等同于

Alter table Student add constraint CK_Student_sAge check(sAge between 18 and 60);

 

MYSQL不知道检查约束!!

 

  • 对于由于操作系统或者浏览器外界元素的编码导致的乱码,在数据库中可以通过一个指令来纠正。

Set names 对应数据的编码;

Set character set 对应数据库的编码;

本文来自投稿,不代表重蔚自留地立场,如若转载,请注明出处https://www.cwhello.com/2930.html

如有侵犯您的合法权益请发邮件951076433@qq.com联系删除

(0)
重蔚重蔚管理团队
上一篇 2017年10月22日 22:28
下一篇 2017年10月24日 08:28

相关推荐

  • 我来分享sql网页版。

    SQL网页管理器是一种用于管理数据库的工具,它可以帮助用户轻松地创建、修改和删除数据库中的数据,通过使用SQL网页管理器,用户可以更加高效地进行数据库操作,提高工作效率,下面将详细介绍如何使用SQL网页管理器…

    2024年6月28日
    03
  • oracle密码怎么设置。

    您可以通过以下步骤设置Oracle密码:,1. 登录到Oracle数据库。,2. 使用DBA身份登录。,3. 输入命令进入Oracle控制台,连接后查看用户列表。,4. 修改用户口令即可。 Oracle数据库是一款功能强大的关系型数据库管…

    2024年7月16日
    01
  • 数据库基础之高级查询(数据库查询)

    普通查询 Select 列1[,列2,……] from 表名; 取出对应列所有行的数据; 要项取出对应列几行数据那么要加条件; select sName,sAge from Student where sAge=18   排序 默认情况下查询会按照表中主键升序来显示…

    2017年10月24日
    0289
  • 今日分享哪里买得到数据库,数据库表是怎么得到的。

    数据库是计算机系统中用于存储、管理和检索数据的软件系统,它通常由一个或多个表组成,每个表包含一组相关的数据记录,数据库可以在各种地方购买,包括在线商店、软件开发商的网站以及一些实体店铺。 我们来了解一…

    2024年6月30日
    01
  • wind数据库怎么打开。

    数据库的开通和使用是一个相对复杂的过程,需要一定的技术知识和操作经验,下面将详细介绍如何开通数据库以及如何使用Wind数据库。 一、数据库的开通 1. 选择合适的数据库类型:根据需求和预算,选择适合的数据库类…

    2024年6月29日
    02
  • 经验分享sql2000怎么导入mysql。

    在将SQL Server 2000数据库导入到MySQL数据库时,可以采用以下步骤: 1. 导出SQL Server 2000数据库:需要在SQL Server 2000中导出要导入的数据库,可以使用SQL Server Management Studio (SSMS)来执行此操作,打开…

    2024年6月28日
    01
  • PHP与数据库队列的集成。

    随着现代Web应用的发展,越来越多的需要将任务异步处理,以提高网站的性能和用户体验。其中一种常见的方式是使用队列系统,将需要处理的任务排队,然后由后台进程异步处理。而PHP和数据库都是Web开发中广泛使用的工…

    2023年5月21日
    05
  • 在PHPstudy中桌面通过cmd命令来连接数据库?

    通过PHPstudy中的cmd连接MYSQL。 1、打开PHPstudy 。 2、通过phpstudy打开cmd。 3、输入cmd命令: cd mysql  进入到mysql文件夹。 4、接着输入:cd bin  进入到数据库的bin目录 5、接着输入 mysql  -uroot -proot …

    2017年11月19日 MySQL自学教程
    0502

联系我们

QQ:951076433

在线咨询:点击这里给我发消息邮件:951076433@qq.com工作时间:周一至周五,9:30-18:30,节假日休息