数据库约束定义及分类

约束

约束定义及分类:

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日
下一篇 2017年10月24日

相关推荐

  • 关于自建服务器可以用来干什么。

    自建服务器可以用来干什么 随着互联网的普及和发展,越来越多的企业和个人开始关注到服务器的重要性,服务器作为网络的核心设备,承担着存储、处理和传输数据的重要任务,自建服务器可以用来干什么呢?本文将从以下…

    2024年7月6日
    00
  • 经验分享宝塔建站怎么本地调试。

    宝塔建站本地调试是开发者在开发过程中经常需要进行的一项操作,它可以帮助开发者在本地环境中测试和修改网站代码,确保网站在上线前能够正常运行,以下是详细的技术介绍: 环境准备 在开始本地调试之前,你需要确…

    2024年7月10日
    00
  • 常用操作指令与管理和使用数据库步骤

    常用操作指令与管理和使用数据库步骤 常用操作指令 登录 Mysql -h主机地址 -u用户名 -p   退出 Quit / exit   显示所有数据库 Show databases;   切换数据库 Use 数据库名;   显示所有表 Show …

    2017年10月20日
    0187
  • 我来说说ubuntu启动mysql。

    在Ubuntu系统中,启动MySQL数据库服务器非常简单,下面是详细的步骤: 1. 打开终端,你可以通过点击左上角的”应用”,然后在搜索框中输入”终端”,找到并点击它来打开终端。 2. 在终端中,输入…

    2024年6月16日
    00
  • 经验分享动态网页如何优化,如何设计动态网页。

    动态网页优化和设计是一个复杂而细致的过程,涉及到多个方面,以下是一些关于如何优化和设计动态网页的建议: 1. 优化数据库查询:数据库查询是动态网页中最常见的性能瓶颈之一,为了优化数据库查询,可以采取以下…

    2024年6月28日
    00
  • 我来教你asp.net web连接数据库的方法是什么。

    在ASP.NET Web应用程序中,连接数据库的方法主要有两种。一种是使用ADO.NET来连接数据库,这需要创建一个数据库连接,设置连接字符串,指定数据库的服务器名称,数据库名称,用户名等。另一种是使用MySQL for Visua…

    2024年7月18日
    00
  • 我来说说独立云虚拟主机租用可以干什么。

    独立云虚拟主机租用可以用于以下用途:1. 网站托管:将自己的网站托管在独立云虚拟主机上,可以享受更高的网站访问速度和更稳定的服务器环境,同时还可以根据需要自由地安装和配置各种网站应用程序。2. 应用程序部…

    2024年7月15日
    00
  • 教你如何管理mysql数据库。

    MySQL是一种开源的关系型数据库管理系统,它可以用于管理关系型数据库。要管理MySQL数据库,您需要了解SQL语言。SQL是结构化查询语言,它是用于管理关系型数据库的标准语言。您可以使用SQL语句来创建、删除和修改数…

    2024年7月24日
    00

联系我们

QQ:951076433

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