没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|行业资讯|编辑:董玉霞|2022-09-14 11:53:16.667|阅读 200 次
概述:本文介绍Navicat16.1 中选择主键的相关内容。
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
相关链接:
本文介绍Navicat16.1 中选择主键的相关内容。
身为数据库设计人员,你将面临的首要决定是你的表应使用哪种主键(PK)。如果你询问任何每天处理数据库的人,无论是数据库管理员、开发人员还是测试人员,你都会得到无数的意见和理由。使解决问题的障碍更加复杂的是,没有一种万能的解决方案。有鉴于此,本系列将介绍支持和反对不同类型 PK 的一些原因。在所有这些原因的某处,将会引导你找出 PK 的最佳类型,以满足你的组织需求。在第一部分中,我们将比较两种基本类型的 PK:自然键和代理键。稍后,我们将讨论是否使用数据库自动递增功能,以及哪些数据类型(如果有)是最好的 PK。
自然键是由表中已存在的一个或多个列组成的(例如,它们是数据模型中实体的属性),用于唯一标识表中的一条记录。由于这些列是实体的属性,因此它们本质上具有业务意义。以下是 Navicat Premium 16 的表设计器中有自然键的表示例。我们可以通过 “键”列中的钥匙图标轻松找到主键:
查看一下数据,可以知道 productCode 是有业务义意的:
代理键(或合成键、伪键、实体标识符、非事实型键、技术键等!)是由系统生成的(GUID、序列、唯一标识符等)值,没有业务意义,用于唯一标识表中的记录。键本身也可以由一列或多列(即复合键)组成。 我们可以看到在同一个数据库的表中有一个代理键,定义了一个customerNumber 列作为表的 PK:
虽然该列不是自动递增,但它是一个与客户实体无关的数字字段:
那么,为什么一个表使用自然键,而另一个表使用代理键呢?
产品有一个唯一的库存编号是很常见的,这是一个理想的PK。而添加一个额外的数字键只会浪费磁盘空间,并且几乎肯定需要在 productCode 列上添加一个用于搜索的额外索引。但另一方面,客户通常不会有一个唯一标识符。若你必须在数据库中辨识特定客户,可能需要一个长得惊人的列列表。因此,分配一个数字代理键来索引表中每一列通常要容易得多。
在 “选择主键”的第一部分中,我们探讨了自然主键和代理主键,并考虑了什么因素决定选择哪一种。决定一开始使用自然键还是代理键是很重要的,因为你选择哪种主键也将有助于解答一些后续问题,特别是使用代理键。
如果你想咨询Navicat价格或者咨询其他版本相关信息,点击查看。
想要了解更全面的数据库管理工具的相关功能讯息,欢迎加入QQ技术群:765665608
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com
Sparx EA不仅是一款建模工具,还成为了企业数字化转型的战略加速器。无论是通过多版本适配降低使用门槛,还是依托统一存储库和APM加速器提升治理效率,EA都展现了其在技术深度与易用性上的独特平衡。对于技术团队而言,选择EA意味着:告别碎片化工具链,拥抱全生命周期管理;通过标准化模型降低沟通成本,加速决策;在云原生时代,实现架构资产的可持续演进。
随着硬件性能提升和高性能图形引擎的发展,HOOPS提供了支持超大模型和密集点云数据的可视化能力,解决了长期困扰开发者的技术瓶颈。
在数字体验为王的时代,用户对界面的第一印象决定了产品的去留,然而,功能测试已无法满足用户对完美体验的需求。即使功能逻辑正确,字体错位、颜色偏差或元素重叠等视觉问题仍可能直接影响用户体验,甚至损害品牌信誉。如何突破传统测试的局限?答案在于 “视觉+自动化”的组合拳——通过自动化UI测试工具TestComplete与VisualTest的深度集成,实现功能与视觉的双重验证,打造真正高质量的UI。
DHTMLX React Scheduler正式发布!该组件将成熟稳定的JavaScript Scheduler功能完美移植到React生态,为现代Web开发提供强大的日程排程能力,极大地提升项目开发效率与界面体验。本文将带您快速了解其核心能力与典型用法,助力您轻松构建专业级排程系统。
Navicat for MySQL 是一套管理和开发 MySQL 或 MariaDB 的理想解决方案。
Navicat for OracleNavicat for Oracle是一套超强的Oracle数据库系统管理工具,包括数据模型工具、数据或结构同步、导入或导出、和报表,令维护数据的进程更容易。
Navicat PremiumNavicat Premium 是一套数据库管理工具,让你使用一个程序即可同時连接到 MySQL、MariaDB、SQL Server、SQLite、Oracle 和 PostgreSQL 数据库。
Navicat for SQL ServerNavicat for SQL Server 是一套专为 Mircosoft SQL Server设计的强大数据库管理及开发工具
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@evget.com
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
慧都科技 版权所有 Copyright 2003-
2025 渝ICP备12000582号-13 渝公网安备
50010702500608号