彩世界平台-彩世界时时app-彩世界开奖app苹果下载

热门关键词: 彩世界平台,彩世界时时app,彩世界开奖app苹果下载

您的位置:彩世界平台 > 工作委员会 > SQLServer之DEFAULT约束

SQLServer之DEFAULT约束

发布时间:2019-08-30 10:07编辑:工作委员会浏览(164)

    DEFAULT约束添加规则

    1、若在表中定义了默认值约束,用户在插入新的数据行时,如果该行没有指定数据,那么系统将默认值赋给该列,如果我们不设置默认值,系统默认为NULL。

    2、如果“默认值”字段中的项替换绑定的默认值(以不带圆括号的形式显示),则将提示你解除对默认值的绑定,并将其替换为新的默认值。

    3、若要输入文本字符串,请用单引号 (') 将值括起来;不要使用双引号 ("),因为双引号已保留用于带引号的标识符。

    4、若要输入数值默认值,请输入数值并且不要用引号将值括起来。

    5、若要输入对象/函数,请输入对象/函数的名称并且不要用引号将名称括起来。

    一、约束的分类

      在SQLServer中,有3种不同类型的约束。

      1、实体约束

        实体约束是关于行的,比如某一行出现的值就不允许出现在其他行,例如主键。

      2、域约束

        域约束是关于列的,对于所有行,某一列有那些约束,例如CHECK约束。

      3、参照完整性约束

        如果某列的值必须与其他列的值匹配,那就意味着需要一个参照完整性约束,例如外键。

    使用SSMS数据库管理工具添加DEFAULT约束

    1、连接数据库,选择数据表-》右键点击-》选择设计。

    图片 1

    2、在表设计窗口中-》选择数据列-》在列属性窗口中找到默认值或绑定-》输入默认值(注意默认值的数据类型和输入格式)。

    图片 2

    3、点击保存按钮(或者ctrl+s)-》刷新表-》再次打开表查看结果。

    图片 3

    二、约束命名

      在学习约束之前,首先来了解下为约束命名需要注意哪些地方。

      SQLServer在我们不提供名称时,会自动创建名称,但是由系统自动创建的名称并不是特别有用。

      例如,系统生成的主键名称可能是这样的:PK_Employees_145C0A3F。 

      PK代表主键(primary key),Employees代表在Employees表中,而剩下的“145C0A3F”部分是为了保证唯一性而随机生成的值。只有通过脚本创建才会得到这种值,如果是通过Managerment Studio创建表,那么就直接是PK_Employees。

      对于系统自动生成的Check约束名称如:CK_Customers_22AA2996。CK代表这是一个Check约束,Customers代表是在Customers表中,后面的22AA2996还是一个随机数。如果一个表中有多个Check约束,则命名可能如下:

      CK_Customers_22AA2996

      CK_Customers_25869641

      CK_Customers_267ABA7A

      如果你需要修改这些约束其中的一个,那么你很难分辨这些约束到底是哪一个。

      因此,为了能够一眼看上去就知道这个约束是用来干什么的,我们应该使用一种简单明了的短语来进行命名。

      例如要确保某一列电话号码格式正确的约束,我们可以使用命名CK_Customers_PhoneNo这样的短语来命名。

      总之命名要做到以下几点:

      1、一致性

      2、通俗易懂

      3、满足以上两个条件的情况下简化名称。

    使用T-SQL脚本添加DEFAULT约束

    三、键约束

    当表结构已存在时

    首先判断表中是否存在默认约束,如果存在则先删除默认约束再添加,如果不存在则直接添加。

    语法:

    use 数据库
    go
    --判断默认约束是否存在,如果存在则先删除,如果不存在则直接添加
    if exists(select * from sysobjects where name=约束名)
    alter table 表名 drop constraint 约束名;
    go
    --给指定列添加默认约束
    alter table 表名 add constraint 约束名 default(约束值) for 列名;
    go

    示例:

    use [testss]
    go
    --判断默认约束是否存在,如果存在则先删除,如果不存在则直接添加
    if exists(select * from sysobjects where name='defalut_height')
    alter table [testss].[dbo].[test1] drop constraint defalut_height;
    go
    --给指定列添加默认约束
    alter table [testss].[dbo].[test1] add constraint defalut_height default(160) for height;
    go

    图片 4

    图片 5

    1、主键约束

       主键是每行的唯一标识符,仅仅通过它就能准确定位到一行,其中主键列在整个表中不能有重复,必须包含唯一的值(不能为NULL)。由于主键在关系数据库中的重要性,因此它是所有键和约束中最重要的。

       下面来说说主键的创建方式

      1、在创建表的时候创建主键约束。

    create table customer
    (
        customerId        int identity    not null
            primary key,  --创建主键约束
        CustomerName    nvarchar(30)    not null
    );
    

      怎么样,非常简单吧!

      2、在已存在的表上创建主键约束

      现在假设已经存在了一张表,但是还没有主键约束:

    alter table person
        add constraint PK_Employee_Id  --外键名称
        primary key(personId)  --personId 字段名
    

      alter名称告诉SQLServer如下信息:

      1、添加了一些内容到表中(也可以删除表中的某些内容)

      2、添加了什么内容(一个约束)

      3、对约束的命名(允许以后直接访问约束)

      4、约束的类型(主键约束)

      5、约束应用于哪个列。

      3、复合主键的创建

      如果实在Management Studio中,创建复合主键,只需要按住Ctrl键,选中两个列,然后设置为主键就OK了,非常简单。下面主要讲述使用T-SQL创建复合主键的方法:

    ALTER TABLE 表名 WITH NOCHECK ADD 
    CONSTRAINT [PK_表名] PRIMARY KEY NONCLUSTERED 
    ( 
    [字段名1], 
    [字段名2] 
    ) 
    

      在多对多联系中,常常会有一张表来描述其他两张表的关系,就以此读者和书为例子:

    图片 6

    ALTER TABLE ReaderAndBook 
    ADD 
    CONSTRAINT [PK_ReaderAndBook] PRIMARY KEY NONCLUSTERED 
    ( 
    ReaderId, 
    BookId 
    ) 
    

    图片 7

    创建表时添加默认约束

    首先判断表是否选在,如果存在则先删除表再添加,如果不存在则直接添加。

    语法:

    --创建新表时添加默认约束
    --数据库声明
    use 数据库名
    go
    --如果表已存在则先删除表再创建,如果表不存在则直接创建
    if exists(select * from sysobjects where name=表名 and type ='U')
    drop table 表名;
    go
    --建表语法声明
    create table 表名
    (
    --字段声明
    列名 列类型 identity(1,1) not null,
    列名 列类型) null,
    列名 列类型 null,
    列名 列类型 null,
    列名 列类型,
    列名 列类型 constraint 约束名 default 默认值,
    primary key clustered(列名 asc) with(ignore_dup_key=off) on [primary] --主键索引声明
    )on [primary]

    --字段注释声明
    exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'列说明' , @level0type=N'SCHEMA',
    @level0name=N'dbo', @level1type=N'TABLE',@level1name=N'表名', @level2type=N'COLUMN',@level2name=N'列名';

    exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'列说明' , @level0type=N'SCHEMA',
    @level0name=N'dbo', @level1type=N'TABLE',@level1name=N'表名', @level2type=N'COLUMN',@level2name=N'列名';

    exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'列说明' , @level0type=N'SCHEMA',
    @level0name=N'dbo', @level1type=N'TABLE',@level1name=N'表名', @level2type=N'COLUMN',@level2name=N'列名';

    exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'列说明' , @level0type=N'SCHEMA',
    @level0name=N'dbo', @level1type=N'TABLE',@level1name=N'表名', @level2type=N'COLUMN',@level2name=N'列名';

    exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'列说明' , @level0type=N'SCHEMA',
    @level0name=N'dbo', @level1type=N'TABLE',@level1name=N'表名', @level2type=N'COLUMN',@level2name=N'列名';

    go

    示例:

    --创建新表时添加默认约束
    --数据库声明
    use testss
    go
    --如果表已存在则先删除表再创建,如果表不存在则直接创建
    if exists(select * from sysobjects where name='test1' and type ='U')
    drop table test1;
    go
    --建表语法声明
    create table test1
    (
    --字段声明
    id int identity(1,1) not null,
    name nvarchar(50) null,
    sex nvarchar(50) null,
    age nvarchar(50) null,
    classid int,
    height int constraint default_he default 166,
    primary key clustered(id asc) with(ignore_dup_key=off) on [primary] --主键索引声明
    )on [primary]

    --字段注释声明
    exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'id主键' , @level0type=N'SCHEMA',
    @level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'id';

    exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'姓名' , @level0type=N'SCHEMA',
    @level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'name';

    exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'性别' , @level0type=N'SCHEMA',
    @level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'sex';

    exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'年龄' , @level0type=N'SCHEMA',
    @level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'age';

    exec sys.sp_addextendedproperty @name=N'MS_Description', @value=N'班级id' , @level0type=N'SCHEMA',
    @level0name=N'dbo', @level1type=N'TABLE',@level1name=N'test1', @level2type=N'COLUMN',@level2name=N'classid';

    go

    图片 8

    图片 9

    2、外键约束

      外键既能确保数据完整性,也能表现表之间的关系。添加了外键之后,插入引用表的记录要么必须被引用表中被引用列的某条记录匹配,要么外键列的值必须设置为NULL。

      外键和主键不一样,每个表中的外键数目不限制唯一性。在每个表中,每一有-~253个外键。唯一的限制是一个列只能引用一个外键。一个列可以被多个外键引用。

      1、创建表的时候创建外键

    图片 10

    create table orders
    (
        orderId        int identity    not null
            primary key,
        customerId    int                not null
            foreign key references customer(customerId)  --约束类型-外键-引用表(列名)
    );
    

    图片 11

      2、在已存在的表中添加一个外键

      假设上面的代码去掉了添加外键行,那么可以书写代码如下:

    alter table orders
        add constraint FK_Orders_CustomerId        --添加约束 名称
            foreign key (customerId)    references customer(customerId)    --外键约束,外键列名,被引用列名
    

      刚添加的约束和之前添加的约束一样生效,如果某行引用customerId不存在,那么就不允许把该行添加到Orders表中。

      3、级联动作

      外键和其他类型键的一个重要区别是:外键是双向的,即不仅是限制子表的值必须存在于父表中,还在每次对父表操作后检查子行(这样避免了孤行)。SQLServer的默认行为是在子行存在时“限制”父行被删除。然而,有时会自动删除任何依赖的记录,而不是防止删除被引用的记录。同样在更新记录时,可能希望依赖的记录自动引用刚刚更新的记录。比较少见的情况是,你可能希望将引用行改变为某个已知的状态。为此,可以选择将依赖行的值设置为NULL或者那个列的默认值。

      这种进行自动删除和自动更新的过程称为级联。这种过程,特别是删除过程,可以经过几层的以来关系(一条记录依赖于另一条记录,而这另一条记录又依赖其他记录)。在SQLServer中实现级联动作需要做的就是修改外键语法-只需要在添加前面加上ON子句。例如:

    alter table orders
        add constraint FK_Orders_CustomerId        --添加约束 名称
            foreign key (customerId)    references customer(customerId)    --外键约束,外键列名,被引用列名
            on update     no action    --默认  修改时不级联更新子表
            on delete     cascade      --删除时级联删除依赖行
    

      当在进行级联删除时,如果一个表级联了另一个表,而另一个表又级联了其他表,这种级联会一直下去,不受限制,这其实是级联的一个危险之处,很容易一个不小心删掉大量数据。

      级联动作除了no action,cascade之外,还有set null和set default。后两个是在SQLServer2005中引入的,如果要兼容到SQLServer2000的话,要避免使用这两个级联动作。但是他们的才做是非常简单的:如果执行更新而改变了一个父行的值,那么子行的值将被设置为NULL,或者设置为该列的默认值(不管SET NULL还是SET DEFAULT)。

      4、外键其他方面的考虑

        外键中的之只有相中可能的选择:

        1、在列中填充与被引用表中的相应列相匹配的值。

          通过定义引用列为NOT NULL,可以使外键完全是必须的(即用户添加数据时必须引用表中必须有相匹配的一行数据)。

        2、不填充任何值,而使该值为NULL。

          允许引用列有NULL值时,用户可以选择不提供值-即使在被引用表没有与NULL值匹配的行,还是允许插入。

    DEFAULT约束优缺点

    优点:

    1、使用默认值可以减少代码量,新增数据时可以不用写新增默认值列,执行新增操作时时默认填充。

    2、较有利于进行统计和分析,以及方便程序逻辑操作。

    缺点:

    1、使用不为NULL的默认值,占用了更多的存储空间。

     

    3、唯一约束

      唯一约束与主键比较相似,共同点在于它们都要求表中指定的列(或者列的组合)上有一个唯一值,区别是唯一约束没有被看作表中记录的唯一标识符(即使你可以按这样的方式使用也有效),而且可以有多个唯一约束(而在每个表中只能有一个主键)。

      一旦建立了唯一约束,那么指定列中的每个值必须是唯一的。如果更新或者插入一条记录在带唯一约束的列上有已经存在的值的记录,SQLServer将抛出错误,拒绝这个记录。

      和主键不同,唯一约束不会自动防止设置一个NULL值,是否允许为NULL由表中相应列的NULL选项的设置决定,但即使确实允许NULL值,一张表中也只能够插入一个NULL值(如果允许多个,那就不叫唯一了)。

      在已存在的表上创建唯一约束:

    alter table Account
        add constraint AK_AccountName    --约束名
        unique (Account_Name)    -- 列名
    

      AK代表替换键(Alternate Key),唯一约束也叫替换键。

      主键和唯一约束的区别:

    •     主键约束不允许出现NULL值。任何索引的索引键都不允许包含null值。但唯一约束允许包含NULL值,但唯一约束把两个NULL值当作重复值,所以施加了唯一约束的每一列只允许包含一个NULL值。
    •     创建主键时会自动创建聚集索引,除非当前表中已经含有了聚集索引或是创建主键时指定了NONCLUSTERED关键字。
    •     创建唯一约束时会自动创建非聚集索引,除非你指定了CLUSTERED关键字并且当前表中还没有聚集索引。
    •     每个表中只能有一个主键,但可以由多个唯一约束。

    本文由彩世界平台发布于工作委员会,转载请注明出处:SQLServer之DEFAULT约束

    关键词: