• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Sql 约束(1)

mysql 搞代码 4年前 (2022-01-09) 23次浏览 已收录 0个评论

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

<link href=”/js/syntaxhighlighter/SyntaxHighlighter.css” rel=”stylesheet” type=”text/css” />

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
    来源gaodai#ma#com搞@代~码$网 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 <30)
    )

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

    在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


  • 搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
    转载请注明原文链接:Sql 约束(1)

    喜欢 (0)
    [搞代码]
    分享 (0)
    发表我的评论
    取消评论

    表情 贴图 加粗 删除线 居中 斜体 签到

    Hi,您需要填写昵称和邮箱!

    • 昵称 (必填)
    • 邮箱 (必填)
    • 网址