• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > SQL server约束

SQL server约束

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了server,约束等相关知识,希望本文的分享对您有所帮助

约束的概念:确保在列中输入有效的值并维护表之间的关系。


Primary key约束

功能:primary key(主键约束),一个表中只能有一个,不能有空值,不能有重复值.

创建表时定义约束:字段名 数据类型[长度] primary key

Unique约束
功能:unique(唯一约束), 指定在同一列中的两行不能有相同的值,只能有一行为空值。

创建表时定义约束:字段名 数据类型 unique

Default约束

功能:执行insert语句时将默认值自动插入约束所在的列

创建表时定义约束:字段名 数据类型 default 默认值
Default 约束注意事项
1、每列只能定义一个default约束。
2、不能用于有identity属性的列
3、如果定义的默认值长于其对应字段的允许长度,那么输入到表中的默认值将被截断。
4、有default约束的字段,可插入其他的值,若不插入, 则以默认值为纪录值,且后面创建的默认约束对已
经存在的数据没有影响.

Check约束
功能:check(检查约束),每次执行Insert/update语句时,该约束要校验数据的合法性。

创建表时定义约束:字段名 数据类型 check(条件)

Check约束注意事项
1、一个表中可以定义多个检查约束,但每个字段只 能定义一个检查约束。
2、当执行insert语句或者update语句时,检查约束 将验证数据。
3 、如果对已经有数据的表添加约束,可以用with nocheck避免对以前的数据做检查.

Foreign key 约束

功能:确保主关键字(主表中)和外关键字(辅表中)的关系。
创建表时定义约束:字段名 数据类型 foreign key(字段名) references 表名(字段名)
注意:foreign Key子句中指定的列数和数据类型必须和在references子句中的列数和数据类型匹配。且关联
的表的字段必须设置为主键.

修改约束
修改表时添加约束

alter table 表名
add constraint 约束名 primary key(字段名) –-主键
add constraint 约束名 unique (字段名)    --唯一
add constraint 约束名 default(默认值) for 字段名 –默认
add constraint 约束名 check(条件) –检查
add constraint 约束名 foreign key(字段名) references 主键表(参照字段名)  --外键

删除约束
语法:

alter table 表名 drop 约束名

【例】 删除 xs表的pk_xs约束。

alter table xs drop constraint  pk_xs

注意:
1.要删除被约束的列,必须先删除约束
2.存在外键约束时,要删除主健,必须先删除对应的外键

以上就是SQL server约束 的详细内容,更多请关注微课江湖其它相关文章!

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 使用use index优化sql查询的详细介绍
  • 如何获取SqlServer2005表结构(字段,主键,外键,递增,描述)
  • SQL SERVER 日期格式转换详解
  • 如何在SQL Server中实现 Limit m,n 的功能
  • 基于SQL中SET与SELECT赋值的区别详解
  • 深入Mysql,SqlServer,Oracle主键自动增长的设置详解
  • DBA应该知道的一些关于SQL Server跟踪标记的使用
  • SQL查询超时的设置方法(关于timeout的处理)
  • MySQL rownumber SQL生成自增长序号使用介绍
  • mysql启动提示mysql.host 不存在,启动失败的解决方法

相关文章

  • 2018-12-05MySQL表排序规则不同报错问题分析
  • 2017-05-11mysql 数据库基础笔记
  • 2017-05-11深入mysql外键关联问题的详解
  • 2018-12-05Mysql相关_MySQL
  • 2017-05-11使用Rotate Master实现MySQL 多主复制的实现方法
  • 2018-12-05Oracle set和reset的使用教程案例
  • 2018-12-05关于mysql innodb启动失败无法重启的处理方法讲解
  • 2018-12-05MySQL5.6在Centos6.5下安装教程
  • 2018-12-05[js]javascript与剪贴板交互
  • 2018-12-05MySQL查询时间基础教程

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • 关于MySQL的整型数据的内存溢出问题的应对方法
    • SQL Select语句完整的执行顺序
    • Oracle监听器无法启动,提示“错误1067:进程意外终止”
    • Visual Studio2017数据库架构介绍
    • linux下mysql数据库单向同步配置方法分享
    • mysql服务1067错误多种解决方案分享
    • 高效的mysql分页方法及原理
    • MySQL中curdate()函数的代码案例
    • 排名前十的SQL和NoSQL数据库
    • 命令行查询实例用法汇总

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有