0

0

Sql 约束(1)

php中文网

php中文网

发布时间:2016-06-07 15:14:10

|

1596人浏览过

|

来源于php中文网

原创

SQL 约束 讲解 2009-04-27 09:29 约束 主要包括: NOT NULL UNIQUE PRIMARY KEY FOREIGN KEY CHECK DEFAULT 1、not null :用于控制字段的内容一定不能为空(NULL)。 用法 :Create table MyTable ( id varchar(32) not null , name varchar (32) ) 2、Uniq

SQL 约束讲解

2009-04-27 09:29

约束主要包括:

  • NOT NULL
  • UNIQUE
  • PRIMARY KEY
  • FOREIGN KEY
  • CHECK
  • DEFAULT

    1、not null :用于控制字段的内容一定不能为空(NULL)。
         用法 :Create table MyTable
                   (
                       id varchar(32) not null,
                       name varchar (32)
                   )

    2、Unique :控件字段内容不能重复,一个表允许有多个 Unique 约束
          在Sql Server、Orcale、MS Access 支持的添加 Unique 语法
                 Create table MyTable
                    (
                        id varchar(32) not null unique,
                        name varchar (32)
                    )

          在Sql Server、 My Sql 支持的添加 Unique 语法
                 Create table MyTable
                    (
                        id varchar(32) not null,
                        name varchar (32),
                       unique (id,.....)
                     )

          在Sql Server、Orcale、MS Access、My Sql 都支持的添加 Unique 语法
                  Create table MyTable
                      (
                          id varchar(32) not null,
                          name varchar (32),
                         Constraint uniqueName unique(UniqueColumn,.....)
                       )

          :第一种写法(也就是在字段后面直接添加约束),保证每个字段数据唯一性
              第二种写法(也就是同时添加几个字段为约束),这个是保证几个字段数据同时是唯一的,比如 Unique(id,name) 两个字段为约束,那么当 id 有重复值,而 name 没有重复值的情况下是允许的,只有当两个字段数据都与原数据重复的情况下才是不允许的。
       
       在Sql Server、Oracle、MS Access 删除 Unique 约束语法:drop constraintUniqueName;
       在My Sql 删除 Unique 约束语法:drop index UniqueName;

    3、Primary Key :也是用于控件字段内容不能重复,但它在一个表只允许出现一个。

  • 这个表的外键必须是另一个表的主键!
  • 表内至少要有一行数据才可以创建

  •       在Sql Server、Orcale、MS Access 支持的添加Primary Key语法
                  Create table myTB1
                 (
                     id nvarchar(32) not null primary key,
                     name nvarchar(32)
                  )
          在Sql Server、My Sql 支持的添加Primary Key 语法
                 Create table myTB1
                 (
                     id nvarchar(32) not null,
                     name nvarchar(32),
                     primary key (id)
                 )
           在Sql Server、Orcale、MS Access、My Sql 支持的添加Primary Key 语法
                 Create table myTB1
                 (
                      id nvarchar(32) not null,
                     name nvarchar(32),
                     constraint PrimaryName primary key (id)
                  )
    在Sql Server、Orcale、MS Access、My Sql 表已存在的情况下,添加表的Primary Key约束语法
                  Alter table myTB1
                  ADD Primary Key (id,......) --这样的写法,系统会自定义约束名称

                  Alter table myTB1
                  Add Constaint PrimaryName primary key (id)--这样的写法,自己可以自定义约束名称

    在Sql Server、Orcale、MS Access 删除表已存在的 Primary Key 约束的语法:
                  Alter table myTB1
                  Drop Constraint PrimaryName

    在My Sql 删除表已存在的 Primary Key 约束的语法:
                  Alter table myTB1
                  Drop Primary Key
    Unique 与 Primary 的相同之处:UNIQUE 和 PRIMARY KEY 约束均为列或列集合提供了唯一性的保证。
    Unique 与 Primary 的不同之处:每个表可以有多个 UNIQUE 约束,但是每个表只能有一个 PRIMARY KEY 约束,Unique允许有NULL值,而 Primary key 不允许有NULL值。

    :在同一个数据库中,就算在不同的表中,约束名称是不允许相同的。

    4、Foreign Key
    :FOREIGN KEY 约束用于预防破坏表之间连接的动作,FOREIGN KEY 约束也能防止非法数据插入外键列,因为它必须是它指向的那个表中的值之一。
       在Sql Server、My Sql 支持的添加Foreign Key语法
                  Create table myTB1
                  (
                       id nvarchar(32) not null primary key,
                       name nvarchar(32),
                       foreign key(id) references myTB(id)
                  )

       在Sql Server、Orcale、MS Access 支持的添加Foreign Key语法
                  Create table myTB1
                  (
                       id nvarchar(32) not null foreign key references myTB(id),
                       name nvarchar(32)
                  )

       在Sql Server、Orcale、MS Access、My Sql 都支持的添加Foreign Key语法
                  Create table myTB1
                  (
                       id nvarchar(32) not null primary key,
                       name nvarchar(32),
                        Constraint foreignName foreign key(id) references myTB(id)
                  )

    在Sql Server、Orcale、MS Access、My Sql 的表已存在情况下,向表添加外键约束的语法:
                  Alter table myTB1
                  Add foreign key(id) references myTB(id) --这样写系统会自定义约束名称

                   Alter table myTB1
                  Add Constraint foreignName foreign key(id) references myTB(id) --这样写自己可以自定义约束名称

    在Sql Server、Orcale、MS Access 中删除外键约束的语法:
                  Alter table myTB1
                  Drop Constraint foreignName;

    在My Sql 中删除外键约束的语法:
                  Alter table myTB1
                  Drop foreign key foreignName;


    5、Check :用于控制字段的值范围。
          在Sql Server、My Sql 支持的添加check 语法
                  Create table myCheck
                  (
                       id nvarchar(32) not null,
                       age int not null,
                       check (age>15 and age               )

           在Sql Server、Orcale、MS Access 支持的添加 check语法
                  Create table myCheck
                  (
                       id nvarchar(32) not null,
                       age int not null check (age>15 and age
                  )

          在Sql Server、Orcale、MS Access、My Sql 都支持的添加 check 语法
                   Create table myCheck
                  (
                       id nvarchar(32) not null,
                       age int not null,
                       constraint checkName check (age30)
                  )

    在Sql Server、Orcale、MS Access、My Sql 的表已存在情况下,向表添加check约束的语法:
                  Alter table myCheck
                  add check (id='celly'); --这样定义是系统自定义 check约束名称。

                  Alter table myCheck
                   add constraint checkName check(id='celly'); --这样定义是自己自定义 check约束名称。


    在 Sql Server、Orcale、MS Access 删除表已存在的 check 约束的语法:
                  Alter table myCheck
                  drop constraint checkName

    6、Default :用于设置新记录的默认值。

          在Sql Server、Orcale、MS Access、My Sql 添加default约束的语法:
                  Create table myDefault
                  (
                      id int,
                      name nvarchar(32) default 'celly'
                  )

          在My Sql 的已存在表中添加 字段默认值:
                   Alter table myDefault
                  Alter [id] set default 0

          在 Sql Server、Orcale、MS Access 的已存在表中添加 字段默认值:
                  Alter table myDefault
                  Alter column [id] set default 0

          在 My Sql 中删除字段默认值语法:
                  Alter table myDefault
                  Alter ColumnName drop default
  • 相关专题

    更多
    Word 字间距调整方法汇总
    Word 字间距调整方法汇总

    本专题整合了Word字间距调整方法,阅读下面的文章了解更详细操作。

    2

    2025.12.24

    任务管理器教程
    任务管理器教程

    本专题整合了任务管理器相关教程,阅读下面的文章了解更多详细操作。

    2

    2025.12.24

    AppleID格式
    AppleID格式

    本专题整合了AppleID相关内容,阅读专题下面的文章了解更多详细教程。

    0

    2025.12.24

    csgo视频观看入口合集
    csgo视频观看入口合集

    本专题整合了csgo观看入口合集,阅读下面的文章了知道更多入口地址。

    29

    2025.12.24

    yandex外贸入口合集
    yandex外贸入口合集

    本专题汇总了yandex外贸入口地址,阅读下面的文章了解更多内容。

    58

    2025.12.24

    添加脚注通用方法
    添加脚注通用方法

    本专题整合了添加脚注方法合集,阅读专题下面的文章了解更多内容。

    1

    2025.12.24

    重启电脑教程汇总
    重启电脑教程汇总

    本专题整合了重启电脑操作教程,阅读下面的文章了解更多详细教程。

    3

    2025.12.24

    纸张尺寸汇总
    纸张尺寸汇总

    本专题整合了纸张尺寸相关内容,阅读专题下面的文章了解更多内容。

    5

    2025.12.24

    Java Spring Boot 微服务实战
    Java Spring Boot 微服务实战

    本专题深入讲解 Java Spring Boot 在微服务架构中的应用,内容涵盖服务注册与发现、REST API开发、配置中心、负载均衡、熔断与限流、日志与监控。通过实际项目案例(如电商订单系统),帮助开发者掌握 从单体应用迁移到高可用微服务系统的完整流程与实战能力。

    1

    2025.12.24

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    SQL 教程
    SQL 教程

    共61课时 | 3万人学习

    SQL优化与排查(MySQL版)
    SQL优化与排查(MySQL版)

    共26课时 | 2.2万人学习

    MySQL索引优化解决方案
    MySQL索引优化解决方案

    共23课时 | 2万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号