`
isiqi
  • 浏览: 16337493 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

SQL约束(对比)

阅读更多

约束主要包括:

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 constraint UniqueName;
在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 <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 (age<15 and age>30)
)

在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


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/fancy050821/archive/2009/05/13/4176212.aspx

分享到:
评论

相关推荐

    SQL结构对比工具

    "SQL结构对比工具"是针对数据库开发和维护的专业辅助软件,它们帮助用户快速识别并解决数据库结构之间的差异,确保数据的一致性和准确性。 DBCompare是一款专门针对SQL SERVER数据库的结构比较工具,其核心功能是...

    sql数据库对比表工具

    "sql数据库对比表工具"就是这样一个专门用于此目的的实用软件。 这个工具提供了安装版和绿色版两种形式,以适应不同的使用环境和需求。安装版通常包含了完整的功能和设置,适合长期稳定的使用;绿色版则无需安装,...

    SQLSERVER表结构对比

    "SQLSERVER表结构对比"这个主题涉及到如何比较两个SQL Server数据库中的表定义,包括字段、索引、约束以及存储过程等差异。 SQL Server 2008 R2是在Windows 2008 R2 64位操作系统上运行的一个强大关系型数据库管理...

    sql数据库对比工具

    “SQL数据库对比工具”能够分析这些元素在两个数据库间的差异,比如表的字段数量、类型或约束不同,视图的定义不同,存储过程的代码有异,或者触发器的触发条件不一致。它不仅显示差异,还能生成相应的SQL语句,帮助...

    sqlserver数据库对比工具

    1. **对比表结构**:检查两个数据库中的表是否有不同的字段、数据类型、索引或约束。 2. **比较存储过程**:分析存储过程的定义,找出代码差异,这对于跟踪和更新复杂的业务逻辑至关重要。 3. **对比视图和函数**:...

    SQL Server中约束与触发器差异比较.pdf

    对比约束和触发器,约束在数据插入或更新时立即执行,通常更高效,且更易于理解和维护。它们直接与表结构相关联,强制执行预定义的规则。而触发器可能涉及多表操作,可以在事务中执行,对于需要在多个表之间保持一致...

    SQL数据库对比工具

    对比完成后,用户将获得一个清晰的差异报告,包括表结构、索引、约束、存储过程等各个方面的差异。 5. **功能特性**: - **结构对比**:检查表、视图、存储过程等数据库对象的结构差异。 - **数据对比**:比较两...

    SQLSERVER数据库对比工具

    1. **结构对比**:此功能允许用户比较两个数据库的模式,包括表、视图、索引、约束、存储过程、触发器和用户定义类型等。这有助于确保开发环境和生产环境的数据库结构一致性。 2. **数据对比**:除了结构对比,工具...

    SQLserver、Oracle、Mysql语法与用法对比

    - SQL Server:`alter table 子表 add constraint 外键约束名 foreign key (子表的列名) references 主表(列名) on update cascade / on update action` - Oracle:相同 - MySQL:相同 16. **添加索引约束**: ...

    mssql数据库对比工具

    1. **结构对比**:对比两个数据库中的表结构,包括字段名、数据类型、约束、索引等,确保数据库设计的一致性。 2. **对象对比**:除了表之外,还能对比存储过程、视图、函数、触发器等数据库对象,找出定义上的差异...

    比较SQLSERVER数据库差异

    在对比过程中,我们需要关注存储过程的名称、输入/输出参数、返回值、以及实际的SQL代码。不同数据库间的存储过程差异可能影响到业务流程的执行,因此这是对比的重点之一。 函数是预定义的计算逻辑,分为内建函数和...

    SQLserver、Oracle、Mysql语法与用法对比.doc

    《SQLserver、Oracle、Mysql语法与用法对比》 SQLserver、Oracle和Mysql是当前最主流的三种关系型数据库管理系统,它们在语法和用法上存在一些共性,但也各自具有特色。以下是对这三种数据库在常用操作上的对比分析...

    SqlServer连接工具

    此外,SSDT还包含了一个强大的数据库比较工具,可以对比不同数据库实例之间的结构差异,并生成同步脚本。 对于远程访问和跨平台需求,我们可以使用SQL Server的Web版管理工具,如Azure Data Studio。它是一款轻量级...

    SQL.Compare 数据库对比工具

    SQL Compare是一款强大的数据库对比工具,由Red Gate Software公司开发,版本10是其一个重要的迭代。这个工具的主要目的是帮助数据库管理员和开发人员快速识别并解决两个SQL Server数据库之间的结构差异,确保数据的...

    Oracle与SQL和Mysql的对比笔记

    - SQL Server: `ALTER TABLE 子表 ADD CONSTRAINT 外键约束名 FOREIGN KEY (子表的列名) REFERENCES 主表 (列名) ON UPDATE CASCADE / ACTION` - MySQL: `ALTER TABLE 子表 ADD CONSTRAINT 外键约束名 FOREIGN KEY...

    SQLDelta4 数据库比较工具

    它能对比两个数据库的结构,包括表、视图、索引、触发器、约束等对象。这项功能对于开发人员和DBA来说非常有用,例如在升级数据库架构或迁移数据时,可以快速定位并修正潜在的不兼容问题。 其次,SQLDelta4不仅对比...

    SQL SERVER基本语法参考

    `NOT NULL` 约束确保该列不允许有空值,`PRIMARY KEY` 定义了表的主键,用于唯一标识每行记录。 2. **修改表**: - 添加列:`ALTER TABLE table_name ADD column_name datatype` - 设置主键:`ALTER TABLE table_...

    SQL Server 实验指导书

    7. **实验7:联接与子查询对比** - **学习内容**:比较联接与子查询的不同之处。 - **重点**:掌握何时使用联接,何时使用子查询。 8. **实验8:聚合与GROUP BY** - **学习内容**:聚合函数和分组查询的使用。 ...

    mysql和sqlserver的比较

    本篇将详细对比这两种数据库在数据定义、约束以及索引等方面的异同。 首先,我们来看数据定义部分。在创建数据库表时,MySQL 和 SQL Server 使用 `CREATE TABLE` 语句。尽管语句结构类似,但具体的语法细节和功能...

    SQL Delta 4.2 + SN + 中文使用手册

    它能够对比两个数据库实例的差异,然后生成必要的SQL脚本来更新一个数据库以匹配另一个。这对于数据库的版本升级、备份恢复和团队协作非常有用。 2. **数据库结构比较**: 在SQL Delta 4.2中,用户可以比较数据库...

Global site tag (gtag.js) - Google Analytics