SQL Server外键关系是强制约束,外键值也可以是空(NULL)

本文探讨了SQL Server中外键约束与允许NULL值的关系。即使外键设置为强制约束,外键列仍然可以接受NULL值。通过示例创建表及插入数据,展示了外键约束主要针对非空值进行限制,而是否允许NULL值取决于表的设计。
摘要由CSDN通过智能技术生成

在SQL Server中,实际上外键值可不可以为空(NULL),和外键关系是不是强制约束无关。

 

我们先在SQL Server数据库中建立两张表People和Car,一个People可以有多个Car,所以这两张表是一对多关系。

 

 

建立表

People建表语句:

CREATE TABLE [dbo].[People](
    [ID] [int] NOT NULL,
    [Name] [nvarchar](50) NULL,
    [Age] [int] NULL,
    [Sex] [nvarchar](50) NULL,
 CONSTRAINT [PK_People] PRIMARY KEY CLUSTERED 
(
    [ID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
GO

其中列ID是People表的主键

 

Car建表语句:

CREATE TABLE [dbo].[Car](
    [ID] [int] NOT NULL,
    [Brand] [nvarchar](50) NULL,
    [PeopleID] [int] NULL,
 CONSTRAINT [PK_Car] PRIMARY KEY 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值