没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:吴园园|2020-05-29 09:28:45.653|阅读 213 次
概述:第1部分探讨了MySQL的严格SQL模式的后果,以及如何使用Navicat for MySQL 15对其进行查看和设置。今天的后续文章中,我们将讨论何时使用默认值以及如何提出默认值。
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
相关链接:
Navicat for MySQL是一套管理和开发 MySQL 或 MariaDB 的理想解决方案。数据传输、数据同步和结构同步让你以低成本轻松快速地迁移数据。提供详细的指引,在各种数据库之间传输数据。比对和同步数据库的数据和结构。只需几秒钟就能设置和部署比对,并获得你要运行更改的详细脚本。
第2部分:何时使用它们
您可能已经知道,在非null列上设置默认值有助于摆脱那些讨厌的“字段'xyz'没有默认值”错误。希望您也意识到,保持错误信息本身并不是提供默认值的有效理由。提供默认列值的原因很多-有些很好,有些则更少。第1部分探讨了MySQL的严格SQL模式的后果,以及如何使用Navicat for MySQL 15对其进行查看和设置。在今天的后续博客中,我们将讨论何时使用默认值以及如何提出默认值。
为什么不只允许空值?
可空列不像非空列那样面临相同的挑战,那么为什么不在所有非键列中都允许空值呢?在许多情况下,将非null约束应用于列的目的是迫使填充它的应用程序或系统提供值。有时,非空列可能包含审核信息,例如用户ID或时间戳。无论哪种情况,您都在寻找有效的数据,而不仅仅是填充。
这是一个重要的考虑因素,因为它带动了生成有用的默认值以及前端验证的重要性。我仍然记得我的第一个Web应用程序。它收集了用户详细信息,例如姓名,电子邮件和电话号码。所有这些字段都是必填字段,因此聪明的用户找到了各种规避输入真实信息的方法,例如输入电话号码111-111-1111和“ Elmer J. Fudd”之类的名称。
产生时间戳记
现在,我们已经讨论了一些原因,为什么随时可以自动填充字段值得这样做,让我们来看一个生成值的常见示例:审计时间戳记。
Sakila示例数据库中的某些表具有last_update列。这些应用时间戳数据类型;其值设置为MySQL CURRENT_TIMESTAMP函数的输出。在Navicat(高级功能如下图所示)中,您可以通过下拉列表设置默认值:
该默认值设置上记录创建时间戳,而检查在更新CURRENT_TIMESTAMP框告诉MySQL更新每次更新操作的时间戳。
前哨值
在RDBMS中,前哨值是具有特殊含义的值。例如,年龄列中的值999表示它是未知的。我还看到了使用“ 1900-01-01”作为未知日期的应用程序。前哨值在您要分配“未知”值的情况下很有用,而空值表示“无值”。并不是每个人都喜欢哨兵值,因为使用数据库的人员和应用程序必须知道所有哨兵值才能正确处理它们。
结论
尽管默认值(并作为扩展名)在组织良好的数据库设计和开发中具有前哨值,但在分配值之前,应考虑每个值的用途。仅仅依靠默认值来避免使用null可能不是一个足够好的理由。
有想要购买正版授权的朋友,欢迎咨询客服了解详情>>本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com
文章转载自:Navicat本文主要介绍如何使用DevExpress WPF Grid控件实现节点(Nodes)的遍历,欢迎下载最新版组件体验!
AG Grid 是一个与框架无关的数据网格,它为 React、Angular、Vue 和 Vanilla JS 提供官方支持,本文将重点介绍一些可以使用 AG Grid 添加到应用程序的特性和功能的示例,以及现场演示和示例代码。
从 2025.2 版本开始,用于仪表板创建的 Stimulsoft 产品引入了InclusionMode属性,我们将在本文中对其进行探讨。
本文将为大家介绍如何在Telerik UI for WinForms应用中使用Kendo UI for Angular组件来交换通信和事件,欢迎下载新版组件体验!
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@evget.com
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
慧都科技 版权所有 Copyright 2003-
2025 渝ICP备12000582号-13 渝公网安备
50010702500608号