【MySQL】数据库的 “红绿灯”:非空、主键、外键到底管什么?

【MySQL】数据库的 “红绿灯”:非空、主键、外键到底管什么?

表的约束:表中一定要有各种约束,通过各种约束,保证未来数据库中的数据的准确的;约束的本质是:通过技术手段倒逼程序员,插入正确的数据,进而保证数据库中的数据的正确的;

一、非空约束

两个值:null(默认的)和not null(不为空)

数据库默认字段基本都是字段为空,但是实际开发时,尽可能保证字段不为空,因为数据为空没办法参与运算。

null Vs '' 

null : 表示什么都没有;

'' :有,但是为空;

二、default 约束

default : 跟 C++ 的缺省值一样;

not null  and default:

注意:如果我们的表中没有设置 default 和 not null 约束,他默认 default null,如果设置了 not null 则不会有 default null;

三、comment 列描述

列描述跟注释没什么区别;

四、zerofill 约束

int(10) 没有 zerofill 约束是没有意义的:

相当于 int(10) 里面的 10 就是数字的长度,如果少于 10 个数字,用0来补充显示;

五、主键约束

主键:primary key用来唯一的约束该字段里面的数据,不能重复,不能为空,一张表中最多只能有一个主键;主键所在的列通常是整数类型。

去除主键约束:

添加主键约束:

复合主键:主键不是只能给一列设置,给多列设置主键的就是符合主键;

注意:复合主键只有设置有主键的那几列同时和过往的数据相同时就会产生主键冲突;

六、auto increment 约束

auto_increment:当对应的字段,不给值,会自动的被系统触发,系统会从当前字段中已经有的最大值+1操作,得到一个新的不同的值。通常和主键搭配使用,作为逻辑主键。

自增长的特点:

任何一个字段要做自增长,前提是本身是一个索引(key一栏有值)

自增长字段必须是整数

一张表最多只能有一个自增长

自定义自增长值:

查看最后一次的插入的自增长的值:

七、唯一键

主键不能为空,而唯一键可以为空,NULL 的意思的什么都没有,NULL 不参与计算;

注意:一张表中只能有一个主键,但是可以有多个唯一键;

八、外键

因为学生是从属于某个班级的,所以:

外键主要是:表与表之间的约束;

创建外键:

外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。当定义外键后,要求外键列数据必须在主表的主键列存在或为null。

Read more

C++ 波澜壮阔 40 年:引用、内联函数与现代空指针,效率跃升三基石

C++ 波澜壮阔 40 年:引用、内联函数与现代空指针,效率跃升三基石

🔥@晨非辰Tong: 个人主页 👀专栏:《数据结构与算法入门指南》、《C++学习之旅》 💪学习阶段:C语言、数据结构与算法初学者 ⏳“人理解迭代,神理解递归。” 文章目录 * 引言 * 一、引用:C++前期重难点 * 1.1 一览:引用的方方面面 * 1.2 划重点:引用的正确使用 * 1.3 存疑的地方 * 1.4 const引用 * 1.5 引用和指针的关系(面试必看) * 二、inline内联函数 * 2.1 对要点的详细解释 * 三、宏:nullptr * 总结 引言 C++的演进之路,是不断在性能与安全、灵活与严谨之间寻求平衡的艺术。 本文将深入剖析三大特性:

By Ne0inhk
C++性能优化:提升代码执行效率的艺术

C++性能优化:提升代码执行效率的艺术

C++性能优化:提升代码执行效率的艺术 一、学习目标与重点 本章将深入探讨C++性能优化的核心知识,帮助你掌握提升代码执行效率的艺术。通过学习,你将能够: 1. 理解性能优化的基本概念,掌握性能分析的方法 2. 学会优化内存管理,减少内存泄漏和内存碎片 3. 理解CPU优化技巧,提高代码的执行速度 4. 学会优化I/O操作,提升文件和网络读写的效率 5. 培养性能优化思维,设计高效的代码 二、性能优化的基本概念 2.1 性能优化的原则 性能优化应该遵循以下原则: * 先测量后优化:在优化之前,必须先测量代码的性能,找出瓶颈所在 * 优化瓶颈:只优化对性能影响最大的部分 * 保持代码的可维护性:优化后的代码应该易于理解和维护 * 测试优化结果:优化后必须测试代码的正确性和性能提升效果 2.2 性能分析工具 常用的性能分析工具包括: * GProf:GNU的性能分析工具 * Valgrind:内存调试和性能分析工具

By Ne0inhk

PLI接口与VCS调试生态:连接Verilog与C/C++的魔法桥梁

PLI接口与VCS调试生态:连接Verilog与C/C++的魔法桥梁 在芯片验证的世界里,效率就是生命线。当传统的Verilog验证遇到性能瓶颈时,PLI(Programming Language Interface)技术就像一把瑞士军刀,为验证工程师打开了通往高性能验证的新天地。想象一下,你正在验证一个AI加速器设计,需要在仿真中实时处理数百万个神经元的数据交互——纯Verilog可能让你陷入性能泥潭,而PLI与VCS的结合却能让你游刃有余。 1. PLI技术核心:跨越语言边界的桥梁 PLI的本质是让Verilog具备调用外部C/C++函数的能力,就像在Python中调用NumPy一样自然。这种能力不是简单的接口对接,而是深度的语言级融合。通过三个关键机制实现: * TF(Task/Function)例程:处理$display等系统任务 * ACC(Access)例程:直接访问Verilog内部数据结构 * VPI(Verilog Procedural Interface):新一代更强大的接口标准 实际开发中,一个典型的PLI函数生命周期是这样的: #includ

By Ne0inhk
使用现代C++构建高效日志系统的分步指南

使用现代C++构建高效日志系统的分步指南

使用现代C++构建高效日志系统的分步指南 * 1. 确定日志系统的需求和目标 * 2. 设计日志系统的架构 * 3. 实现阶段 * 3.1 实现日志管理器(LogManager) * 3.2 实现日志记录器(Logger) * 3.3 实现日志格式化器(Formatter) * 3.4 实现日志输出器(Outputter) * 3.5 实现日志文件轮转 * 3.6 实现异常处理 * 3.7 实现性能优化 * 4. 测试和验证 * 5. 文档编写 * 6. 总结 在软件开发中,日志系统扮演着关键角色,帮助开发者记录程序运行状态、调试问题以及监控系统性能。使用现代C++构建一个高效且灵活的日志系统,不仅可以提升开发效率,还能增强程序的可维护性和可靠性。以下是构建这样一个日志系统的详细分步指南: 1. 确定日志系统的需求和目标

By Ne0inhk