在 SQL Server 上使用或不使用 CONSTRAINT 关键字的区别

2023-11-21

使用和不使用有什么区别CONSTRAINT在 SQL Server 上使用外键时的关键字?

我注意到在这个特定情况下显然两者的工作原理相同,没有CONSTRAINT:

CREATE TABLE ClientsPhones
(
     ClientPhone varchar(10) NOT NULL,
     ClientID smallint NOT NULL,

     PRIMARY KEY (ClientPhone),
     FOREIGN KEY (ClientID) REFERENCES Clients(ClientID)
);

CONSTRAINT:

CREATE TABLE ClientsPhones
(
    ClientPhone varchar(10) NOT NULL,
    ClientID smallint NOT NULL,

    PRIMARY KEY (ClientPhone),
    CONSTRAINT fk_ClientID 
      FOREIGN KEY (ClientID) REFERENCES Clients(ClientID)
);

两者都不允许我向表中添加记录,除非ClientID已经存在于Clients表,并且相同ClientID and ClientPhone尚未加入ClientsPhones table.

除了我能够命名约束这一事实之外,两者之间还有什么真正的区别吗?


如果你不创造约束。它会自动创建自己的约束名称

外键索引名称是使用引用外键列的名称自动生成的。

所以没有办法看出差异使用和不使用 Constraint 关键字。默认情况下将定义约束名称。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

在 SQL Server 上使用或不使用 CONSTRAINT 关键字的区别 的相关文章

随机推荐

  • 如何为 VS Code 创建简单的自定义语言着色

    我正在尝试为日志文件创建一个简单的着色 现在可以在代码中包含自定义语言 我使用的是 0 9 2 我创建了一个简单的 tmLanguage 文件来对字母 q 进行着色 只是为了启动 但没有成功 我的新语言 log 与文件扩展名正确关联 我也可
  • 如何查找 MySQL 中缺失的索引?

    5 我想识别其中丢失的索引 有人可以帮我识别吗 这将帮助我们提高导致应用程序的查询的性能 我能想到的最好的办法就是使用EXPLAIN检查带索引和不带索引的查询的执行计划 然后查看查询性能的差异 您还可以参考 MySQL执行计划是否依赖于可用
  • VS 更新到 17.7.3 后无法连接到 Mac

    我刚刚在 Windows PC 上安装了新的 Visual Studio 2022 Update 17 7 3 从那时起 我无法再与我的 Mac 配对来部署我的 NET MAUI 应用程序 我收到以下错误消息 无法安装工作负载 ios 详细
  • 我需要一个初学者指南来设置 Windows 进行 Python 开发

    我目前只使用 NET 并且想尝试一下 python 为此我需要搭建一个python开发环境 我对此的指导会很方便 我想我会进行网络开发 所以需要一个网络服务器 可能还需要一个数据库 我还需要流行的 ORM MVC 框架和测试库的指针 我对这
  • 使用 Jetpack Compose 时如何使两个按钮宽度相同?

    我运行代码 A 并得到结果 A 如何使两个按钮的宽度相同 顺便说一句 你知道不同的字符串有不同的宽度 你不能编写硬代码 例如Modifier width 100 dp Code A Row modifier Modifier fillMax
  • 如何上传/设置Azure Blob存储的default.html页面?

    首先 如何将文件上传到 blob 根目录 看来我必须将文件上传到容器 IMO 是一个文件夹 其次 如果我最终找到了将文件上传到根目录的方法 default html 页面 或其他名称 是否会成为该域的默认页面 Thanks 有一个名为 ro
  • 如何提取画布中图像的一部分并将其用作 div 的背景图像?

    这就是我的代码的样子 document addEventListener DOMContentLoaded function var canvas document querySelector canvas var ctx canvas g
  • 部分类、LINQ、接口和 VB.NET

    好的 我在 VB NET 中遇到了问题 那么所有 VB NET 的维护者们能帮帮我吗 这是我的问题 我正在使用 LINQ to Entities 它也可以与 LINQ to SQL 一起使用 我构建我的 edmx 文件 然后创建一个与实体之
  • traefik代理后面的docker中的gitlab失败(通常)

    我有几个网站在 docker 中运行 使用 LetsEncrypt 凭据并通过 traefik 进行路由 我想在 docker 中使用 LetsEncrypt 和 traefik 运行本地 gitlab ce 所以我将其添加到我的 trae
  • Typescript 接口默认值

    我在 TypeScript 中有以下界面 interface IX a string b any c AnotherType 我声明该类型的变量并初始化所有属性 let x IX a abc b null c null 然后我稍后在 ini
  • 读取csv文件中的特定行,python

    In an CSV使用python的文件我们可以逐行或逐行读取所有文件 我想读取特定行 第24行示例 而不读取所有文件和所有行 您可以使用行缓存 getline linecache getline 文件名 lineno module glo
  • 使用高级加密标准算法 (AES) 在 Typescript 中加密字符串并在 C# 中解密

    我很难在打字稿中实现加密并在 C 中实现解密 在在这里发布问题之前 我用 Google 搜索并找到了一些链接 但这些链接与 JavaScript 而不是打字稿相关 在 javascript 中加密并使用 AES 算法在 C 中解密 使用 a
  • 如何告诉 Eclipse 使用与通常不同的 JRE 版本来编译和构建项目?

    我不确定这个问题是否已得到完整回答 或者我的标题是否足够描述我的情况 但我被要求将项目从使用 Ant 构建转换为 Maven 这部分还不错 但我被告知这个应用程序是专门为 JRE 1 5 版而不是我一直在处理的其他应用程序使用的 JRE 6
  • 为什么不使用 GlobalScope.launch?

    我读到了这个用法Globalscope非常沮丧 here 我有一个简单的用例 对于我收到的每条 kafka 消息 假设是一个 Id 列表 我必须将其拆分并同时为每个 Id 调用休息服务 并等待其完成并继续执行其他同步任务 该应用程序中没有其
  • 获取最后一个插入 ID 的标准方法是什么?

    获取最后插入的id的sql标准是什么 如果有这样的事情的话 mysql LAST INSERT ID postgresql 返回 f idmssql SCOPE IDENTITY 更多例子在这里 我的意思是 所有数据库都有不同的实现 这样的
  • AMQP C++ 实现 [关闭]

    Closed 此问题正在寻求书籍 工具 软件库等的推荐 不满足堆栈溢出指南 目前不接受答案 我们正在编写需要消息传递的 C 代码 是否有免费 开源且稳定的 AMQP 服务器可用 并且具有同样稳定的 C 客户端库 我们还需要向用户提供代码的
  • Xamarin.Forms - 用于异步操作的 BeginInvokeOnMainThread

    我熟悉有关使用 Device BeginInvokeOnMainThread 在 UI 线程上更新 UI 元素的规则 但是我有一个需要在 UI 线程上运行的操作 该操作实际上是一个任务 例如 XLabs Forms Mvvm 上的 Push
  • 如何停用 GMail 计量电子邮件?

    如何停用 google apps 脚本 活动报告 我尝试了gmail Meter 最后删除了google docs中的文档 现在 每天晚上我都会收到一份报告 如下 Ihr Skript Gmail Meter konnte nicht er
  • React - 如何在 Jest 中对 API 调用进行单元测试?

    我有一堆 API 调用 我想对其进行单元测试 据我所知 单元测试 API 调用并不涉及实际进行这些 API 调用 据我所知 您会模拟这些 API 调用的响应 然后测试 DOM 更改 但我目前正在努力做到这一点 我有以下代码 App js f
  • 在 SQL Server 上使用或不使用 CONSTRAINT 关键字的区别

    使用和不使用有什么区别CONSTRAINT在 SQL Server 上使用外键时的关键字 我注意到在这个特定情况下显然两者的工作原理相同 没有CONSTRAINT CREATE TABLE ClientsPhones ClientPhone